我有一个TimerTask,每天运行一次(大约1或2个小时).并且在每次运行时,它将创建数百个线程来为MySQL数据库中的每个表执行一些计算工作.我使用c3p0作为数据库源连接池(每个线程在计算之前获得连接并在计算之后关闭连接).我设置连接池配置如下,
cpDs = new ComboPooledDataSource();
cpDs.setMinPoolSize(10);
cpDs.setMaxPoolSize(20);
cpDs.setMaxStatementsPerConnection(10);
Run Code Online (Sandbox Code Playgroud)
在测试期间,我发现在第二天运行时所有数据库连接都丢失了,并且日志文件中显示了许多"由于底层异常导致的通信链路故障".所以我添加了以下配置,以便在使用之前测试连接.
// 7 hours, less than MYSQL default value - 8 hours
cpDs.setMaxIdleTime(25200);
cpDs.setTestConnectionOnCheckout(true);
cpDs.setPreferredTestQuery("select 1");
Run Code Online (Sandbox Code Playgroud)
但我观察到当TimerTask没有运行时,总有10个连接保持睡眠/空闲状态(通过SQL'show processlist;'),我经常看到着名的"APPARENT DEADLOCK !!!" 警告(该错误在c3p0项目中仍处于打开状态http://sourceforge.net/tracker/?func=detail&aid=3432139&group_id=25357&atid=383690).
那么有什么方法可以在完成所有计算工作时关闭所有连接,并在第二天重新构建连接时再次执行任务?谢谢.
问候,乔伊
如果您希望关闭所有连接,请将minPoolSize和设置initialPoolSize为 0。另外,我建议减少maxIdleTime到更小的值,例如 600(10 分钟)。这种设置组合将使池在您的工作人员完成后快速“耗尽”。
reset您还可以使用中公开的方法之一强制所有连接关闭ComboPooledDataSource,但如果池配置正确,则不需要这样做。
| 归档时间: |
|
| 查看次数: |
6151 次 |
| 最近记录: |