004.MySQL雙主+Keepalived高可用

 

一 基礎環境

主機名
系統版本
MySQL版本
主機IP
Master01
CentOS 6.8
MySQL 5.6
172.24.8.10
Master02
CentOS 6.8
MySQL 5.6
172.24.8.11
VIP
172.24.8.12

二 實際部署

2.1 安裝MySQL

  1 [root@Master01 ~]# yum list installed | grep mysql	#查看是否存在其餘MySQL組件
  2 [root@Master01 ~]# yum -y remove mysql-libs.x86_64	#爲避免衝突引起報錯,卸載已存在的組件
 
25
  1 [root@Master01 study]#  yum localinstall mysql-commu* -y
  2 [root@Master01 ~]# chkconfig --list | grep mysqld		#查看MySQL是否加入啓動項
  3 [root@Master01 ~]# chkconfig mysqld on
 

2.2 初始化MySQL

  1 [root@Master01 ~]# service mysqld start
  2 [root@Master01 ~]# mysql_secure_installation
  3 [root@Master01 ~]# service iptables stop
  4 [root@Master01 ~]# chkconfig iptables off
  5 [root@Master01 ~]# vi /etc/sysconfig/selinux
  6 SELINUX=disabled
 
注意:以上操做在Master02主機上也須要執行。
安裝參考:http://www.cnblogs.com/007sx/p/7083143.html

2.3 master01 my.cf配置

  1 [root@Master01 ~]# vi /etc/my.cnf
  2 [mysqld]
  3 ……
  4 server-id=1				#設置主服務器master的id
  5 log-bin=mysql-bin			#配置二進制變動日誌命名格式
  6 replicate-wild-ignore-table=mysql.%
  7 replicate-wild-ignore-table=test.%
  8 replicate-wild-ignore-table=information_schema.%
 
注意:
master開啓二進制日誌後默認記錄全部庫全部表的操做,能夠經過配置來指定只記錄指定的數據庫甚至指定的表的操做,具體在mysql配置文件的[mysqld]可添加修改以下選項:
方法一:
  1 # 不一樣步哪些數據庫
  2 binlog-ignore-db = mysql
  3 binlog-ignore-db = test
  4 binlog-ignore-db = information_schema
  5 # 只同步哪些數據庫,除此以外,其餘不一樣步
  6 binlog-do-db = mysqltest
 
方法二:
建議採用如下方式配置過濾:
  1 replicate-wild-ignore-table=mysql.%	#從庫配置不一樣步表
  2 replicate-wild-do-table=test.%		#從庫配置須要同步的表
 

提示:不要在主庫使用binlog-ignore-db和binlog-do-db,也不要在從庫使用replicate-wild-ignore和replicate-wild-do-table。html

2.4 建立帳號

  1 [root@Master01 ~]# mysql -uroot -p
  2 Enter password:
  3 mysql> grant replication slave on *.* to 'repl_user'@'172.24.8.11' identified by 'x12345678';
  4 mysql> grant all privileges on *.* to 'root'@'172.24.8.%'  identified by 'x120952576' with grant option;
  5 mysql> flush privileges;
  6 [root@Master01 ~]# service mysqld restart
  7 [root@Master01 ~]# mysql -uroot -p
  8 Enter password:
  9 mysql> show master status;
 
26
master01:
file:mysql-bin.000001
position:120

2.5 smaster02 my.cf配置配置

  1 [root@Master02 ~]# vi /etc/my.cnf
  2 [mysqld]
  3 server-id=2				#設置主服務器master的id
  4 log-bin=mysql-bin			#配置二進制變動日誌命名格式
  5 replicate-wild-ignore-table=mysql.%
  6 replicate-wild-ignore-table=test.%
  7 replicate-wild-ignore-table=information_schema.%
  8 read_only=1
 

2.6 建立帳號

  1 [root@Master02 ~]# mysql -uroot -p
  2 Enter password:
  3 mysql> grant replication slave on *.* to 'repl_user'@'172.24.8.10' identified by 'x12345678';
  4 mysql> grant all privileges on *.* to 'root'@'172.24.8.%'  identified by 'x120952576' with grant option;
  5 mysql> flush privileges;
  6 [root@Master02 ~]# service mysqld restart
  7 [root@Master02 ~]# mysql -uroot -p
  8 Enter password:
  9 mysql> show master status;
