• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Spring Boot项目同时使用druid和另一种连接池来连接Click House

武飞扬头像
daggerin7
帮助1

springboot项目用druid连接MySQL,使用JDBC连clickhouse。一段时候后clickhouse的JDBC响应很慢,想着是网络问题,加上一直使用JDBC连,每次JDBC都要新建tcp连接消耗网络资源,太low,决定加上连接池。(clickhouse的jdbc用jar包是 clickhouse-native-jdbc,想用9000端口,tcp连接)

如果复用druid的连接池,一个问题是多数据源配置druid要加代码,spring的AbstractRoutingDataSource那一套,另一个问题是druid那套公司前辈已经封装好jar包,还得找他要项目,重新开发,打包成jar包、所以决定换另一个连接池hikari。遇到了点问题,

正常应该大概这么写

  1.  
    @Configuration
  2.  
     
  3.  
    public class ClickhouseDataSourceFactory{
  4.  
     
  5.  
         @Value("${clickhouse.datasource.url:}")
  6.  
        private String url;
  7.  
     
  8.  
        @Value("${clickhouse.datasource.user:}")
  9.  
        private String user;
  10.  
     
  11.  
            xxxxxxx一堆配置
  12.  
     
  13.  
            @Bean
  14.  
     
  15.  
            public DataSource clickhouseDataSource{
  16.  
     
  17.  
                    HikariConfig hikariConfig = new HikariConfig();
  18.  
     
  19.  
                    hikariConfig.setUsername(user);
  20.  
     
  21.  
                    hikariConfig.setJdbcUrl(url);//一堆配置
  22.  
     
  23.  
                    return new HikariDataSource(hikariConfig);
  24.  
     
  25.  
            }
  26.  
     
  27.  
    }
  28.  
     
  29.  
    public class TestServiceImpl implements TestService{
  30.  
     
  31.  
            @Autowired
  32.  
     
  33.  
            DataSource clickhouseDataSource;
  34.  
     
  35.  
            Connection c = clickhouseDataSource.getConnection();
  36.  
     
  37.  
            PreparedStatement ps = c.prepareStatement(sql); 
  38.  
     
  39.  
            ResultSet result = ps.executeQuery();
  40.  
     
  41.  
    }
学新通

结果呢,直接导致我们druid下的mysql也连到这个clickhouse的datasource了,然后报错了,找不到表之类的。原因没有深究,应该要么是重名啥的,要么是bean加载的时候问题,要么就还得用AbstractRoutingDataSource来搞。本想解决响应慢的问题,来不及看了。

没办法换一个方法,先搞定连接池,解决响应慢的问题再说,

  1.  
    @Component
  2.  
    public class ClickHouseDataSourceFactory {
  3.  
            
  4.  
    @Value("${clickhouse.datasource.db}")
  5.  
    private String database;
  6.  
     
  7.  
    @Value("${clickhouse.datasource.user}")
  8.  
    private String user;
  9.  
      xxxxxxx还是那堆配置
  10.  
     
  11.  
    @PostConstruct
  12.  
    private DataSource ds;
  13.  
     
  14.  
    public void init() throws Exception {
  15.  
    HikariConfig config = new HikariConfig();
  16.  
    config.setUsername(user);
  17.  
    ds = new HikariDataSource(config);
  18.  
    }
  19.  
    public DataSource getDataSource(){
  20.  
    return ds;
  21.  
    }
  22.  
    }
学新通

搞的像全局变量一样。然后项目启动时,druid会先加载,然后hikari的pool还是创建。之前的问题就没有了,druid和hikari都正常运行。

不过响应慢的问题用了连接池后没有太大改善,下篇再说。

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgcgiji
系列文章
更多 icon
同类精品
更多 icon
继续加载