我有多个网站(大约200个)由同一个Java Web应用程序托管。每个站点都有自己的MySQL数据库。数据库都在同一个MySQL服务器上,并且都使用相同的用户名和密码进行访问。
由于我实现池化的方式,我目前正在耗尽数据库连接。我正在为每个站点的数据库使用C3P0 ComboPooledDataSource。这会创建数百个与数据库服务器的连接,而数据库服务器似乎无法处理它。
是否有一个池化机制可以创建一个数据库连接池,可以用于托管在单个数据库服务器上的所有数据库?
答案 0 :(得分:1)
我发现我可以为第一个数据库创建一个ComboPooledDataSource。然后,当我从数据库池获得连接时,我可以在连接上调用setCatalog(name)
以使用C3P0数据池在同一服务器上使用任何其他数据库。
ComboPooledDataSource cpds = new ComboPooledDataSource();
cpds.setDriverClass("com.mysql.jdbc.Driver");
cpds.setJdbcUrl("jdbc:mysql://localhost:3306/site_a");
cpds.setUser(user);
cpds.setPassword(pass);
....
Connection conn = getPool().getConnection();
conn.setCatalog("site_b");
...
编辑:自写这篇文章后,我切换到Proxool。 setCatalog
的相同技术适用于它,但创建连接的语法不同:
try {
Class.forName("org.logicalcobwebs.proxool.ProxoolDriver");
} catch (ClassNotFoundException e) {
throw new RuntimeException(e);
}
Properties info = new Properties();
info.setProperty("proxool.maximum-connection-count", "20");
info.setProperty("proxool.house-keeping-test-sql", " select CURDATE()");
info.setProperty("user", user);
info.setProperty("password", pass);
info.setProperty("proxool.alias", "mypoolname");
info.setProperty("proxool.url", "jdbc:mysql://localhost:3306/site_a");
info.setProperty("proxool.driver", "com.mysql.jdbc.Driver");
String url = "proxool.mypoolname";
ProxoolDatabasePool pool = new ProxoolDatabasePool(url, info);
....
Connection conn = pool.getConnection();
conn.setCatalog("site_b");
...