27

master02:mysql

file:mysql-bin.000001
position:120

三 啓動主從

3.1 手動同步

若是Master01和Master02已經存在數據,則在開啓主備複製以前,須要將Master01和Master02手動同步一次(/var/lib/mysql整個目錄打包tar.gz),具體方法略。
注意:本實驗都是從新安裝的MySQL,可直接啓動同步。

3.2 啓動Master01的slave功能

  1 [root@Master01 ~]# service mysqld restart
  2 [root@Master01 ~]# mysql -uroot -p
  3 Enter password:
  4 mysql> change master to master_host='172.24.8.11',
  5 master_user='repl_user',
  6 master_password='x12345678',
  7 master_log_file='mysql-bin.000001',
  8 master_port=3306,
  9 master_log_pos=120;
 10 mysql> start slave;
 11 mysql> show slave status\G			#查看slave狀態
 
28

3.3 啓動Master02的slave功能

  1 [root@Master02 ~]# service mysqld restart
  2 [root@Master02 ~]# mysql -uroot -p
  3 Enter password:
  4 mysql> change master to master_host='172.24.8.10',
  5 master_user='repl_user',
  6 master_password='x12345678',
  7 master_log_file='mysql-bin.000001',
  8 master_log_pos=120;
  9 mysql> start slave;
 10 mysql> show slave status\G			#查看slave狀態
 
29
提示:
slave的I/O和SQL線程都已經開始運行,並且Seconds_Behind_Master再也不是NULL。日誌的位置增長了,意味着一些事件被獲取並執行了。若是你在master上進行修改,你能夠在slave上看到各類日誌文件的位置的變化,一樣,你也能夠看到數據庫中數據的變化。

四 安裝Keepalived

4.1 下載

  1 [root@Master01 ~]# wget http://www.keepalived.org/software/keepalived-1.3.6.tar.gz
  2 [root@Master01 ~]# tar -zvxf keepalived-1.3.6.tar.gz -C /tmp/
  3 [root@Master01 ~]# cd /tmp/keepalived-1.3.6
  4 [root@Master01 keepalived-1.3.6]# ./configure --prefix=/usr/local/keepalived/ --sysconf=/etc --with-init=SYSV
  5 #注:(upstart|systemd|SYSV|SUSE|openrc) #根據你的系統選擇對應的啓動方式
  6 [root@Master01 keepalived-1.3.6]# make && make install
  7 [root@Master01 ~]# ln -s /usr/local/keepalived/sbin/keepalived /sbin
  8 [root@Master01 ~]# chmod u+x /etc/init.d/keepalived
  9 [root@Master01 ~]# chkconfig --add keepalived
 10 [root@Master01 ~]# chkconfig --level 35 keepalived on
 
注意:Master02上也須要如上操做。
若出現如下提示,須要執行:yum -y install openssl-devel。
30
提示:也可採用yum install -y keepalived安裝(我的不建議)。

4.2 Master01配置Keepalived

默認狀況下keepalived啓動時會去/etc/keepalived目錄下找配置文件。
  1 [root@Master01 ~]# vim /etc/keepalived/keepalived.conf
  2 ! Configuration File for keepalived
  3 global_defs {
  4    notification_email {
  5     x120952576@126.com
  6 #表示keepalived在發生諸如切換操做時發送Email給哪些地址,郵件地址能夠多個,每行一個。
  7    }
  8    notification_email_from Alexandre.Cassen@firewall.loc
  9    smtp_server 172.24.8.10
 10    smtp_connect_timeout 30
 11    router_id LVS_DEVEL
 12 }
 13 vrrp_instance VI_1 {
 14     state BACKUP
 15     interface eth0
 16     virtual_router_id 51
 17 #這裏設置VRID,這裏很是重要,相同的VRID爲一個組,他將決定多播的MAC地址
 18     priority 100
 19     advert_int 1
 20     nopreempt
 21 #不搶佔,只在優先級高的機器上設置便可,優先級低的機器不設置
 22     authentication {
 23         auth_type PASS
 24         auth_pass 1111
 25     }
 26 track_script {
 27     check_mysqld		#執行定義的監控腳本
 28 }
 29     virtual_ipaddress {
 30         172.24.8.12
 31     }
 32 }
 33 vrrp_script check_mysqld {
 34     script"/etc/keepalived/mysqlcheck/keepalived_check_mysql.sh "
 35     interval 2
 36 }
 

