接上期,MySQL主从同步咱们已经部署完成,接下来,咱们开始部署本期的核心---MMM高可用集群mysql
4、MMM高可用集群部署c++
一、安装依赖包web
因为mmm 是用perl语言写的脚本程序,所以须要在5台服务器中分别安装 perl 和 perl-CPANsql
[root@cluster-mysqlb ~]# yum -y install perl perl-CPANshell
二、yum 安装 mmm数据库
a、在4台 MySQL 服务器中安装 mysql-mmm-agentvim
[root@cluster-mysqla ~]# yum -y install gcc gcc-c++ mysql-mmm-agent服务器
b、在 monitor 服务器中安装 mysql-mmm-monitor网络
[root@cluster-proxy ~]# yum -y install gcc gcc-c++ mysql-mmm-monitorapp
三、配置 mmm
mysql-mmm 的配置文件在 /etc/mysql-mmm目录下,进入该目录
mysql-mmm-agent 配置文件
mysql-mmm-monitor 配置文件
如图,mysql-mmm-agent 的配置文件只有2个,mmm_agent.conf 和 mmm_common.conf,而 mysql-mmm-monitor 的配置文件有4个,本来是3个,由于我这里安装了 mysql-mmm-tools ,所以多了一个mmm_tools.conf
a、修改公共配置文件 mmm_common.conf
[root@cluster-mysqla mysql-mmm]# vim mmm_common.conf
如图:
(1)、字段解释
active_master_role writer #主动的master角色标示,全部数据库服务器都须要开启 read_only 参数,而对于 Write 服务器,监控服务器会自动将 read_only 属性关闭,也就是将其值设为1 <host default> cluster_interface eth0 #集群网络接口 pid_path /run/mysql-mmm-agent.pid #mmm-agent进程pid文件路径 bin_path /usr/libexec/mysql-mmm/ #可执行文件路径 replication_user slaveuser #复制用户 replication_password 123456 #复制用户的密码 agent_user mmmagent #代理用户 agent_password 123456 #代理用户的密码 </host> <host mastera> #这里写 mastera 的主机名 ip 192.168.20.134 #mastera 的 IP 地址 mode master #角色模式:master 表示主库 peer masterb #与 mastera 同等的主库的主机名称,也就是说向 mastera 同步数据的数据库的主机的名称,所以为 masterb </host> <host masterb> #这里的属性同 mastera ip 192.168.20.128 mode master peer mastera </host> <host slavea> #从库的主机名称 ip 192.168.20.129 #从库的 IP 地址 mode slave #角色模式:该主机为 masterb 的从数据库,所以为 slave </host> <host slaveb> #这里的属性同 slavea mode slave </host> <role writer> #Write 角色配置 hosts mastera, masterb #具备写操做的主机名称,这里的配置能够写单个,也能够写多个,写单个的时候,能够避免在网络延迟过大时切换Write,可是当master出现故障时,就没法进行write了,只能对外提供read操做了 ips 192.168.20.254 #对外提供写操做的虚拟 IP 地址 mode exclusive #模式,exclusive 表示只容许存在一个主数据库,也就是只能写 一个虚拟 IP 地址 </role> <role reader> #read 角色配置 hosts slavea, slaveb #对外提供 read 操做的服务器的主机的名称,这里也能够写master进来,写进来时,master也对外提供 read 操做 ips 192.168.20.253, 192.168.20.252 #对外提供 read 操做的虚拟 IP 地址,为了实现负载均衡,这里的虚拟 IP 地址至少应该和 read 数据库服务器数量相同 mode balanced #模式,balanced 表示负载均衡 </role> |
(2)、mmm_common.conf配置文件修改
若是在服务器中有多张网卡,则须要在 cluster_interface 字段中指定网卡名称
按照上面的格式修改公共配置文件,修改完后复制到其余4台服务器中
scp /etc/mysql-mmm/mmm_common.conf root@192.168.20.128:/etc/mysql-mmm
scp /etc/mysql-mmm/mmm_common.conf root@192.168.20.129:/etc/mysql-mmm
scp /etc/mysql-mmm/mmm_common.conf root@192.168.20.130:/etc/mysql-mmm
scp /etc/mysql-mmm/mmm_common.conf root@192.168.20.131:/etc/mysql-mmm
(3)、mmm_agent.conf配置文件修改
[root@cluster-mysqla mysql-mmm]# vim mmm_agent.conf
如图,改配置文件只须要修改图中标示部分,所以,若是服务器是 mastera ,就改成 this mastera ,若是服务器是 masterb ,就改成 this masterb ,以此类推
(4)、修改 mysql-mmm-monitor 的配置文件 mmm_mon.conf
[root@cluster-proxy mysql-mmm]# vim mmm_mon.conf
如上图,字段解释
include mmm_common.conf #调用 mmm_common.conf 配置文件 <monitor> ip 192.168.20.131 #监控主机 IP 地址 pid_path /run/mysql-mmm-monitor.pid #监控进程 pid 文件目录 bin_path /usr/libexec/mysql-mmm #可执行文件目录 status_path /var/lib/mysql-mmm/mmm_mond.status ping_ips 192.168.20.134, 192.168.20.128, 192.168.20.129, 192.168.20.130 #这里写4台数据库服务器的 IP 地址 auto_set_online 60 # The kill_host_bin does not exist by default, though the monitor will # throw a warning about it missing. See the section 5.10 "Kill Host # Functionality" in the PDF documentation. # # kill_host_bin /usr/libexec/mysql-mmm/monitor/kill_host # </monitor> <host default> monitor_user monitor #监控用户 monitor_password 123456 #监控用户密码 </host> debug 0 |
按照上面的格式,配置好 mmm_mond.conf
b、启动 mmm 服务
在4台 MySQL 服务器中启动 mysql-mmm-agent 服务
[root@cluster-mysqla mysql-mmm]# mmm_agentd start
在监控服务器中驱动 mysql-mmm-monitor 服务
[root@cluster-proxy mysql-mmm]# mmm_mond start
c、在 monitor 服务器查看其余4台服务器的状态
[root@cluster-proxy mysql-mmm]# mmm_control show
如上图,表示4台数据库服务器配置 mmm 配置 OK。
d、测试虚拟 IP 地址是否可以 ping 通
若是可以 ping 通,说明 mysql-mmm 部署成功,若是没法 ping 通,则说明在主机上虚拟 IP 地址没有设置成功,这时候,咱们须要在 5 台数据库服务器上执行如下命令
[root@cluster-mysqla mysql-mmm]# perl -MCPAN -e shell
如图:
cpan[1]> install Net::ARP
若是在执行 perl -MCPAN -e shell 该命令时报错 Can't locate CPAN.pm in @INC (@INC contains: /usr/local/lib/perl5 /usr/local/share/perl5 /usr/lib/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib/perl5 /usr/share/perl5 .).
说明,咱们没有安装 perl-CPAN,用 yum 安装便可
执行完上述命令以后,在分别在4台服务器中执行下列命令
mastera
[root@cluster-mysqla mysql-mmm]# /usr/libexec/mysql-mmm/agent/configure_ip /etc/mysql-mmm/mmm_common.conf ens33 192.168.20.254
masterb
[root@cluster-mysqlb mysql-mmm]# /usr/libexec/mysql-mmm/agent/configure_ip /etc/mysql-mmm/mmm_common.conf ens33 192.168.20.254
slavea
[root@cluster-mysqlc mysql-mmm]# /usr/libexec/mysql-mmm/agent/configure_ip /etc/mysql-mmm/mmm_common.conf ens33 192.168.20.253
slaveb
[root@cluster-mysqld mysql-mmm]# /usr/libexec/mysql-mmm/agent/configure_ip /etc/mysql-mmm/mmm_common.conf ens33 192.168.20.252
执行上面命令以后,在 ping 虚拟 IP 地址,ping 测试 OK,可以 ping 通
最后,在查看4台数据库服务器的状态
[root@cluster-proxy mysql-mmm]# mmm_control checks all
如图:
若是全是 OK ,说明咱们的 mysql-mmm 服务部署成功
上面的地2列的意思分别是:
ping:ping 测试,能够 ping 通时 OK,不然,请按照上述操做检查
mysql:mysql server 在线时 OK,不然,请检查 mysql server 是否有中止
rep_threadh:复制线程正在运行时 OK,不然请排查复制线程未运行的缘由,常见可能缘由为:一、监控和复制所用的用户名、密码错误;二、主从同步出现故障
rep_backlog:复制挤压的日志不多时 OK,不然多是服务器处理速度太慢或者数据量太大
e、mmm_control 名词解释
如图:
check:查看指定 host 或者全部主机的指定状态或者全部状态
show:查看当前集群状态
set_online:把 host 的状态由AWAITING_RECOVERY或者ADMIN_OFFLINE恢复到ONLINE
set_offline:把 host 的状态手动设置为ADMIN_OFFLINE,而且会中止mysql复制
mode:打印当前monitor的运行模式
set_active:切换monitor进程为主动模式
set_passive:切换monitor进程为被动模式
set_manual:切换monitor进程为手动模式
move_role:将write角色切换到其余主机
f、测试mysql-mmm在服务故障状况下是否可以自动切换,这里值提供方法
测试方法为:
中止 mastera 的 mysql 服务,查看 writer(192.168.20.254) 是否可以切换到 masterb,随后开启 mastera 的 mysql 服务,在手动中止 masterb 的 mysql 服务,查看 writer(192.168.20.254) 是否可以切换到 mastera ,若是都能,则说明,咱们的mysql-mmm集群部署时OK的,若是不能,请检查mmm_common.conf配置文件是否有错。固然还有其余测试思路,这里就不一一列举了。
5、链接MMM集群
部署完 mysql-mmm 集群,这时候咱们就火烧眉毛的想要用咱们现有的应用服务去链接
首先,咱们在mastera新建一个MySQL帐号game
mysql> grant all privileges on *.* to game@"%" identified by "123456";
mysql> flush privileges;
而后,咱们在咱们的应用服务器上链接虚拟 IP(192.168.20.25四、192.168.20.25三、192.168.20.252)
a、链接192.168.20.254建立一个数据库
[root@weba ~]# mysql -h192.168.20.254 -ugame -p123456
MySQL [(none)]> create database web;
b、链接192.168.20.25三、192.168.20.252查看刚才建立的数据库是否存在
[root@webb ~]# mysql -h192.168.20.253 -ugame -p123456
[root@webb ~]# mysql -h192.168.20.252 -ugame -p123456
有图可见,咱们链接192.168.20.254建立的数据库,在链接192.168.20.253和192.168.20.252后也能看获得,说明一切OK
注意:链接192.168.20.254时,最好可以切换 mastera 和 masterb 进行链接建库测试,在这期间有可能会出现如下报错:
1209 - The MySQL server is running with the --read-only option so it cannot execute this statement
出现这个错误缘由是,mmm 将主数据库设置成了只读模式,咱们只须要执行 set global read_only=0; 便可
到此为止,咱们的MySQL主从同步+MMM高可用集群部署完成,咱们也列举了一些在部署过程当中可能会踩到的坑,可是,在线上部署中,须要具体问题具体分析,因此,在之后的生活中,小弟还会和大佬们共同成长。
对于以上部署过程,如有疑问,可参照 官方安装文档 。
本节完。