1

我有多个由同一个 Java Web 应用程序托管的网站(大约 200 个)。每个站点都有自己的 MySQL 数据库。数据库都在同一个 MySQL 服务器上,并且都使用相同的用户名和密码进行访问。

由于我实现池的方式,我目前正在用完数据库连接。我为每个站点的数据库使用 C3P0 ComboPooledDataSource。这会创建数百个与数据库服务器的连接,而数据库服务器似乎无法处理它。

是否有一种池机制可以创建一个数据库连接池,可用于托管在单个数据库服务器上的所有数据库?

4

1 回答 1

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");
...
于 2013-04-26T15:04:18.587 回答