4.3 建立檢測腳本

  1 [root@Master01 ~]# mkdir -p /etc/keepalived/mysqlcheck/
  2 [root@Master01 ~]# vi /etc/keepalived/mysqlcheck/keepalived_check_mysql.sh
  3 #!/bin/bash
  4 MYSQL=/usr/bin/mysql
  5 MYSQL_HOST=localhost
  6 MYSQL_USER=root
  7 MYSQL_PASSWORD=x120952576
  8 CHECK_TIME=3
  9 #mysql  is workingMYSQL_OK is 1 , mysql down MYSQL_OK is 0
 10 MYSQL_OK=1
 11 function check_mysql_helth (){
 12 $MYSQL -h $MYSQL_HOST -u $MYSQL_USER -p${MYSQL_PASSWORD} -e "show status;" >/dev/null 2>&1
 13 if [ $? = 0 ] ;then
 14         MYSQL_OK=1
 15 else
 16         MYSQL_OK=0
 17 fi
 18 return $MYSQL_OK
 19 }
 20 while [ $CHECK_TIME -ne 0 ]
 21 do
 22         let "CHECK_TIME -= 1"
 23         check_mysql_helth
 24         if [ $MYSQL_OK = 1 ] ; then
 25                 CHECK_TIME=0
 26                 exit 0
 27         fi
 28         if [ $MYSQL_OK -eq 0 ] &&  [ $CHECK_TIME -eq 0 ]
 29         then
 30                 /etc/init.d/keepalived stop
 31                 exit 1
 32         fi
 33         sleep 1
 34 done
 35 [root@Master01 ~]# chmod u+x /etc/keepalived/mysqlcheck/keepalived_check_mysql.sh
 36 [root@Master01 ~]# service keepalived start
 

4.4 Master02配置Keepalived

  1 [root@Master01 ~]# scp /etc/keepalived/keepalived.conf root@127.24.8.11:/etc/keepalived/
參考Master01配置,去掉nopreempt選項,priority設置比Master01低便可。

4.5 建立檢測腳本

  1 [root@Master02 ~]# mkdir -p /etc/keepalived/mysqlcheck/
  2 [root@Master01 ~]# scp /etc/keepalived/mysqlcheck/keepalived_check_mysql.sh root@172.24.8.11:/etc/keepalived/mysqlcheck/
  3 [root@Master02 ~]# chmod u+x /etc/keepalived/mysqlcheck/keepalived_check_mysql.sh
  4 [root@Master02 ~]# service keepalived start
 

五 功能測試

5.1 測試vip

  1 [root@test ~]# mysql -uroot -h172.24.8.12 -p
31
  1 mysql> show variables like "%hostname%";
  2 mysql> show variables like "%server_id%";
 
31

5.2 同步測試

  1 [root@test ~]# mysql -uroot -p
  2 Enter password:
  3 mysql> create database mysqltest;
  4 mysql> use mysqltest;
  5 mysql> create table user(id int(5),name char(10));
  6 mysql> insert into user values (00001,'zhangsan');
  7 在Slave從服務器上進行驗證:
  8 [root@Master02 ~]# mysql -uroot -p
  9 Enter password:
 10 mysql> show databases;
 11 mysql> select * from mysqltest.user;
 
33

5.3 測試Keepalived切換

  1 [root@Master01 ~]# service mysqld stop				#中止Master01的MySQL
  2 [root@Master01 ~]# tail -f /var/log/messages			#觀察Master01的日誌
 
34
  1 [root@Master02 ~]# tail -f /var/log/messages			#觀察Master02的日誌
35
  1 [root@Client ~]# mysql -uroot -h172.24.8.12 -px120952576	#客戶端鏈接VIP
36
注意:已經成功切換,在切換過程當中可能中斷幾秒。
相關文章
相關標籤/搜索