MHA脚本管理方式

(1)获取管理脚本master_ip_failover

提示:yum安装的manager是没有这个脚本的。 
我们需要从manager的源码包里复制一个。

 
    1. [root@mysql-db03 ~]# ll mha4mysql-manager-0.56.tar.gz
    2. -rw-r--r--. 1 root root 113914 Sep 4 18:43 mha4mysql-manager-0.56.tar.gz
    3. [root@mysql-db03 ~]# tar xf mha4mysql-manager-0.56.tar.gz
    4. [root@mysql-db03 ~]# cd mha4mysql-manager-0.56
    5. [root@mysql-db03 mha4mysql-manager-0.56]# cd samples/scripts/
    6. [root@mysql-db03 scripts]# ll
    7. total 32
    8. -rwxr-xr-x. 1 4984 users 3648 Mar 31 2014 master_ip_failover #这就是管理虚拟IP的脚本
    9. -rwxr-xr-x. 1 4984 users 9870 Mar 31 2014 master_ip_online_change
    10. -rwxr-xr-x. 1 4984 users 11867 Mar 31 2014 power_manager
    11. -rwxr-xr-x. 1 4984 users 1360 Mar 31 2014 send_report
    12. [root@mysql-db03 scripts]# cp master_ip_failover /usr/local/bin/ #复制到/usr/local/bin目录下
    13. [root@mysql-db03 scripts]# which master_ip_failover
    14. /usr/local/bin/master_ip_failover

(2)修改mha配置文件

 
  1. [root@mysql-db03 scripts]# vim /etc/mha/mha1.cnf
  2. [root@mysql-db03 scripts]# cat /etc/mha/mha1.cnf
  3. [server default]
  4. manager_log=/var/log/mha/mha1/manager
  5. manager_workdir=/var/log/mha/mha1
  6. master_binlog_dir=/usr/local/mysql/data
  7. master_ip_failover_script=/usr/local/bin/master_ip_failover #添加脚本位置
  8. password=666666
  9. ping_interval=2
  10. repl_password=666666
  11. repl_user=rep
  12. ssh_user=root
  13. user=mha
  14. #candidate_master=1 #留着备用的注释项
  15. #check_repl_delay=0 #留着备用的注释项
  16. [server1]
  17. hostname=192.168.200.20
  18. port=3306
  19. [server2]
  20. hostname=192.168.200.28
  21. port=3306
  22. [server3]
  23. hostname=192.168.200.29
  24. port=3306

(3)修改源程序自带VIP漂移脚本

#在下边的脚本里添加如下4行代码: 
[root@mysql-db03 scripts]# sed -n '34,37p' /usr/local/bin/master_ip_failover 
my $vip = '192.168.0.60/24'; #定义VIP my $key = '0'; #定义网卡后缀数值,如果eth0就是0,eth1就是1 
my $ssh_start_vip = "/sbin/ifconfig eth0:$key $vip"; #绑定VIP的命令 my $ssh_stop_vip = "/sbin/ifconfig eth0:$key down"; #关闭VIP的命令

(4)重启动mha管理端

 
  1. [root@mysql-db03 ~]# ps -ef | grep mha | grep -v grep #查看mha进程
  2. root 14138 13211 0 19:22 pts/3 00:00:00 perl /usr/bin/masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover
  3. [root@mysql-db03 ~]# pkill perl #杀掉perl进程
  4. [1]+ Exit 1 nohup masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /var/log/mha/mha1/manager.log 2>&1
  5. [root@mysql-db03 ~]# ps -ef | grep mha | grep -v grep #查看mha进程
  6. [root@mysql-db03 ~]# nohup masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > #启动mha进程 /var/log/mha/mha1/manager.log 2>&1 &

(1)查看mysql-db01网络状态 
 
