【问题标题】:Java application connecting to replicated mysql databasesJava 应用程序连接到复制的 mysql 数据库
【发布时间】:2012-07-27 15:59:54
【问题描述】:

我们有一个连接到 mysql 数据库的 java 应用程序。我们现在将通过添加另一个数据库实例将数据库更改为复制模式。这个想法是提供数据库高可用性。应用程序应该能够切换到备用数据库,以防无法连接到主数据库。实现这一点的一种方法是维护 2 组连接,持续监控两个数据库,如果应用无法连接到主数据库,则切换到下一组连接并继续。

我的问题是是否有一种通过 mysql 连接器本身切换连接的透明方式?或者是否有任何实用程序可以位于我的应用程序和 mysql 连接器之间并完成这项工作?

为了澄清,我们计划进行主-主复制。写入和读取都频繁发生。

【问题讨论】:

  • 你能澄清一下这个复制将是一个循环复制吗?如果你只是做一个标准的复制配置,你永远不想写副本,因为这样做可能会破坏复制。

标签: java mysql database-replication


【解决方案1】:

是的,Connector/J(MySQL JDBC 驱动程序)提供连接故障转移。

不过,设置起来并非易事。这应该可以帮助您入门。

http://dev.mysql.com/doc/refman/5.5/en/connector-j-usagenotes-j2ee-concepts-load-balancing-failover.html

@Mike Brant 的观点很好。如果您的数据不经常写入/经常读取,那么您最好只让您的应用程序写入主 DBMS,并从从属 DBMS 池中读取。对应用程序的写入部分和将读取数据的部分使用不同的连接是一种很好的编程习惯。您可以使用负载平衡和故障转移设置只读连接,同时让写入连接指向主节点。

【讨论】:

    猜你喜欢
    • 2013-03-21
    • 1970-01-01
    • 1970-01-01
    • 2017-01-08
    • 2011-07-28
    • 2014-11-26
    • 2015-03-16
    • 2014-11-05
    相关资源
    最近更新 更多