如何使用 HikariDataSource 在 logBack 中配置 DBappender 的池大小?

Ant*_*lop 4 datasource logback hikaricp

这是我使用 HikariDatasource 的 logback 配置:

<appender name="AUDIT-DB" class="ch.qos.logback.classic.db.DBAppender">
    <connectionSource class="ch.qos.logback.core.db.DataSourceConnectionSource">
        <dataSource class="com.zaxxer.hikari.HikariDataSource">
            <driverClassName>com.mysql.jdbc.Driver</driverClassName>
            <jdbcUrl>jdbc:mysql://myurl:3306/audit?useUnicode=true&amp;characterEncoding=utf8&amp;useSSL=false</jdbcUrl>
            <username>mysqlciuser</username>
            <password>mysqlcipwd</password>
        </dataSource>
    </connectionSource>
</appender>
Run Code Online (Sandbox Code Playgroud)

在 logback https://logback.qos.ch/manual/appenders.html的文档中,我没有找到限制数据源创建的默认池大小(10)的方法。我尝试使用标签 : <maxPoolSize>5</maxPoolSize>但它不起作用。

谢谢你的帮助。

Ser*_*gey 5

您应该使用以下配置行:

<maximumPoolSize>50</maximumPoolSize>
Run Code Online (Sandbox Code Playgroud)

问题是在 HikariConfig 中 setter 和字段名称是矛盾的:

 @Override
   public void setMaximumPoolSize(int maxPoolSize)
   {
      if (maxPoolSize < 1) {
         throw new IllegalArgumentException("maxPoolSize cannot be less than 1");
      }
      this.maxPoolSize = maxPoolSize;
   }
Run Code Online (Sandbox Code Playgroud)