使用guice,mybatis和c3p0或bonecp配置连接池大小

时间:2014-09-23 20:10:56

标签: connection connection-pooling guice c3p0 bonecp

我使用Guice / Mybatis来管理和执行我对MySQL数据库的查询。我设置连接并扩展MyBatisModule的类包含以下相关位:

Properties myBatisProperties = new Properties();
myBatisProperties.setProperty("c3p0.maxPoolSize", "5");
myBatisProperties.setProperty("c3p0.initialPoolSize", "5");
bindDataSourceProviderType(C3p0DataSourceProvider.class);
bindTransactionFactoryType(JdbcTransactionFactory.class);
addMapperClass(getMapperClass());
Names.bindProperties(binder(), myBatisProperties);
bind(getBindServiceClass()).to(getBindServiceToClass());

当我使用c3p0或bonecp使用bonecp.maxConnectionsPerPartitionbonecp.partitionCount的属性配置,并使用适当的DataSourceProvider.class代替C3p0DataSourceProvider时,c3p0和bonecp都会忽略我的最大连接配置,只需打开(并保持打开)每个查询的新连接,直到mysql用完可用连接。

当我使用默认的mybatis池提供程序PooledDataSourceProvider及其属性mybatis.pooled.maximumActiveConnectionsmybatis.pooled.maximumIdleConnections时,它会正确地遵循我的配置和池连接。

我做错了什么?

有关此问题的进一步文档,请访问http://mybatis.github.io/guice/datasources.html

1 个答案:

答案 0 :(得分:0)

看起来这个问题是由于我每次创建一个新的注射器。特别是这一行:

Injector injector = Guice.createInjector(new MyDAOPoolModule()); return injector.getInstance(MyDAOService.class);

如果我将注射器设为单个,它只创建一个池。