我使用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.maxConnectionsPerPartition
和bonecp.partitionCount
的属性配置,并使用适当的DataSourceProvider.class
代替C3p0DataSourceProvider
时,c3p0和bonecp都会忽略我的最大连接配置,只需打开(并保持打开)每个查询的新连接,直到mysql用完可用连接。
当我使用默认的mybatis池提供程序PooledDataSourceProvider
及其属性mybatis.pooled.maximumActiveConnections
和mybatis.pooled.maximumIdleConnections
时,它会正确地遵循我的配置和池连接。
我做错了什么?
有关此问题的进一步文档,请访问http://mybatis.github.io/guice/datasources.html
答案 0 :(得分:0)
看起来这个问题是由于我每次创建一个新的注射器。特别是这一行:
Injector injector = Guice.createInjector(new MyDAOPoolModule());
return injector.getInstance(MyDAOService.class);
如果我将注射器设为单个,它只创建一个池。