1

我在 Ubuntu 16.04 上的 2 个节点上安装了 MariaDB Galera 集群。

这里来自node1的信息:

root@localhost:~# sudo more /etc/mysql/conf.d/galera.cnf
[mysqld]
binlog_format=ROW
default-storage-engine=innodb
innodb_autoinc_lock_mode=2
bind-address=0.0.0.0
# Galera Provider Configuration
wsrep_on=ON
wsrep_provider=/usr/lib/galera/libgalera_smm.so
# Galera Cluster Configuration
wsrep_cluster_name="galera_cluster"
wsrep_cluster_address="gcomm://192.168.143.81,192.168.148.75"

# Galera Synchronization Configuration
wsrep_sst_method=rsync

# Galera Node Configuration
wsrep_node_address="192.168.143.81"
wsrep_node_name="Node1"

这里是来自node2的信息:

mysqld]
binlog_format=ROW
default-storage-engine=innodb
innodb_autoinc_lock_mode=2
bind-address=0.0.0.0
# Galera Provider Configuration
wsrep_on=ON
wsrep_provider=/usr/lib/galera/libgalera_smm.so
# Galera Cluster Configuration
wsrep_cluster_name="galera_cluster"
wsrep_cluster_address="gcomm://192.168.143.81,192.168.148.75"

# Galera Synchronization Configuration
wsrep_sst_method=rsync

# Galera Node Configuration
wsrep_node_address="192.168.148.75"
wsrep_node_name="Node2”

我正在从 Java 应用程序访问数据库。具有以下属性:

spring.datasource.url=jdbc:mysql://192.168.143.81:3306/can_peris_db
spring.datasource.username=peris
spring.datasource.password=3nRam0nD3L3s0l1v3s
spring.jpa.show-sql=false
spring.jpa.properties.hibernate.format_sql=true
hibernate.dialect=org.hibernate.dialect.MySQLDialect

一切正常,数据在两个数据库中都复制了。但是当我关闭服务器 192.168.143.81 时出现错误java.net.NoRouteToHostException: No route to host (Host unreachable)

有没有办法自动连接到可用的主机?

4

2 回答 2

0

需要设置浮动IP并安装Keepalived

于 2018-08-01T15:34:32.857 回答
0

你有几个选择。查看MariaDB JDBC 连接器文档

例如,如果您只想有一个故障转移方案,您应该以这种方式设置 jdbc url:

jdbc:mariadb:sequential://mainHost,failoverHost/your_database?autoReconnect=true

“顺序”模式意味着应用程序将尝试始终连接到第一个主机并仅在第一个节点不可用时切换到故障转移节点。

希望这可以帮助。

于 2018-10-26T18:43:29.547 回答