zoukankan      html  css  js  c++  java
  • SpringBoot 多数据库支持:

    SpringBoot 多数据库支持:

    springboot2.0+mybatis多数据源集成

    https://www.cnblogs.com/cdblogs/p/9275883.html

     

    Springboot + Mybatis 多数据源配置

    https://www.cnblogs.com/dannyyao/p/7009264.html

    springboot-mybatis整合多数据源

    https://blog.csdn.net/tuesdayma/article/details/81081666

    Springboot整合mybatis的多数据源配置与使用(XML版)

    https://www.jianshu.com/p/6291068f130c

    ____SpringBoot +MSSQL________________________________________________________________________________

    https://www.cnblogs.com/wang-yaz/p/9561188.html  ******************这篇最重要

    4.从事务管理器中选择一个事务,在方法上加@Transactional(value = "mysqlTransactionManager",rollbackFor = Exception.class)

    https://www.cnblogs.com/memoryXudy/p/7767741.html

    基本项目框架搭建 sqlserver druid配置

     

      1.  我的连接池采用的是阿里云的druid的连接池,工具是IDEA 框架是springboot+maven

       以下是我的项目框架结构

      

     2. pom  中配置

    复制代码
    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>cn.xudy.sqlservice</groupId>
        <artifactId>StorageSqlService</artifactId>
        <version>1.0-SNAPSHOT</version>
    
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>1.5.4.RELEASE</version>
            <relativePath/>
        </parent>
    
        <dependencies>
    
    
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>druid</artifactId>
                <version>1.0.25</version>
            </dependency>
            <dependency>
                <groupId>com.microsoft.sqlserver</groupId>
                <artifactId>sqljdbc4</artifactId>
                <version>4.0</version>
            </dependency>
            <!-- Spring Boot JDBC -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-jdbc</artifactId>
            </dependency>
    
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
        </dependencies>
    
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    
    </project>
    复制代码

    2. .properties 配置

    复制代码
    server.port=8011
    
    druid.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
    
    
    druid.url=jdbc:sqlserver://localhost:1433;DatabaseName=test
    druid.username=sa
    druid.password=123456
    复制代码

     3. SystemConfig 配置

    复制代码
    package cn.xudy.group.config;
    
    
    
    
    import com.alibaba.druid.pool.DruidDataSource;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
    import org.springframework.boot.context.properties.ConfigurationProperties;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.Primary;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.stereotype.Component;
    import org.springframework.web.servlet.config.annotation.CorsRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
    
    import javax.sql.DataSource;
    
    /**
     * Created by Ulegal on 2017/8/19.
     */
    @Configuration
    public class SystemConfig {
    
    
                @Bean(name = "dataSource")
                @Qualifier(value = "dataSource")
                @Primary
                @ConfigurationProperties(prefix = "druid")
                public DataSource dataSource() {
                    return DataSourceBuilder.create().type(DruidDataSource.class).build();
    
                }
    
    
        /**
         * 跨域
         * @return
         */
        @Bean
        public WebMvcConfigurer corsConfigurer() {
            return new WebMvcConfigurerAdapter() {
                @Override
                public void addCorsMappings(CorsRegistry registry) {
                    registry.addMapping("/**");
                }
            };
        }
    
    }
    复制代码

    4. dao数据层测试

    复制代码
    @Repository
    public class StorageDaoImpl implements StorageDao{
    
        @Autowired
        JdbcTemplate jdbcTemplate;
    
        @Override
        public List<Map<String, Object>> getInfo() {
    
    
            // 传统方法
            List<Map<String,Object>> list = new ArrayList<Map<String, Object>>();
            String  sql  =   "SELECT * FROM " + "Table_1" +";";
            list = jdbcTemplate.queryForList(sql);
            System.out.println("-------------"+list);
    
            return list;
        }
    复制代码

       搞定

    ______________________________________________________________________________________________________________

    SpringBoot数据库连接池常用配置

     

    关注公众号:程序猿王国         持续更新,每日分享

    在配置文件中添加配置如下(我使用的是多数据源):

    spring.datasource.primary.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8
    spring.datasource.primary.username=test
    spring.datasource.primary.password=123456
    spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver
    #验证连接的有效性
    spring.datasource.primary.test-while-idle=true
    #获取连接时候验证,会影响性能
    spring.datasource.primary.test-on-borrow=false
    #在连接归还到连接池时是否测试该连接
    spring.datasource.primary.test-on-return=false
    spring.datasource.primary.validation-query=SELECT 1 FROM DUAL
    #空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
    spring.datasource.primary.time-between-eviction-runs-millis=300000
    #连接池空闲连接的有效时间 ,设置30分钟
    spring.datasource.primary.min-evictable-idle-time-millis=1800000
    spring.datasource.primary.initial-size=5
    #指定连接池中最大的活跃连接数.
    spring.datasource.primary.max-active=50
    #指定连接池等待连接返回的最大等待时间,毫秒单位.
    spring.datasource.primary.max-wait=60000
    #指定必须保持连接的最小值
    spring.datasource.primary.min-idle=5

    spring.datasource.secondary.url=jdbc:mysql://localhost:3306/test2?useUnicode=true&characterEncoding=utf-8
    spring.datasource.secondary.username=test
    spring.datasource.secondary.password=123456
    spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver
    #验证连接的有效性
    spring.datasource.secondary.test-while-idle=true
    #获取连接时候验证,会影响性能
    spring.datasource.secondary.test-on-borrow=false
    #在连接归还到连接池时是否测试该连接
    spring.datasource.secondary.test-on-return=false
    spring.datasource.secondary.validation-query=SELECT 1 FROM DUAL
    #空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
    spring.datasource.secondary.time-between-eviction-runs-millis=300000
    #连接池空闲连接的有效时间 ,设置30分钟
    spring.datasource.secondary.min-evictable-idle-time-millis=1800000
    spring.datasource.secondary.initial-size=5
    #指定连接池中最大的活跃连接数.
    spring.datasource.secondary.max-active=50
    #指定连接池等待连接返回的最大等待时间,毫秒单位.
    spring.datasource.secondary.max-wait=60000
    #指定必须保持连接的最小值
    spring.datasource.secondary.min-idle=5

    datasource

    • spring.dao.exceptiontranslation.enabled是否开启PersistenceExceptionTranslationPostProcessor,默认为true

    • spring.datasource.abandon-when-percentage-full设定超时被废弃的连接占到多少比例时要被关闭或上报

    • spring.datasource.allow-pool-suspension使用Hikari pool时,是否允许连接池暂停,默认为: false

    • spring.datasource.alternate-username-allowed是否允许替代的用户名.

    • spring.datasource.auto-commit指定updates是否自动提交.

    • spring.datasource.catalog指定默认的catalog.

    • spring.datasource.commit-on-return设置当连接被归还时,是否要提交所有还未完成的事务

    • spring.datasource.connection-init-sql指定连接被创建,再被添加到连接池之前执行的sql.

    • spring.datasource.connection-init-sqls使用DBCP connection pool时,指定初始化时要执行的sql

    • spring.datasource.connection-properties.[key]在使用DBCP connection pool时指定要配置的属性

    • spring.datasource.connection-test-query指定校验连接合法性执行的sql语句

    • spring.datasource.connection-timeout指定连接的超时时间,毫秒单位.

    • spring.datasource.continue-on-error在初始化数据库时,遇到错误是否继续,默认false

    • spring.datasource.data指定Data (DML)脚本

    • spring.datasource.data-source-class-name指定数据源的全限定名.

    • spring.datasource.data-source-jndi指定jndi的地址

    • spring.datasource.data-source-properties.[key]使用Hikari connection pool时,指定要设置的属性

    • spring.datasource.db-properties使用Tomcat connection pool,指定要设置的属性

    • spring.datasource.default-auto-commit是否自动提交.

    • spring.datasource.default-catalog指定连接默认的catalog.

    • spring.datasource.default-read-only是否设置默认连接只读.

    • spring.datasource.default-transaction-isolation指定连接的事务的默认隔离级别.

    • spring.datasource.driver-class-name指定driver的类名,默认从jdbc url中自动探测.

    • spring.datasource.fair-queue是否采用FIFO返回连接.

    • spring.datasource.health-check-properties.[key]使用Hikari connection pool时,在心跳检查时传递的属性

    • spring.datasource.idle-timeout指定连接多久没被使用时,被设置为空闲,默认为10ms

    • spring.datasource.ignore-exception-on-pre-load当初始化连接池时,是否忽略异常.

    • spring.datasource.init-sql当连接创建时,执行的sql

    • spring.datasource.initial-size指定启动连接池时,初始建立的连接数量

    • spring.datasource.initialization-fail-fast当创建连接池时,没法创建指定最小连接数量是否抛异常

    • spring.datasource.initialize指定初始化数据源,是否用data.sql来初始化,默认: true

    • spring.datasource.isolate-internal-queries指定内部查询是否要被隔离,默认为false

    • spring.datasource.jdbc-interceptors使用Tomcat connection pool时,指定jdbc拦截器,分号分隔

    • spring.datasource.jdbc-url指定JDBC URL.

    • spring.datasource.jmx-enabled是否开启JMX,默认为: false

    • spring.datasource.jndi-name指定jndi的名称.

    • spring.datasource.leak-detection-threshold使用Hikari connection pool时,多少毫秒检测一次连接泄露.

    • spring.datasource.log-abandoned使用DBCP connection pool,是否追踪废弃statement或连接,默认为: false

    • spring.datasource.log-validation-errors当使用Tomcat connection pool是否打印校验错误.

    • spring.datasource.login-timeout指定连接数据库的超时时间.

    • spring.datasource.max-active指定连接池中最大的活跃连接数.

    • spring.datasource.max-age指定连接池中连接的最大年龄

    • spring.datasource.max-idle指定连接池最大的空闲连接数量.

    • spring.datasource.max-lifetime指定连接池中连接的最大生存时间,毫秒单位.

    • spring.datasource.max-open-prepared-statements指定最大的打开的prepared statements数量.

    • spring.datasource.max-wait指定连接池等待连接返回的最大等待时间,毫秒单位.

    • spring.datasource.maximum-pool-size指定连接池最大的连接数,包括使用中的和空闲的连接.

    • spring.datasource.min-evictable-idle-time-millis指定一个空闲连接最少空闲多久后可被清除.

    • spring.datasource.min-idle指定必须保持连接的最小值(For DBCP and Tomcat connection pools)

    • spring.datasource.minimum-idle指定连接维护的最小空闲连接数,当使用HikariCP时指定.

    • spring.datasource.name指定数据源名.

    • spring.datasource.num-tests-per-eviction-run指定运行每个idle object evictor线程时的对象数量

    • spring.datasource.password指定数据库密码.

    • spring.datasource.platform指定schema要使用的Platform(schema-${platform}.sql),默认为: all

    • spring.datasource.pool-name指定连接池名字.

    • spring.datasource.pool-prepared-statements指定是否池化statements.

    • spring.datasource.propagate-interrupt-state在等待连接时,如果线程被中断,是否传播中断状态.

    • spring.datasource.read-only当使用Hikari connection pool时,是否标记数据源只读

    • spring.datasource.register-mbeans指定Hikari connection pool是否注册JMX MBeans.

    • spring.datasource.remove-abandoned指定当连接超过废弃超时时间时,是否立刻删除该连接.

    • spring.datasource.remove-abandoned-timeout指定连接应该被废弃的时间.

    • spring.datasource.rollback-on-return在归还连接时,是否回滚等待中的事务.

    • spring.datasource.schema指定Schema (DDL)脚本.

    • spring.datasource.separator指定初始化脚本的语句分隔符,默认: ;

    • spring.datasource.sql-script-encoding指定SQL scripts编码.

    • spring.datasource.suspect-timeout指定打印废弃连接前的超时时间.

    • spring.datasource.test-on-borrow当从连接池借用连接时,是否测试该连接.

    • spring.datasource.test-on-connect创建时,是否测试连接

    • spring.datasource.test-on-return在连接归还到连接池时是否测试该连接.

    • spring.datasource.test-while-idle当连接空闲时,是否执行连接测试.

    • spring.datasource.time-between-eviction-runs-millis指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔

    • spring.datasource.transaction-isolation指定事务隔离级别,使用Hikari connection pool时指定

    • spring.datasource.url指定JDBC URL.

    • spring.datasource.use-disposable-connection-facade是否对连接进行包装,防止连接关闭之后被使用.

    • spring.datasource.use-equals比较方法名时是否使用String.equals()替换==.

    • spring.datasource.use-lock是否对连接操作加锁

    • spring.datasource.username指定数据库名.

    • spring.datasource.validation-interval指定多少ms执行一次连接校验.

    • spring.datasource.validation-query指定获取连接时连接校验的sql查询语句.

    • spring.datasource.validation-query-timeout指定连接校验查询的超时时间.

    • spring.datasource.validation-timeout设定连接校验的超时时间,当使用Hikari connection pool时指定

    • spring.datasource.validator-class-name用来测试查询的validator全限定名.

    • spring.datasource.xa.data-source-class-name指定数据源的全限定名.

    • spring.datasource.xa.properties指定传递给XA data source的属性

       spring.datasource.useGlobalDataSourceStat 合并多个DruidDataSource的监控数据
            spring.datasource.druid.filters=stat,wall,log4j # 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙                spring.datasource.druid.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000 # 通过connectProperties属性来打开mergeSql功能;慢SQL记录
     
  • 相关阅读:
    js 屏蔽非数字字符输入
    javaScript注释变成颜文字
    canvas 画图优化
    快速回到顶部
    多行文字垂直居中
    innerHTML 与 outerHTML区别
    高内聚、低耦合
    webstorm快捷键
    HTML、CSS规范
    RabbitMQ学习笔记(3)----RabbitMQ Worker的使用
  • 原文地址:https://www.cnblogs.com/kelelipeng/p/11240479.html
Copyright © 2011-2022 走看看