(2)停掉mysql-db01的MySQL数据库服务

  1. [root@localhost ~]# /etc/init.d/mysqld stop
  2. Shutting down MySQL....... SUCCESS!
  3. [root@localhost ~]# ifconfig #VIP没了
  4. eth0 Link encap:Ethernet HWaddr 00:0C:29:E0:9C:4A
  5. inet addr:192.168.200.20 Bcast:192.168.200.255 Mask:255.255.255.0
  6. inet6 addr: fe80::20c:29ff:fee0:9c4a/64 Scope:Link
  7. UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
  8. RX packets:249568 errors:0 dropped:0 overruns:0 frame:0
  9. TX packets:22184 errors:0 dropped:0 overruns:0 carrier:0
  10. collisions:0 txqueuelen:1000
  11. RX bytes:337973697 (322.3 MiB) TX bytes:3172031 (3.0 MiB)
  12. lo Link encap:Local Loopback
  13. inet addr:127.0.0.1 Mask:255.0.0.0
  14. inet6 addr: ::1/128 Scope:Host
  15. UP LOOPBACK RUNNING MTU:16436 Metric:1
  16. RX packets:66 errors:0 dropped:0 overruns:0 frame:0
  17. TX packets:66 errors:0 dropped:0 overruns:0 carrier:0
  18. collisions:0 txqueuelen:0
  19. RX bytes:10106 (9.8 KiB) TX bytes:10106 (9.8 KiB)

(3)查看mysql-db02 

(4)查看mysql-db03的主从同步情况 

(5)mysql-db01故障恢复

  1. [root@localhost ~]# /etc/init.d/mysqld start
  2. Starting MySQL........ SUCCESS!
  3. [root@localhost ~]# mysql -uroot -p666666
  4. Warning: Using a password on the command line interface can be insecure.
  5. Welcome to the MySQL monitor. Commands end with ; or \g.
  6. Your MySQL connection id is 1
  7. Server version: 5.6.17-log MySQL Community Server (GPL)
  8. Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.
  9. Oracle is a registered trademark of Oracle Corporation and/or its
  10. affiliates. Other names may be trademarks of their respective
  11. owners.
  12. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  13. mysql> CHANGE MASTER TO MASTER_HOST='192.168.200.28', MASTER_PORT=3306, MASTER_AUTO_POSITION=1, MASTER_USER='rep', MASTER_PASSWORD='666666';
  14. Query OK, 0 rows affected, 2 warnings (0.11 sec)
  15. mysql> start slave;
  16. Query OK, 0 rows affected, 1 warning (0.13 sec)
  17. mysql> show slave status\G
  18. *************************** 1. row ***************************
  19. Slave_IO_State: Waiting for master to send event
  20. Master_Host: 192.168.200.28
  21. Master_User: rep
  22. Master_Port: 3306
  23. Connect_Retry: 60
  24. Master_Log_File: mysql-bin.000006
  25. Read_Master_Log_Pos: 231
  26. Relay_Log_File: localhost-relay-bin.000002
  27. Relay_Log_Pos: 361
  28. Relay_Master_Log_File: mysql-bin.000006
  29. Slave_IO_Running: Yes
  30. Slave_SQL_Running: Yes
  31. ...一下省略...

(6)补上缺失的mha配置文件

  1. [root@localhost ~]# cat /etc/mha/mha1.cnf
  2. [server default]
  3. manager_log=/var/log/mha/mha1/manager
  4. manager_workdir=/var/log/mha/mha1
  5. master_binlog_dir=/usr/local/mysql/data
  6. master_ip_failover_script=/usr/local/bin/master_ip_failover
  7. password=666666
  8. ping_interval=2
  9. repl_password=666666
  10. repl_user=rep
  11. ssh_user=root
  12. user=mha
  13. [server1]
  14. hostname=192.168.200.20
  15. port=3306
  16. [server2]
  17. hostname=192.168.200.28
  18. port=3306
  19. [server3]
  20. hostname=192.168.200.29
  21. port=3306

(7)启动mha管理进程

  1. [root@localhost ~]# ps -ef | grep mha | grep -v grep
  2. [root@localhost ~]# nohup masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /var/log/mha/mha1/manager.log 2>&1 &
  3. [1] 7382
  4. [root@localhost ~]# ps -ef | grep mha | grep -v grep
  5. root 7382 5389 1 03:14 pts/0 00:00:00 perl /usr/bin/masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover

配置binlog-server备份服务器

主库宕机,也许会造成主库binlog复制不及时而导致数据丢失的情况出现,因此配置binlog-server进行时时同步备份,是必要的一种安全手段。

 

修改mha配置文件

 
  1. [root@localhost ~]# vim /etc/mha/mha1.cnf
  2. [root@localhost ~]# cat /etc/mha/mha1.cnf
  3. [server default]
  4. manager_log=/var/log/mha/mha1/manager
  5. manager_workdir=/var/log/mha/mha1
  6. master_binlog_dir=/usr/local/mysql/data #全局的binlog存放位置
  7. master_ip_failover_script=/usr/local/bin/master_ip_failover
  8. password=666666
  9. ping_interval=2
  10. repl_password=666666
  11. repl_user=rep
  12. ssh_user=root
  13. user=mha
  14. [server1]
  15. hostname=192.168.200.20
  16. port=3306
  17. [server2]
  18. hostname=192.168.200.28
  19. port=3306
  20. [server3]
  21. hostname=192.168.200.29
  22. port=3306
  23. [binlog1] #添加binlog模块
  24. no_master=1 #不允许切换为主
  25. hostname=192.168.200.29 #存放IP
  26. master_binlog_dir=/data/mysql/binlog/ #binlog存放位置优先级比全局的高
 

拉取主库上的binlog日志到mysql-db03的存放目录里

  1. [root@localhost ~]# mkdir -p /data/mysql/binlog #创建存放目录
  2. [root@localhost ~]# cd /data/mysql/binlog #进入存放目录
  3. [root@localhost binlog]# ll
  4. total 0
  5. [root@localhost binlog]# which mysqlbinlog
  6. /usr/local/bin/mysqlbinlog
  7. [root@localhost binlog]# mysqlbinlog -R --host=192.168.200.60 --user=mha --password=666666 --raw --stop-never mysql-bin.000001 & #拉取主库binlog,这里的IP是VIP的
  8. [2] 8133
  9. [root@localhost binlog]# Warning: Using a password on the command line interface can be insecure.
  10. [root@localhost binlog]# ll
  11. total 24
  12. -rw-r--r--. 1 root root 143 Nov 25 03:37 mysql-bin.000001
  13. -rw-r--r--. 1 root root 174 Nov 25 03:37 mysql-bin.000002
  14. -rw-r--r--. 1 root root 685 Nov 25 03:37 mysql-bin.000003
  15. -rw-r--r--. 1 root root 254 Nov 25 03:37 mysql-bin.000004
  16. -rw-r--r--. 1 root root 254 Nov 25 03:37 mysql-bin.000005
  17. -rw-r--r--. 1 root root 120 Nov 25 03:37 mysql-bin.000006
  18. [root@localhost binlog]# ps -ef | grep mysqlbinlog | grep -v grep
  19. root 8133 5389 0 03:37 pts/0 00:00:00 mysqlbinlog -R --host=192.168.200.60 --user=mha --password=x xxxx --raw --stop-never mysql-bin.000001
 

启动mha管理进程

 
  1. [root@localhost binlog]# nohup masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /var/log/mha/mha1/manager.log 2>&1 &
  2. [root@localhost binlog]# ps -ef | grep mysqlbinlog | grep -v grep
  3. root 8133 5389 0 03:37 pts/0 00:00:00 mysqlbinlog -R --host=192.168.200.60 --user=mha --password=x xxxx --raw --stop-never mysql-bin.000001 #binlog进程在
  4. [root@localhost binlog]# ps -ef | grep perl | grep -v grep
  5. root 7382 5389 0 03:14 pts/0 00:00:01 perl /usr/bin/masterha_manager --conf=/etc/mha/mha1.cnf --remove_dead_master_conf --ignore_last_failover #mha进程在

MHA-Atlas-MySQL高可用集群2的更多相关文章

  1. 构建MHA实现MySQL高可用集群架构

    一.MHA简介 MHA(Master HighAvailability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开 ...

  2. MySQL高可用集群MHA方案

    MySQL高可用集群MHA方案 爱奇艺在用的数据库高可用方案 MHA 是目前比较成熟及流行的 MySQL 高可用解决方案,很多互联网公司正是直接使用或者基于 MHA 的架构进行改造实现 MySQL 的 ...

  3. MySQL高可用集群方案

    一.Mysql高可用解决方案 方案一:共享存储 一般共享存储采用比较多的是 SAN/NAS 方案. 方案二:操作系统实时数据块复制 这个方案的典型场景是 DRBD,DRBD架构(MySQL+DRBD+ ...

  4. 部署MYSQL高可用集群

                                                  mysql-day08     部署MYSQL高可用集群 u 集群架构                   ...

  5. Mysql高可用集群环境介绍

    MySQL高可用集群环境搭建 01.MySQL高可用环境方案 02.MySQL主从复制原理 03.MySQL主从复制作用 04.在Linux环境上安装MySQL 05.在MySQL集群环境上配置主从复 ...

  6. Mysql 高可用集群PXC

    PXC是percona公司的percona  xtraDB  cluster,简称PXC.它是基于Galera协议的高可用集群方案.可以实现多个节点间的数据同步复制以及读写,并且可保障数据库的服务高可 ...

  7. keepalived+MySQL高可用集群

    基于keepalived搭建MySQL的高可用集群   MySQL的高可用方案一般有如下几种: keepalived+双主,MHA,MMM,Heartbeat+DRBD,PXC,Galera Clus ...

  8. corosync+pacemaker and drbd实现mysql高可用集群

    DRBD:Distributed Replicated Block Device 分布式复制块设备,原理图如下 DRBD 有主双架构和双主架构的,当处于主从架构时,这个设备一定只有一个节点是可以读写的 ...

  9. heatbeat-gui实现基于nfs的mysql高可用集群

    一.简述HA高可用集群 高可用集群就是当集群中的一个节点发生各种软硬件及人为故障时,集群中的其他节点能够自动接管故障节点的资源并向外提供服务.以实现减少业务中断时间,为用户提供更可靠,更高效的服务. ...

  10. MYSQL高可用集群架构-MHA架构

    1  MHA简介:MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司 ...

随机推荐

  1. jquery validate 校验时,如果有type=hiddien

    当校验时,不需要校验#warnId,否则会引起输入框#alarmtile里的样式混乱

  2. Nodejs搭建基于express的应用,使用脚手架工具--express-generator

    1.安装nodejs 1> 去nodejs官网下载最新nodejs安装包,地址:http://nodejs.cn/download/,选择自己适合自己电脑系统的安装包,下载下来,然后一直next ...

  3. android LogConfigurator

    android LogConfigurator  此为第三方的 Log日志

  4. python-之-深浅拷贝一

    深浅拷贝 一.数据为不可变类型 (str.int.bool) import copy v1 = "abc" v2 = copy.copy(v1) v3 = copy.deepcop ...

  5. Git 转载

    我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整理的常用 Git 命令清单.几个专用名词的译名如下 ...

  6. 后台管理系统之“图片上传” --vue

    图片上传(基于vue) 相信上传图片是所有系统必备的功能吧,工作中的第一个管理系统就在上传图片的功能上卡顿了一整天. 当时用的elementUI组件,但是由于样式和设计图样式差别较大再加上原生相较好理 ...

  7. 常用的字符串函数-S

    header('content-type:text/html;charset=utf-f'); /* $var=addslashes($_GET['username']);//转义表单提交内容中的引号 ...

  8. Type curtilage home

    This year's National Day coincides with the Mid-Autumn festival, the double false merger about eight ...

  9. Sql Server 2012 集群配置

    基于Windows Server 2008 R2的WSFC实现SQL Server 2012高可用性组(AlwaysOn Group) 2012年5月 微软新一代数据库产品SQL Server 201 ...

  10. Unity ECS 初探

    1.安装 安装两个包 2.初探 实例化 注:实例化的实体并不会在Hierarchy视图里面显示,可在EntityDebugger窗口里面显示,因此需要显示的话需要添加Rendermeshcompone ...