一、mysql简介

  MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典MySQL AB公司。MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。


二、mysql复制

  关于mysql复制,我是这样理解的:将某一台主机上的Mysql数据复制到其它主机(slaves)上,并重新执行一遍从而实现当前主机上的mysql数据与(master)主机上数据保持一致的过程我们可以称为复制。

  复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环。这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。


三、mysql复制能解决什么问题

1、数据的分布(Data Distribution)

2、负载均衡(Load balancing) | mysql读写分离

3、可以实现数据的备份(Backups),但是不能当真正意义上数据备份来用

4、高可用性和容错行(比如双主模型中的互为主从能实现高可用)


四、mysql的复制原理

1、工作原理图

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主

从上图来看,Mysql的复制就三个步骤:

    1)在Master服务器将改变的数据记录到二进制日志(binary log)中(这些记录叫做二进制日志事件)

    2)Slave服务器将Master服务器上的二进制日志拷贝到自己的中继日志(relay-log)中

    3)Slave服务器读取中继日志中的事件,然后将改变的数据写入到自己的数据库中

2、说明三步流程

第一步:是在Master服务器上记录二进制日志。在每个更新数据的事务完成之前,Master服务器都会将数据更改记录到二进制日志中。即使事务在执行期间是交错的,Mysql也会串行地将事务写入到二进制日志中。在把事件写入二进制日志之后,Master服务器告诉存储引擎可以提交事务了

第二步:是Slave服务器把主服务器的二进制日志拷贝到自己的硬盘上,进入所谓的“中继日志”中。首先,它启动一个工作线程,叫I/O线程,这个I/O线程开启一个普通的客户端连接,然后启动一个特殊的二进制日志转储进程(它没有相应的SQL命令)。这个转储进程Master服务器的二进制日志中读取数据。它不会对事件进行轮询。如果3跟上了Master服务器,就会进入休眠状态并等待有新的事件发生时Master服务器发出的信号。I/O线程把数据写入Slave服务器的中继日志中

第三步:SQL线程读取中继日志,并且重放其中的事件,然后更新Slave服务器的数据。由于这个线程能跟上I/O线程,中继日志通常在操作系统的缓存中,所以中继日志的开销很低。SQL线程执行事件也可以被写入Slave服务器自己的二进制日志中,它对于有些场景很实用

上图中显示了在Slave服务器有两个运行的线程,在Master服务器上也有一个运行的线程:和其他普通连接一样,由Slave服务器发起的连接,在Master服务器上同样拥有一个线程

3、配置注意事项

1、Master服务器必须开启二进制日志

2、Master和Slave的Server-id不能相同

3、同一个Master的多个Slave,Server-id也不能相同

4、Binlog_format最好相同

5、在Slave服务器上配置log-slave-updates=1时,也需要开启二进制日志;如果可以推荐使用read_only选项,该选项会阻止没有权限的线程修改数据



五、mysql主从异步复制

1、软件版本

系统版本:CentOS6.4 64bit

Mysql版本:mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz


2、拓扑图规划

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _02

3、准备工作

3.1 修改主机名

###MASTER执行
[root@localhost ~]# sed -i 's@\(HOSTNAME=\).*@\1master.allentuns.com@g' /etc/sysconfig/network
[root@localhost ~]# hostname master.allentuns

###SLAVE执行
[root@localhost ~]# sed -i 's@\(HOSTNAME=\).*@\1slave.allentuns.com@g' /etc/sysconfig/network
[root@localhost ~]# hostname slave.allentuns

3.2 配置主机名解析,这里修改hosts文件来实现

###MASTER执行
[root@master ~]# cat >> /etc/hosts << EOF
> 192.168.2.100 master.allentuns.com
> 192.168.2.200 slave.allentuns.com
> EOF

###SLAVE执行
[root@slave ~]# cat >> /etc/hosts << EOF
> 192.168.2.100 master.allentuns.com
> 192.168.2.200 slave.allentuns.com
> EOF

3.3 同步两台服务器的时间,保持时间一致

###MASTER执行
[root@master ~]# crontab -l
*/5 * * * * /usr/sbin/ntpdate -u asia.pool.ntp.org

###SLAVE执行
[root@slave ~]# crontab -l
*/5 * * * * /usr/sbin/ntpdate -u asia.pool.ntp.org


4、安装Mysql

4.1 在Master与Slave服务器上分别安装Mysql

###MASTER执行

1、解压mysql并建立软链接
tar xf mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz -C /usr/local/
cd /usr/local/
ln -sv mysql-5.6.12-linux-glibc2.5-x86_64 mysql

2、创建mysql用户
groupadd -r mysql
useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql

3、赋予mysql程序目录的属主和属组为mysql用户
chown -R mysql.mysql /usr/local/mysql/

4、创建mysql数据存储目录并赋予此目录的属主和属组为mysql用户
mkdir -pv /mydata/data
chown -R mysql:mysql /mydata/data/

5、初始化mysql依赖libaio
yum -y install libaio

6、初始化mysql
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/mydata/data --user=mysql

7、为了mysql数据库的安全,改回mysql程序目录的属主
chown -R root /usr/local/mysql/*

8、修改mysql的默认配置文件,并优化相关参数
# vim /usr/local/mysql/my.cnf
添加内容是:
[mysqld]
log-bin = master-bin
server-id = 1
port = 3306
basedir = /usr/local/mysql/
datadir = /mydata/data
socket = /var/lib/mysql/mysql.sock
innodb_file_per_table = 1 


9、为mysql提供sysv服务脚本并启动服务
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

10、将mysql加入到服务列表并设置开机自启动
chkconfig --add mysqld
chkconfig mysqld on

11、mysql命令添加到环境变量中
# vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin
# source /etc/profile

12、输出mysql的man手册到man命令的查找路径
# yum -y install man
# vim /etc/man.config +54
加入到54行后
MANPATH /usr/local/mysql/man

13、输出mysql的库文件
echo "/usr/local/mysql/lib/" > /etc/ld.so.conf.d/mysql.conf
ldconfig -v

14、输出mysql的头文件到系统头文件
ln -sv /usr/local/mysql/include/ /usr/include/mysql

15、启动mysql服务
service mysqld start

16、测试mysql[root@mysql ~]# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
4 rows in set (0.00 sec)

mysql> \q
Bye
###SLAVE执行

1、解压mysql并建立软链接
tar xf mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz -C /usr/local/
cd /usr/local/
ln -sv mysql-5.6.12-linux-glibc2.5-x86_64 mysql

2、创建mysql用户
groupadd -r mysql
useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql

3、赋予mysql程序目录的属主和属组为mysql用户
chown -R mysql.mysql /usr/local/mysql/

4、创建mysql数据存储目录并赋予此目录的属主和属组为mysql用户
mkdir -pv /mydata/data
chown -R mysql:mysql /mydata/data/

5、初始化mysql依赖libaio
yum -y install libaio

6、初始化mysql
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/mydata/data --user=mysql

7、为了mysql数据库的安全,改回mysql程序目录的属主
chown -R root /usr/local/mysql/*

8、修改mysql的默认配置文件,并优化相关参数
# vim /usr/local/mysql/my.cnf
添加内容是:
[mysqld]
log-bin = master-bin
server-id = 1
port = 3306
basedir = /usr/local/mysql/
datadir = /mydata/data
socket = /var/lib/mysql/mysql.sock
innodb_file_per_table = 1 


9、为mysql提供sysv服务脚本并启动服务
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

10、将mysql加入到服务列表并设置开机自启动
chkconfig --add mysqld
chkconfig mysqld on

11、mysql命令添加到环境变量中
# vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin
# source /etc/profile

12、输出mysql的man手册到man命令的查找路径
# yum -y install man
# vim /etc/man.config +54
加入到54行后
MANPATH /usr/local/mysql/man

13、输出mysql的库文件
echo "/usr/local/mysql/lib/" > /etc/ld.so.conf.d/mysql.conf
ldconfig -v

14、输出mysql的头文件到系统头文件
ln -sv /usr/local/mysql/include/ /usr/include/mysql

15、启动mysql服务
service mysqld start

16、测试mysql[root@mysql ~]# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
4 rows in set (0.00 sec)

mysql> \q
Bye
[root@mysql ~]#


4.2 主从复制配置

4.2.1 在Master服务器上建立用于Slave服务器复制数据的帐户

[root@master ~]# mysql
mysql> grant replication slave,replication client on *.* to 'allentuns'@'192.168.2.200' identified by '1234@6@';
Query OK, 0 rows affected (0.02 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

mysql> show grants for 'allentuns'@'192.168.2.200';   #查看授权用户
+------------------------------------------------------------------------------------------------------------------------------------------------------+
| Grants for allentuns@192.168.2.200                                                                                                                   |
+------------------------------------------------------------------------------------------------------------------------------------------------------+
| GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'allentuns'@'192.168.2.200' IDENTIFIED BY PASSWORD '*7B8E3D52A612E2CB04E31B43FCDC20A07317E332' |
+------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

4.2.2 在Slave服务器上使用授权用户连接测试

[root@slave ~]# mysql -uallentuns -p1234@6@ -h 192.168.2.100
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 6
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>

4.2.3 修改Master服务器上的Mysqld主配置文件如下:

[root@master ~]# vim /usr/local/mysql/my.cnf 
log-bin = master-bin    #二进制日志文件
binlog_format = mixed   #二进制日志文件索引
server-id = 1           #用于识别的ID
port = 3306             #Mysql的默认端口号
basedir = /usr/local/mysql/  #Mysql源程序目录
datadir = /mydata/data       #数据存储目录路径
socket = /var/lib/mysql/mysql.sock  #套接字文件路径
innodb_file_per_table = 1    #每表一个文件

[root@master ~]# service mysqld restart

4.2.4 修改Slave服务器上的Mysqld主配置文件如下:

[root@slave ~]# vim /usr/local/mysql/my.cnf 
#log-bin = master-bin   #注释二进制日志文件,如果当其它从服务器的主服务器,否则关闭
#binlog_format = mixed  #注释此行
skip_slave_start = 1    #启动服务时不自动启动从服务线程
read_only = 1           #设置Slave服务器为只读
server-id = 10 
relay_log = relay_log              
relay_log_index = relay_log.index
port = 3306
basedir = /usr/local/mysql/
datadir = /mydata/data
socket = /var/lib/mysql/mysql.sock
innodb_file_per_table = 1

[root@slave ~]# service mysqld restart

4.2.5 查看Master服务器的二进制日志及二进制日志事件位置用于Slave服务器复制

mysql> RESET MASTER;    #清空二进制日志
Query OK, 0 rows affected (0.05 sec)

mysql> show master status;
+-------------------+----------+--------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------+------------------+-------------------+
| master-bin.000003 |      120 |              |                  |                   |
+-------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

注释:
    File:表示从此日志开始复制
    Position:表示从这个事件开始复制 偏移位

4.2.6 在Slave服务器上同步Master服务器上面的数据如下:

mysql> CHANGE MASTER TO
    ->   MASTER_HOST='192.168.2.100',
    ->   MASTER_USER='allentuns',
    ->   MASTER_PASSWORD='1234@6@',
    ->   MASTER_PORT=3306,
    ->   MASTER_LOG_FILE='master-bin.000003',
    ->   MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.38 sec)
****************************************************
mysql> help change master to  #获取帮助信息
Name: 'CHANGE MASTER TO'
Description:
Syntax:
CHANGE MASTER TO option [, option] ...

CHANGE MASTER TO
  MASTER_HOST='master2.mycompany.com',
  MASTER_USER='replication',
  MASTER_PASSWORD='bigs3cret',
  MASTER_PORT=3306,
  MASTER_LOG_FILE='master2-bin.001',
  MASTER_LOG_POS=4,
  MASTER_CONNECT_RETRY=10;


4.2.7 启动Slave服务器的复制线程并查看状态

mysql> start slave;    #启动Slave服务器线程
Query OK, 0 rows affected (0.02 sec)

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.2.100        #Master服务器地址
                  Master_User: allentuns            #连接Master服务器用户名
                  Master_Port: 3306                 #Master服务器的监听端口
                Connect_Retry: 60                   #重试时间间隔
              Master_Log_File: master-bin.000003    #I/O线程读取的二进制日志文件
          Read_Master_Log_Pos: 120                  #I/O线程读取的二进制日志文件事件位置
               Relay_Log_File: relay_log.000002     #SQL线程正在读取的中继日志文件
                Relay_Log_Pos: 284                  #SQL线程读取和执行的中继日志文件事件位置
        Relay_Master_Log_File: master-bin.000003
             Slave_IO_Running: Yes                  #Slave服务器的IO线程状态
            Slave_SQL_Running: Yes                  #Slave服务器的SQL线程状态
              Replicate_Do_DB:                      #下面Replicate开头的表示用来指明哪些库或者表在复制时不需要同步
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0                    #SQL线程读取日志参数的错误数量
                   Last_Error:                      #SQL线程读取日志参数的错误消息
                 Skip_Counter: 0                    #最近被用于SQL_SLAVE_SKIP_COUNTER的值
          Exec_Master_Log_Pos: 120
              Relay_Log_Space: 451
              Until_Condition: None                 #所有原有中继日志的总大小
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No                   #是否允许对Master服务器进行SSL连接
           Master_SSL_CA_File: 
           Master_SSL_CA_Path: 
              Master_SSL_Cert: 
            Master_SSL_Cipher: 
               Master_SSL_Key: 
        Seconds_Behind_Master: 0                    #落后于Master服务器的时间
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 1
                  Master_UUID: 84774a86-3ee8-11e4-a268-000c29ad35d7
             Master_Info_File: /mydata/data/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: 
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

ERROR: 
No query specified


4.2.8 在Slave服务器查看启动的线程

[root@slave ~]# mysql -e "show processlist;"
+----+-------------+-----------+------+---------+------+-----------------------------------------------------------------------------+------------------+
| Id | User        | Host      | db   | Command | Time | State                                                                       | Info             |
+----+-------------+-----------+------+---------+------+-----------------------------------------------------------------------------+------------------+
|  3 | system user |           | NULL | Connect |  533 | Waiting for master to send event                                            | NULL             |
|  4 | system user |           | NULL | Connect |  533 | Slave has read all relay log; waiting for the slave I/O thread to update it | NULL             |
|  5 | root        | localhost | NULL | Query   |    0 | init                                                                        | show processlist |
+----+-------------+-----------+------+---------+------+-----------------------------------------------------------------------------+------------------+


4.2.9 在Master服务器创建数据库并在Slave服务器上验证是否存在

###在Master服务器创建数据库并查看
[root@master ~]# mysql -e 'create database mydbtest;'
[root@master ~]# mysql -e 'show databases;'
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydbtest           |
| mysql              |
| performance_schema |
| test               |
+--------------------+

###在Slave服务器查看是否有'mydbtest'数据库
[root@slave ~]# mysql -e 'show databases;'
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydbtest           |  #数据库已经成功同步到slave服务器
| mysql              |
| performance_schema |
| test               |
+--------------------+

4.2.10 在Master与Slave服务器查看二进制日志事件位置已更新

###查看Master服务器
[root@master ~]# mysql -e 'show master status;'
+-------------------+----------+--------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------+------------------+-------------------+
| master-bin.000003 |      226 |              |                  |                   |
+-------------------+----------+--------------+------------------+-------------------+

###查看Slave服务器
[root@slave ~]# mysql -e 'show slave status\G;' |grep 'Read_Master_Log_Pos'
          Read_Master_Log_Pos: 226


六、mysql主从监控

1、Linux系统sendmail发邮件到139外部邮箱

1、安装sendmail和mailx
# yum -y install sendmail mailx

2、修改配置文件
# cp /etc/mail.rc /etc/mail.rc.bak
# cat >> /etc/mail.rc << EOF
set from=13260071987@139.com smtp=smtp.139.com 
set smtp-auth-user=13260071987@139.com smtp-auth-password=yi15093547036 smtp-auth=login
EOF

3、重新启动服务
# service sendmail restart

4、发送测试邮件
echo "I Love You" |mail -s "邮件主题:MIS you" 13260071987@139.com

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _03

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _04


2、分别在从服务器(Slave)上创建登陆用户,只限定本地运行,保证安全

mysql> grant all privileges on *.* to "zhengyansheng"@"127.0.0.1" identified by "password123";
Query OK, 0 rows affected (0.04 sec)

mysql> grant all privileges on *.* to "zhengyansheng"@"localhost" identified by "password123";
Query OK, 0 rows affected (0.00 sec)


3、Mysql监控脚本

#!/bin/bash
#check MySQL_Slave Status
#crontab time 00:10
MYSQLPORT=`netstat -na|grep "LISTEN"|grep "3306"|awk -F[:" "]+ '{print $4}'`
MYSQLIP=`ifconfig eth1|grep "inet addr" | awk -F[:" "]+ '{print $4}'`
STATUS=$(/usr/local/mysql/bin/mysql -u zhengyansheng -ppassword123 -S /tmp/mysql.sock -e "show slave status\G" | grep -i "running")
IO_env=`echo $STATUS | grep IO | awk  ' {print $2}'`
SQL_env=`echo $STATUS | grep SQL | awk  '{print $2}'`
DATA=`date +"%y-%m-%d %H:%M:%S"`
if [ "$MYSQLPORT" == "3306" ]
then
  echo "mysql is running"
else
  mail -s "warn!server: $MYSQLIP mysql is down" 13260071987@139.com
fi
if [ "$IO_env" = "Yes" -a "$SQL_env" = "Yes" ]
then
  echo "Slave is running!"
else
  echo "####### $DATA #########">>   /mydata/check_mysql_log/check_mysql_slave.log
  echo "Slave is not running!" >>    /mydata/check_mysql_log/check_mysql_slave.log
  echo "Slave is not running!" | mail -s "warn! $MYSQLIP MySQL Slave is not running" 13260071987@139.com
fi


4、定时执行监控脚本

[root@slave ~]# crontab -l
*/1 * * * * root /bin/sh /mydata/check_mysql_health.sh


5、测试:停止slave进程,看是否能收到邮件

mysql> stop slave;
Query OK, 0 rows affected (0.01 sec)

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: 
                  Master_Host: 192.168.2.100
                  Master_User: allentuns
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-bin.000003
          Read_Master_Log_Pos: 226
               Relay_Log_File: relay_log.000005
                Relay_Log_Pos: 284
        Relay_Master_Log_File: master-bin.000003
             Slave_IO_Running: No  #IO线程已经停止
            Slave_SQL_Running: No  #SQL线程已经停止
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0
                   Last_Error: 
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 226
              Relay_Log_Space: 615
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File: 
           Master_SSL_CA_Path: 
              Master_SSL_Cert: 
            Master_SSL_Cipher: 
               Master_SSL_Key: 
        Seconds_Behind_Master: NULL
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 1
                  Master_UUID: 84774a86-3ee8-11e4-a268-000c29ad35d7
             Master_Info_File: /mydata/data/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: 
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: 
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

C成功收到邮件!哈哈

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _05

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _06


七、mysql主从半同步复制

1、什么是同步复制

    同步复制:同步复制可以定义为数据在同一时刻被提交到一台或多台机器,通常这是通过众所周知的“两阶段提交”做到的。

    虽然这确实给你在多系统中保持一致性,但也由于增加了额外的消息交换而造成性能下降。使用MyISAM或者InnoDB存储引擎的MySQL本身并不支持同步复制,然而有些技术,例如分布式复制块设备(简称DRBD),可以在下层的文件系统提供同步复制,允许第二个MySQL服务器在主服务器丢失的情况下接管

(使用第二服务器的复本)。


2、什么是半同步复制

    MYSQL 5.5开始,支持半同步复制。之前版本的MySQL Replication都是异步(asynchronous)的,主库在执行完一些事务后,是不会管备库的进度的。

    如果备库不幸落后,而更不幸的是主库此时又出现Crash(例如宕机),这时备库中的数据就是不完整的。简而言之,在主库发生故障的时候,我们无法使用备库来继续提供数据一致的服务Semisynchronous Replication(半同步复制)则一定程度上保证提交的事务已经传给了至少一个备库。Semi synchronous中,仅仅保证事务的已经传递到备库上,但是并不确保已经在备库上执行完成了。

    此外,还有一种情况会导致主备数据不一致。在某个session中,主库上提交一个事务后,会等待事务传递给至少一个备库,如果在这个等待过程中主库Crash,那么也可能备库和主库不一致,这是很致命的。如果主备网络故障或者备库挂了,主库在事务提交后等待10秒(rpl_semi_sync_master_timeout的默认值)后,就会继续。这时,主库就会变回原来的异步状态。

    MySQL在加载并开启Semi-sync插件后,每一个事务需等待备库接收日志后才返回给客户端。如果做的是小事务,两台主机的延迟又较小,则Semi-sync可以实现在性能很小损失的情况下的零数据丢失。


3、异步与半同步的区别

    默认情况下MySQL的复制是异步的,Master上所有的更新操作写入Binlog之后并不确保所有的更新都被复制到Slave之上。异步操作虽然效率高,但是在Master/Slave出现问题的时候,存在很高数据不同步的风险,甚至可能丢失数据。

    MySQL5.5引入半同步复制功能的目的是为了保证在master出问题的时候,至少有一台Slave的数据是完整的。在超时的情况下也可以临时转入异步复制,保障业务的正常使用,直到一台salve追赶上之后,继续切换到半同步模式。

    默认情况下我们的主从复制是异步进行的,导致我们的从服务器有可能是落后于主服务器的,这在一定程度上是不安全的,如果我们的主服务器瞬间挂掉,从服务器将来不及复制数据。为了解决这个问题,我们可以打上google的一个补丁,使主从服务器实现半同步。

    为什么叫半同步呢?

    因为开启这个功能之后,主服务器只等待多个从服务器中的指定的一台从服务器复制成功,然后才进行其他写操作,使这个从服务器和主服务器上的数据完全同步,而并不管其他的从服务器。这在一定程度上就保证了我们数据的安全性。当然主服务器是不能一直等待从服务器复制成功的,因为万一从服务器挂掉,那么主服务器将一直处于等待状态而不提供写服务,这就需要我们定义一个超时时间,防止等待从服务器时间太长,单位是ms。如果超过定义的时间,从服务器还没有响应,则把指定的从服务器自动降级到异步模式,在选定一个从服务器做同步。


4、查看半同步插件

注意:Mysql5.5+半同步插件是由谷歌提供的,具体的位置/usr/local/mysql/lib/plugin/下

[root@master ~]# cd /usr/local/mysql/lib/plugin/
[root@master plugin]# ll semisync*.so
-rwxr-xr-x 1 root mysql 415322 6月  20 2013 semisync_master.so  #用于Master服务器安装的半同步插件
-rwxr-xr-x 1 root mysql 250750 6月  20 2013 semisync_slave.so   #用于Slave服务器安装的半同步插件

5、在Master与Slave服务器分别安装半同步插件

###在Master上安装半同步插件
mysql> install plugin rpl_semi_sync_master soname 'semisync_master.so'; #安装Master半同步插件
Query OK, 0 rows affected (0.03 sec)

mysql>  set global rpl_semi_sync_master_enabled = 1;   #开启Master半同步功能
Query OK, 0 rows affected (0.00 sec)

mysql> set global rpl_semi_sync_master_timeout = 1000; #设置超时时间
Query OK, 0 rows affected (0.00 sec)


###在Slave上安装半同步插件
mysql> install plugin rpl_semi_sync_slave soname 'semisync_slave.so';   #安装Slave半同步插件
Query OK, 0 rows affected (0.08 sec)

mysql> set global rpl_semi_sync_slave_enabled = 1;    #开启Slave半同步功能
Query OK, 0 rows affected (0.00 sec)

mysql> stop slave io_thread;   #停止IO线程
Query OK, 0 rows affected (0.00 sec)

mysql> start slave io_thread;  #启动IO线程
Query OK, 0 rows affected (0.00 sec)

6、查看半同步开启状态

#在Master服务器上查看
mysql> show global status like 'rpl_semi%';
+--------------------------------------------+-------+
| Variable_name                              | Value |
+--------------------------------------------+-------+
| Rpl_semi_sync_master_clients               | 1     | #已经有一个客户端连接
| Rpl_semi_sync_master_net_avg_wait_time     | 0     |
| Rpl_semi_sync_master_net_wait_time         | 0     |
| Rpl_semi_sync_master_net_waits             | 0     |
| Rpl_semi_sync_master_no_times              | 0     |
| Rpl_semi_sync_master_no_tx                 | 0     |
| Rpl_semi_sync_master_status                | ON    | #表明Master已经开启了半同步功能
| Rpl_semi_sync_master_timefunc_failures     | 0     |
| Rpl_semi_sync_master_tx_avg_wait_time      | 0     |
| Rpl_semi_sync_master_tx_wait_time          | 0     |
| Rpl_semi_sync_master_tx_waits              | 0     |
| Rpl_semi_sync_master_wait_pos_backtraverse | 0     |
| Rpl_semi_sync_master_wait_sessions         | 0     |
| Rpl_semi_sync_master_yes_tx                | 0     |
+--------------------------------------------+-------+
14 rows in set (0.00 sec)

mysql> show global variables like '%rpl%';
+------------------------------------+-------+
| Variable_name                      | Value |
+------------------------------------+-------+
| rpl_semi_sync_master_enabled       | ON    |  #Master半同步功能已经开启
| rpl_semi_sync_master_timeout       | 1000  |  #超时时间
| rpl_semi_sync_master_trace_level   | 32    |
| rpl_semi_sync_master_wait_no_slave | ON    |
+------------------------------------+-------+
4 rows in set (0.00 sec)


#在Slave服务器上查看
mysql> show global status like 'rpl_semi%';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| Rpl_semi_sync_slave_status | ON    |   #表明Slave已经开启了半同步功能
+----------------------------+-------+
1 row in set (0.04 sec)

mysql> show global variables like '%rpl%';
+---------------------------------+-------+
| Variable_name                   | Value |
+---------------------------------+-------+
| rpl_semi_sync_slave_enabled     | ON    |  #Slave半同步功能已经开启
| rpl_semi_sync_slave_trace_level | 32    |  
+---------------------------------+-------+
2 rows in set (0.00 sec)

7、查看Slave线程是否为"Yes"

[root@slave ~]# mysql -e 'show slave status\G;' |grep 'Running:'
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

8、验证半同步功能

###在Master服务器上删除数据库
[root@master ~]# mysql -e 'drop database mydbtest;'
[root@master ~]# mysql -e 'show databases;'
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+

###在Slave服务器查看数据库
[root@slave ~]# mysql -e 'show databases;' 
+--------------------+
| Database           |  #删除数据库mydbtest已经成功同步到Slave数据库上
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+

9、已经配置都是临时的,如果要永久生效,需要将参数加到my.cnf配置文件并重启服务就可以了



八、mysql的ssl加密认证

1、简述

由于Mysql的主从复制是明文传送的,但如果在生产环境中跨网络我们使用主从还是明文传送的话,就保证不了数据的安全性,为了解决这一问题,我们需要加密进行传送,也就是基于SSL的加密方法进行传输数据


2、将Master服务器自己做成CA服务器

[root@master ~]# cd /etc/pki/CA/
[root@master CA]# (umask 077;openssl genrsa -out private/cakey.pem 2048)
Generating RSA private key, 2048 bit long modulus
........+++
...................+++
e is 65537 (0x10001)
[root@master CA]# openssl req -new -x509 -key private/cakey.pem -out cacert.pem -days 365
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [XX]:CN
State or Province Name (full name) []:BJ
Locality Name (eg, city) [Default City]:HaiDian
Organization Name (eg, company) [Default Company Ltd]:Allentuns
Organizational Unit Name (eg, section) []:Tech
Common Name (eg, your name or your server's hostname) []:master.allentuns.com
Email Address []:
[root@master CA]# touch index.txt
[root@master CA]# echo 01 > serial


3、为Master创建证书申请并由CA服务器签发证书

[root@master ~]# mkdir /usr/local/mysql/ssl
[root@master ~]# cd /usr/local/mysql/ssl
[root@master ssl]# (umask 077;openssl genrsa -out master.key 2048)
Generating RSA private key, 2048 bit long modulus
........................+++
......+++
e is 65537 (0x10001)
[root@master ssl]# openssl req -new -key master.key -out master.csr -days 365
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [XX]:CN
State or Province Name (full name) []:BJ
Locality Name (eg, city) [Default City]:HaiDian
Organization Name (eg, company) [Default Company Ltd]:Allentuns
Organizational Unit Name (eg, section) []:Tech
Common Name (eg, your name or your server's hostname) []:master.allentuns.com
Email Address []:master@allentuns.com

Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:
[root@master ssl]# openssl ca -in master.csr -out master.crt -days 365
Using configuration from /etc/pki/tls/openssl.cnf
Check that the request matches the signature
Signature ok
Certificate Details:
        Serial Number: 1 (0x1)
        Validity
            Not Before: Sep 18 13:12:43 2014 GMT
            Not After : Sep 18 13:12:43 2015 GMT
        Subject:
            countryName               = CN
            stateOrProvinceName       = BJ
            organizationName          = Allentuns
            organizationalUnitName    = Tech
            commonName                = master.allentuns.com
            emailAddress              = master@allentuns.com
        X509v3 extensions:
            X509v3 Basic Constraints: 
                CA:FALSE
            Netscape Comment: 
                OpenSSL Generated Certificate
            X509v3 Subject Key Identifier: 
                FB:20:AF:6D:64:AB:46:AB:83:E5:71:BA:D9:A3:42:BF:2F:3D:6E:CD
            X509v3 Authority Key Identifier: 
                keyid:C5:1A:5C:09:E1:A7:49:03:BC:55:C8:9F:EB:32:3A:6A:16:3D:FD:1B

Certificate is to be certified until Sep 18 13:12:43 2015 GMT (365 days)
Sign the certificate? [y/n]:y


1 out of 1 certificate requests certified, commit? [y/n]y
Write out database with 1 new entries
Data Base Updated


4、为Slave创建证书申请

[root@slave ~]# mkdir /usr/local/mysql/ssl
[root@slave ~]# cd /usr/local/mysql/ssl
[root@slave ssl]# (umask 077;openssl genrsa -out slave.key 2048)
Generating RSA private key, 2048 bit long modulus
.............................................................................................+++
...........+++
e is 65537 (0x10001)
[root@slave ssl]# openssl req -new -key slave.key -out slave.csr -days 365
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [XX]:CN
State or Province Name (full name) []:BJ
Locality Name (eg, city) [Default City]:HaiDian
Organization Name (eg, company) [Default Company Ltd]:Allentuns
Organizational Unit Name (eg, section) []:Tech
Common Name (eg, your name or your server's hostname) []:slave.allentuns.com
Email Address []:

Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:


5、为Slave服务器签署证书

[root@slave ssl]# scp slave.csr master.allentuns.com:/tmp/   #在Slave主机上将证书申请文件拷贝到Master的CA服务器上
The authenticity of host 'master.allentuns.com (192.168.2.100)' can't be established.
RSA key fingerprint is 46:b9:7c:11:db:75:93:ad:f1:26:f0:a7:4d:00:40:20.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'master.allentuns.com,192.168.2.100' (RSA) to the list of known hosts.
root@master.allentuns.com's password: 
slave.csr                                                                                           100% 1013     1.0KB/s   00:00 

[root@master ~]# openssl ca -in /tmp/slave.csr -out /tmp/slave.crt -days 365  #CA服务器签署Slave的证书申请
Using configuration from /etc/pki/tls/openssl.cnf
Check that the request matches the signature
Signature ok
Certificate Details:
        Serial Number: 2 (0x2)
        Validity
            Not Before: Sep 18 13:18:06 2014 GMT
            Not After : Sep 18 13:18:06 2015 GMT
        Subject:
            countryName               = CN
            stateOrProvinceName       = BJ
            organizationName          = Allentuns
            organizationalUnitName    = Tech
            commonName                = slave.allentuns.com
        X509v3 extensions:
            X509v3 Basic Constraints: 
                CA:FALSE
            Netscape Comment: 
                OpenSSL Generated Certificate
            X509v3 Subject Key Identifier: 
                7C:51:D9:CD:DC:28:B3:3D:5D:F7:20:83:FA:0F:3D:2B:1A:4B:F3:8B
            X509v3 Authority Key Identifier: 
                keyid:C5:1A:5C:09:E1:A7:49:03:BC:55:C8:9F:EB:32:3A:6A:16:3D:FD:1B

Certificate is to be certified until Sep 18 13:18:06 2015 GMT (365 days)
Sign the certificate? [y/n]:y


1 out of 1 certificate requests certified, commit? [y/n]y
Write out database with 1 new entries
Data Base Updated
[root@master ~]#  scp /tmp/slave.crt slave.allentuns.com:/usr/local/mysql/ssl/   #将签署好的证书拷贝到Slave服务器上
The authenticity of host 'slave.allentuns.com (192.168.2.200)' can't be established.
RSA key fingerprint is 46:b9:7c:11:db:75:93:ad:f1:26:f0:a7:4d:00:40:20.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'slave.allentuns.com,192.168.2.200' (RSA) to the list of known hosts.
root@slave.allentuns.com's password: 
slave.crt                                                                                           100% 4477     4.4KB/s   00:00


6、将CA证书拷贝到Slave服务器并为Master拷贝一份

[root@master ~]# scp /etc/pki/CA/cacert.pem slave.allentuns.com:/usr/local/mysql/ssl/
root@slave.allentuns.com's password: 
cacert.pem                                                                                          100% 1338     1.3KB/s   00:00    
[root@master ~]# cp /etc/pki/CA/cacert.pem /usr/local/mysql/ssl/


7、修改Master与Slave服务器证书属主、属组为"mysql"用户

###在Master服务器上执行
[root@master ~]# chown -R mysql.mysql /usr/local/mysql/ssl
[root@master ~]# ll /usr/local/mysql/ssl
总用量 20
-rw-r--r-- 1 mysql mysql 1338 9月  18 21:22 cacert.pem
-rw-r--r-- 1 mysql mysql 4564 9月  18 21:12 master.crt
-rw-r--r-- 1 mysql mysql 1066 9月  18 21:12 master.csr
-rw------- 1 mysql mysql 1679 9月  18 21:11 master.key

###在Slave服务器上执行
[root@slave ssl]# chown -R mysql.mysql /usr/local/mysql/ssl
[root@slave ssl]# ll /usr/local/mysql/ssl/
总用量 20
-rw-r--r-- 1 mysql mysql 1338 9月  18 21:22 cacert.pem
-rw-r--r-- 1 mysql mysql 4477 9月  18 21:18 slave.crt
-rw-r--r-- 1 mysql mysql 1013 9月  18 21:14 slave.csr
-rw------- 1 mysql mysql 1679 9月  18 21:14 slave.key

注意:Master与Slave服务器上的证书属主、属组必须为mysql用户及组

8、在Master与Slave服务器修改主配置文件开启SSL加密功能

###在Master服务器上执行
[root@master ~]# vim /usr/local/mysql/my.cnf 
#添加如下参数
ssl                                               #开启SSL功能
ssl_ca = /usr/local/mysql/ssl/cacert.pem          #指定CA文件位置
ssl_cert = /usr/local/mysql/ssl/master.crt        #指定证书文件位置
ssl_key = /usr/local/mysql/ssl/master.key         #指定密钥所在位置
[root@master ~]# service mysqld restart
Shutting down MySQL.. SUCCESS! 
Starting MySQL.... SUCCESS! 

###在Slave服务器上执行
[root@slave ~]# vim /usr/local/mysql/my.cnf 
#添加如下参数
ssl                                               #开启SSL功能
ssl_ca = /usr/local/mysql/ssl/cacert.pem          #指定CA文件位置
ssl_cert = /usr/local/mysql/ssl/master.crt        #指定证书文件位置
ssl_key = /usr/local/mysql/ssl/master.key         #指定密钥所在位置
[root@slave ~]# service mysqld restart
Shutting down MySQL.. SUCCESS! 
Starting MySQL.... SUCCESS!


9、在Master服务器查看SSL加密是否开启;然后创建授权一个基于密钥认证的用户

mysql> show variables like "%ssl%";
+---------------+---------------------------------+
| Variable_name | Value                           |
+---------------+---------------------------------+
| have_openssl  | YES                             |
| have_ssl      | YES                             |
| ssl_ca        | /usr/local/mysql/ssl/cacert.pem |
| ssl_capath    |                                 |
| ssl_cert      | /usr/local/mysql/ssl/master.crt |
| ssl_cipher    |                                 |
| ssl_crl       |                                 |
| ssl_crlpath   |                                 |
| ssl_key       | /usr/local/mysql/ssl/master.key |
+---------------+---------------------------------+
9 rows in set (0.00 sec)

mysql> grant replication client,replication slave on *.* to 'userssl'@'192.168.2.%' identified by '1234@6@' require ssl;
Query OK, 0 rows affected (0.04 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)


10、查看Master服务器二进制日志文件和事件位置用于Slave服务器连接从这个位置开始复制

mysql> show master status;
+-------------------+----------+--------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------+------------------+-------------------+
| master-bin.000005 |      442 |              |                  |                   |
+-------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)


11、测试使用加密用户指定密钥连接Master服务器

[root@slave ssl]# mysql -uallentuns -p1234@6@ -h 192.168.2.100  --ssl-ca=/usr/local/mysql/ssl/cacert.pem --ssl-cert=/usr/local/mysql/ssl/slave.crt --ssl-key=/usr/local/mysql/ssl/slave.key
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 6
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>


12、查看Slave服务器SSL是否开启并连接Master服务器

这里有个疑问Slave中到底是否要开启SSL功能??????

mysql> show variables like '%ssl%';
+---------------+---------------------------------+
| Variable_name | Value                           |
+---------------+---------------------------------+
| have_openssl  | DISABLED                        |
| have_ssl      | DISABLED                        |
| ssl_ca        | /usr/local/mysql/ssl/cacert.pem |
| ssl_capath    |                                 |
| ssl_cert      | /usr/local/mysql/ssl/master.crt |
| ssl_cipher    |                                 |
| ssl_crl       |                                 |
| ssl_crlpath   |                                 |
| ssl_key       | /usr/local/mysql/ssl/master.key |
+---------------+---------------------------------+

mysql> CHANGE MASTER TO
    ->   MASTER_HOST='192.168.2.100',
    ->   MASTER_USER='userssl',
    ->   MASTER_PASSWORD='1234@6@',
    ->   MASTER_PORT=3306,
    ->   MASTER_LOG_FILE='master-bin.000005',
    ->   MASTER_LOG_POS=442,
    ->   MASTER_SSL = 1,
    ->   MASTER_SSL_CA = '/usr/local/mysql/ssl/cacert.pem',
    ->   MASTER_SSL_CERT = '/usr/local/mysql/ssl/slave.crt',
    ->   MASTER_SSL_KEY = '/usr/local/mysql/ssl/slave.key';
Query OK, 0 rows affected, 2 warnings (0.06 sec)


13、查看Slave服务器状态

mysql> start slave;
Query OK, 0 rows affected (0.01 sec)

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.2.100
                  Master_User: userssl
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-bin.000005
          Read_Master_Log_Pos: 442
               Relay_Log_File: relay_log.000002
                Relay_Log_Pos: 284
        Relay_Master_Log_File: master-bin.000005
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0
                   Last_Error: 
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 442
              Relay_Log_Space: 451
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: Yes
           Master_SSL_CA_File: /usr/local/mysql/ssl/cacert.pem
           Master_SSL_CA_Path: 
              Master_SSL_Cert: /usr/local/mysql/ssl/slave.crt
            Master_SSL_Cipher: 
               Master_SSL_Key: /usr/local/mysql/ssl/slave.key
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 1
                  Master_UUID: 84774a86-3ee8-11e4-a268-000c29ad35d7
             Master_Info_File: /mydata/data/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: /usr/local/mysql/ssl/cacert.pem
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

ERROR: 
No query specified


14、基于SSL的结果验证

###在Master服务器上创建数据库并查看
[root@master ~]# mysql -e 'create database mydbtestt1;'
[root@master ~]# mysql -e 'show databases;'
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydbtestt1         |
| mysql              |
| performance_schema |
| test               |
+--------------------+

###在Slave服务器上查看是否同步

[root@slave ~]# mysql -e 'show databases;'
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydbtestt1         |
| mysql              |
| performance_schema |
| test               |
+--------------------+


九、mysql主主复制

1、主主复制或者互为主从的思路

1、在两台服务器上各自建立一个具有复制权限的用户
2、修改配置文件
3、重新启动数据库
4、查看两台服务器当前的二进制日志文件和事件位置
5、互为CHANGE MASTER TO
6、先后启动Slave功能


2、配置主主复制

###在Master上执行
1、创建具有复制权限的用户
mysql> grant replication slave,replication client on *.* to 'master1'@'192.168.2.200' identified by '1234@6@';
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

2、修改配置文件
[root@master ~]# vim /usr/local/mysql/my.cnf 
[mysqld]
server-id = 1
log-bin = master-node1-bin
relay-log = relay-mysql
relay-log-index = relay-mysql.index
auto-increment-increment = 2
auto-increment-offset = 1

3、重新启动数据库
[root@master ~]# service mysqld restart
Shutting down MySQL.. SUCCESS! 
Starting MySQL. SUCCESS! 

4、查看当前的二进制日志文件和事件位置
mysql> show master status;
+-------------------------+----------+--------------+------------------+-------------------+
| File                    | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------------+----------+--------------+------------------+-------------------+
| master-node1-bin.000001 |      120 |              |                  |                   |
+-------------------------+----------+--------------+------------------+-------------------+

5、两台服务器分别指定另一台服务器为自己的主服务器:
mysql> CHANGE MASTER TO
    -> MASTER_HOST='192.168.2.200',
    -> MASTER_USER='master2',
    -> MASTER_PASSWORD='1234@6@',
    -> MASTER_PORT=3306,
    -> MASTER_LOG_FILE='master-node2-bin.000001',
    -> MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.01 sec)

6、启动Slave并查看是否同步
mysql> start slave;
Query OK, 0 rows affected (0.02 sec)

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.2.200
                  Master_User: master2
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-node2-bin.000001
          Read_Master_Log_Pos: 120
               Relay_Log_File: relay-mysql.000002
                Relay_Log_Pos: 290
        Relay_Master_Log_File: master-node2-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0
                   Last_Error: 
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 120
              Relay_Log_Space: 459
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File: 
           Master_SSL_CA_Path: 
              Master_SSL_Cert: 
            Master_SSL_Cipher: 
               Master_SSL_Key: 
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 10
                  Master_UUID: 89726004-3ee8-11e4-a268-000c29c32576
             Master_Info_File: /mydata/data/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: 
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

ERROR: 
No query specified



###在Slave上执行
1、创建具有复制权限的用户
mysql> grant replication slave,replication client on *.* to 'master2'@'192.168.2.100' identified by '1234@6@';
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

2、修改配置文件
[root@master ~]# vim /usr/local/mysql/my.cnf 
[mysqld]
server-id = 10
log-bin = master-node2-bin
relay-log = relay-mysql
relay-log-index = relay-mysql.index
auto-increment-increment = 2
auto-increment-offset = 2

3、重新启动数据库
[root@master ~]# service mysqld restart
Shutting down MySQL.. SUCCESS! 
Starting MySQL. SUCCESS!
 
 4、查看当前的二进制日志文件和事件位置
mysql> show master status;
+-------------------------+----------+--------------+------------------+-------------------+
| File                    | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------------+----------+--------------+------------------+-------------------+
| master-node1-bin.000001 |      120 |              |                  |                   |
+-------------------------+----------+--------------+------------------+-------------------+

5、两台服务器分别指定另一台服务器为自己的主服务器
mysql> CHANGE MASTER TO
    -> MASTER_HOST='192.168.2.100',
    -> MASTER_USER='master1',
    -> MASTER_PASSWORD='1234@6@',
    -> MASTER_PORT=3306,
    -> MASTER_LOG_FILE='master-node1-bin.000001',
    -> MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.00 sec)

mysql> start slave;  #报错 
ERROR 1872 (HY000): Slave failed to initialize relay log info structure from the repository
mysql> reset slave;  #网上解决方案
Query OK, 0 rows affected (0.00 sec)

6、启动Slave并查看是否同步
mysql> start slave;
Query OK, 0 rows affected (0.07 sec)

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.2.100
                  Master_User: master1
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-node1-bin.000001
          Read_Master_Log_Pos: 120
               Relay_Log_File: relay-mysql.000005
                Relay_Log_Pos: 290
        Relay_Master_Log_File: master-node1-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 0
                   Last_Error: 
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 120
              Relay_Log_Space: 459
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: Yes
           Master_SSL_CA_File: /usr/local/mysql/ssl/cacert.pem
           Master_SSL_CA_Path: 
              Master_SSL_Cert: /usr/local/mysql/ssl/slave.crt
            Master_SSL_Cipher: 
               Master_SSL_Key: /usr/local/mysql/ssl/slave.key
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 0
               Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 1
                  Master_UUID: 84774a86-3ee8-11e4-a268-000c29ad35d7
             Master_Info_File: /mydata/data/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 
               Master_SSL_Crl: /usr/local/mysql/ssl/cacert.pem
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

ERROR: 
No query specified


3、验证主主复制是否同步

分为两种情况

第一、在主1上创建数据库、创建表、插入数据、删除部分数据;并在主2上查看是否同步

#创建数据库、创建表、插入数据、删除部分数据
[root@master ~]# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>  create database mydbs;
Query OK, 1 row affected (0.00 sec)

mysql> use mydbs;
Database changed
mysql> CREATE TABLE t1 (id int(11) DEFAULT NULL) ENGINE=MyISAM DEFAULT CHARSET=utf8; 
Query OK, 0 rows affected (0.03 sec)

mysql> insert into t1  value (1),(2),(3),(4),(5),(6),(7),(8),(9),(10); 
Query OK, 10 rows affected (0.01 sec)
Records: 10  Duplicates: 0  Warnings: 0

mysql> delete from t1 where id > 7;
Query OK, 3 rows affected (0.00 sec)

mysql> select * from t1;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
|    4 |
|    5 |
|    6 |
|    7 |
+------+
7 rows in set (0.00 sec)

mysql> \q
Bye


#查看是否同步成功
[root@slave ~]# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 6
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydbs              |
| mydbtestt1         |
| mysql              |
| performance_schema |
| test               |
+--------------------+
6 rows in set (0.00 sec)

mysql> use mydbs;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+-----------------+
| Tables_in_mydbs |
+-----------------+
| t1              |
+-----------------+
1 row in set (0.00 sec)

mysql> select * from t1;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
|    4 |
|    5 |
|    6 |
|    7 |
+------+
7 rows in set (0.00 sec)

mysql> \q
Bye


第二、在主2上创建数据库、创建表、插入数据、删除部分数据;并在主1上查看是否同步

#创建数据库、创建表、插入数据、删除部分数据
[root@slave ~]# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> create database mydbs222;
Query OK, 1 row affected (0.00 sec)

mysql> use mydbs222;
Database changed
mysql> CREATE TABLE t1 (id int(11) DEFAULT NULL) ENGINE=MyISAM DEFAULT CHARSET=utf8; 
Query OK, 0 rows affected (0.01 sec)

mysql> insert into t1  value (1),(2),(3),(4),(5),(6),(7),(8),(9),(10); 
Query OK, 10 rows affected (0.01 sec)
Records: 10  Duplicates: 0  Warnings: 0

mysql> delete from t1 where id > 7;
Query OK, 3 rows affected (0.00 sec)

mysql> select * from t1;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
|    4 |
|    5 |
|    6 |
|    7 |
+------+
7 rows in set (0.00 sec)


#查看是否同步成功
[root@master ~]# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 10
Server version: 5.6.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mydbs              |
| mydbs222           |
| mydbtestt1         |
| mysql              |
| performance_schema |
| test               |
+--------------------+
7 rows in set (0.00 sec)

mysql> use mydbs222;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+--------------------+
| Tables_in_mydbs222 |
+--------------------+
| t1                 |
+--------------------+
1 row in set (0.00 sec)

mysql> select * from t1;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
|    4 |
|    5 |
|    6 |
|    7 |
+------+
7 rows in set (0.00 sec)

到此,主主复制就完成了!是不是So Easy 啊!呵呵


十、mysql的高可用ha

1、简介

Mysql的高可用是基于Mysql的主主复制的基础,在这里主主复制就不在累述。


2、安装依赖包

yum -y install pcre-devel openssl-devel popt-devel

3、安装keepalived服务并添加系统服务

tar zxvf keepalived-1.2.7.tar.gz
cd keepalived-1.2.7
./configure --prefix=/usr/local/keepalived
make && make install
cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/
cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
mkdir /etc/keepalived/
cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
cp /usr/local/keepalived/sbin/keepalived /usr/sbin/

4、配置keepalived服务

ON Master1

[root@master keepalived]# cat keepalived.conf 
! Configuration File for keepalived
 
global_defs {
   notification_email {
     zhengyansheng@cdvcloud.com  #故障联系人
   }
   notification_email_from admin@cdvcloud.com #故障发送人
   smtp_server 127.0.0.1 
   smtp_connect_timeout 30
   router_id MySQL-MASTER    #定义router_id的名称
}
 
vrrp_instance VI_1 {
    state BACKUP             #都要修改成BACKUP
    interface eth1           #监听的本地网卡
    virtual_router_id 51     #默认为51,主从都选择默认
    priority 100             #优先级高的为主节点,从节点修改成80
    advert_int 1             #检查间隔,默认为1秒
    nopreempt                #不抢占资源,意思就是它活了之后也不会再把主抢回来
    authentication {
        auth_type PASS       #认证方式,可以是PASS或AH两种认证方式
        auth_pass 1111       #认证密码
    }
    virtual_ipaddress {
        192.168.2.88        #这里设置的就是VIP,也就是虚拟IP地址,他随着state的变化而增加删除,
    }
}
 
virtual_server 192.168.2.88 3306 {
    delay_loop 2          #每个2秒检查一次real_server状态;即服务轮询的时间间隔
    lb_algo rr            #LVS调度算法 rr|wrr|lc|wlc|lblc|sh|dh  
    lb_kind DR            #LVS模式 NAT|DR|TUN 
    nat_mask 255.255.255.0
    persistence_timeout 50  #同一IP的连接60秒内被分配到同一台真实服务器
    protocol TCP            #健康检查用的是TCP还是UDP
 
    real_server 192.168.2.100 3306 {  #检测本地mysql,backup也要写检测本地mysql是否存活
        weight 3
        notify_down /usr/local/keepalived/mysql.sh   #当mysql服务down时,执行此脚本,杀死keepalived实现VIP切换
        TCP_CHECK {
            connect_timeout 3     #连接超时
            nb_get_retry 3        #重试次数
            delay_before_retry 3  #重试间隔时间
        }
   }
}


ON Master2

[root@slave keepalived]# cat keepalived.conf 
! Configuration File for keepalived
 
global_defs {
   notification_email {
     zhengyansheng@cdvcloud.com
   }
   notification_email_from admin@cdvcloud.com
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id MySQL-BACKUP
}
 
vrrp_instance VI_1 {
    state BACKUP
    interface eth1
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.2.88
    }
}
 
virtual_server 192.168.2.88 3306 {
    delay_loop 2
    lb_algo rr
    lb_kind DR
    nat_mask 255.255.255.0
    persistence_timeout 50
    protocol TCP
 
    real_server 192.168.2.200 3306 {
        weight 3
        notify_down /usr/local/keepalived/mysql.sh
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
   }
}



5、建立授权登陆用户(两台服务器都要建立授权登陆用户)

mysql> grant all privileges on *.* to root@"192.168.2.%" identified by "123456";
mysql> flush privileges


6、启动keepalived服务(两台服务器都要启动keepalived服务)

service keepalived start


7、查看系统日志信息和vip地址

###查看输出系统日志信息
[root@slave ~]# tail -f /var/log/messages
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: TCP connection to [192.168.2.200]:3306 failed !!!
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Removing service [192.168.2.200]:3306 from VS [192.168.2.88]:3306
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Executing [/usr/local/keepalived/mysql.sh] for service [192.168.2.200]:3306 in VS [192.168.2.88]:3306
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Lost quorum 1-0=1 > 0 for VS [192.168.2.88]:3306
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Remote SMTP server [127.0.0.1]:25 connected.
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: SMTP alert successfully sent.
Sep 18 23:41:55 slave Keepalived[8952]: Stopping Keepalived v1.2.7 (09/18,2014)
Sep 18 23:41:55 slave Keepalived_vrrp[8955]: VRRP_Instance(VI_1) sending 0 priority
Sep 18 23:41:55 slave Keepalived_vrrp[8955]: VRRP_Instance(VI_1) removing protocol VIPs.


###查看vip地址 无
[root@slave ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:c3:25:76 brd ff:ff:ff:ff:ff:ff
    inet 192.168.2.200/24 brd 192.168.2.255 scope global eth1
    inet6 fe80::20c:29ff:fec3:2576/64 scope link 
       valid_lft forever preferred_lft forever
###查看输出系统日志信息
[root@master ~]# tail -f /var/log/messages 
Sep 18 23:41:55 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Transition to MASTER STATE
Sep 18 23:41:56 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Entering MASTER STATE
Sep 18 23:41:56 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) setting protocol VIPs.
Sep 18 23:41:56 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth1 for 192.168.2.88
Sep 18 23:41:56 master Keepalived_healthcheckers[5328]: Netlink reflector reports IP 192.168.2.88 added
Sep 18 23:42:01 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth1 for 192.168.2.88

#查看vip地址 有
[root@master ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:ad:35:d7 brd ff:ff:ff:ff:ff:ff
    inet 192.168.2.100/24 brd 192.168.2.255 scope global eth1
    inet 192.168.2.88/32 scope global eth1
    inet6 fe80::20c:29ff:fead:35d7/64 scope link 
       valid_lft forever preferred_lft forever


8、keepalived主从切换的脚本(分别在两台服务器上运行监控脚本)

#!/bin/bash 
while  : 
do 
 mysqldpid=`ps -C mysqld --no-header | wc -l` 
 if [ $mysqldpid -eq 0 ];then 
  /etc/init.d/mysqld restart
  sleep 5 
  mysqldpid=`ps -C mysqld --no-header | wc -l`
  echo $mysqldpid
    if [ $mysqldpid -eq 0 ];then 
 /etc/init.d/keepalived stop 
   fi 
 fi 
 sleep 5 
done
nohup /usr/local/mysql/mysql_keepalived.sh &
没有测试这个监控脚本
#!/bin/bash
MYSQL=/usr/local/mysql/bin/mysql
MYSQL_HOST=localhost
MYSQL_USER=root
MYSQL_PASSWORD="1234"
CHECK_TIME=3
#mysql is working MYSQL_OK is 0 , mysql down MYSQL_OK is 1
MYSQL_OK=1
function check_mysql_helth (){
$MYSQL -h $MYSQL_HOST -u $MYSQL_USER -p $MYSQL_PASSWORD -e "show status;" > /dev/null 2>&1
if [ $? = 0 ] ;then
MYSQL_OK=0
else
MYSQL_OK=1
fi
return $MYSQL_OK
}
while [ $CHECK_TIME -ne 0 ]
do
let "CHECK_TIME -= 1"
check_mysql_helth
if [ $MYSQL_OK = 0 ] ; then
CHECK_TIME=0
exit 0
fi
if [ $MYSQL_OK -eq 1 ] && [ $CHECK_TIME -eq 1 ]
then
  /etc/init.d/keepalived stop
exit 1
fi
sleep 1
done


9、测试高可用

1>通过Mysql客户端通过VIP连接,看是否连接成功Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _07

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _08


2>、停止master这台mysql服务,是否能正常切换过去,可通过ip addr命令来查看VIP在哪台服务器上

[root@master ~]# killall -9 mysqld
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
You have new mail in /var/spool/mail/root
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# killall -9 mysqld
mysqld: 没有进程被杀死
[root@master ~]# service mysqld status
 SUCCESS! MySQL running (6462)
[root@master ~]# service keepalived status
keepalived 已停
[root@master ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:ad:35:d7 brd ff:ff:ff:ff:ff:ff
    inet 192.168.2.100/24 brd 192.168.2.255 scope global eth1
    inet6 fe80::20c:29ff:fead:35d7/64 scope link 
       valid_lft forever preferred_lft forever


Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _09

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _10

3>、可通过查看/var/log/messges日志,看出主备切换过程

[root@master ~]# tail -f /var/log/messages 
Sep 18 23:41:55 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Transition to MASTER STATE
Sep 18 23:41:56 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Entering MASTER STATE
Sep 18 23:41:56 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) setting protocol VIPs.
Sep 18 23:41:56 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth1 for 192.168.2.88
Sep 18 23:41:56 master Keepalived_healthcheckers[5328]: Netlink reflector reports IP 192.168.2.88 added
Sep 18 23:42:01 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth1 for 192.168.2.88
Sep 18 23:53:28 master Keepalived_healthcheckers[5328]: TCP connection to [192.168.2.100]:3306 failed !!!
Sep 18 23:53:28 master Keepalived_healthcheckers[5328]: Removing service [192.168.2.100]:3306 from VS [192.168.2.88]:3306
Sep 18 23:53:28 master Keepalived_healthcheckers[5328]: Executing [/usr/local/keepalived/mysql.sh] for service [192.168.2.100]:3306 in VS [192.168.2.88]:3306
Sep 18 23:53:28 master Keepalived_healthcheckers[5328]: Lost quorum 1-0=1 > 0 for VS [192.168.2.88]:3306
Sep 18 23:53:28 master Keepalived_healthcheckers[5328]: Remote SMTP server [127.0.0.1]:25 connected.
Sep 18 23:53:28 master Keepalived_healthcheckers[5328]: SMTP alert successfully sent.
Sep 18 23:53:37 master Keepalived[5326]: Stopping Keepalived v1.2.7 (09/18,2014)
Sep 18 23:53:37 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) sending 0 priority
Sep 18 23:53:37 master Keepalived_vrrp[5329]: VRRP_Instance(VI_1) removing protocol VIPs.
[root@slave ~]# tail -f /var/log/messages
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: TCP connection to [192.168.2.200]:3306 failed !!!
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Removing service [192.168.2.200]:3306 from VS [192.168.2.88]:3306
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Executing [/usr/local/keepalived/mysql.sh] for service [192.168.2.200]:3306 in VS [192.168.2.88]:3306
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Lost quorum 1-0=1 > 0 for VS [192.168.2.88]:3306
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: Remote SMTP server [127.0.0.1]:25 connected.
Sep 18 23:41:46 slave Keepalived_healthcheckers[8954]: SMTP alert successfully sent.
Sep 18 23:41:55 slave Keepalived[8952]: Stopping Keepalived v1.2.7 (09/18,2014)
Sep 18 23:41:55 slave Keepalived_vrrp[8955]: VRRP_Instance(VI_1) sending 0 priority
Sep 18 23:41:55 slave Keepalived_vrrp[8955]: VRRP_Instance(VI_1) removing protocol VIPs.
Sep 18 23:53:02 slave Keepalived[10202]: Starting Keepalived v1.2.7 (09/18,2014)
Sep 18 23:53:02 slave Keepalived[10203]: Starting Healthcheck child process, pid=10205
Sep 18 23:53:02 slave Keepalived[10203]: Starting VRRP child process, pid=10206
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Interface queue is empty
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Netlink reflector reports IP 192.168.2.200 added
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Netlink reflector reports IP fe80::20c:29ff:fec3:2576 added
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Registering Kernel netlink reflector
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Registering Kernel netlink command channel
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Registering gratuitous ARP shared channel
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Opening file '/etc/keepalived/keepalived.conf'.
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Interface queue is empty
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Netlink reflector reports IP 192.168.2.200 added
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Netlink reflector reports IP fe80::20c:29ff:fec3:2576 added
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Registering Kernel netlink reflector
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Registering Kernel netlink command channel
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Opening file '/etc/keepalived/keepalived.conf'.
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Configuration is using : 63030 Bytes
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Configuration is using : 11601 Bytes
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: Using LinkWatch kernel netlink reflector...
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Using LinkWatch kernel netlink reflector...
Sep 18 23:53:02 slave Keepalived_healthcheckers[10205]: Activating healthchecker for service [192.168.2.200]:3306
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: VRRP_Instance(VI_1) Entering BACKUP STATE
Sep 18 23:53:02 slave Keepalived_vrrp[10206]: VRRP sockpool: [ifindex(2), proto(112), fd(11,12)]
Sep 18 23:53:37 slave Keepalived_vrrp[10206]: VRRP_Instance(VI_1) Transition to MASTER STATE
Sep 18 23:53:38 slave Keepalived_vrrp[10206]: VRRP_Instance(VI_1) Entering MASTER STATE
Sep 18 23:53:38 slave Keepalived_vrrp[10206]: VRRP_Instance(VI_1) setting protocol VIPs.
Sep 18 23:53:38 slave Keepalived_vrrp[10206]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth1 for 192.168.2.88
Sep 18 23:53:38 slave Keepalived_healthcheckers[10205]: Netlink reflector reports IP 192.168.2.88 added
Sep 18 23:53:43 slave Keepalived_vrrp[10206]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth1 for 192.168.2.88


4>、master服务器故障恢复后,是否主动抢占资源,成为活动服务器。

[root@master ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:ad:35:d7 brd ff:ff:ff:ff:ff:ff
    inet 192.168.2.100/24 brd 192.168.2.255 scope global eth1
    inet6 fe80::20c:29ff:fead:35d7/64 scope link 
       valid_lft forever preferred_lft forever
[root@master ~]# service mysqld status
 SUCCESS! MySQL running (6462)
[root@master ~]# service keepalived status
keepalived 已停
[root@master ~]# service keepalived start
正在启动 keepalived:                                      [确定]
[root@master ~]# service keepalived status
keepalived (pid  6761) 正在运行...
[root@master ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:ad:35:d7 brd ff:ff:ff:ff:ff:ff
    inet 192.168.2.100/24 brd 192.168.2.255 scope global eth1
    inet6 fe80::20c:29ff:fead:35d7/64 scope link 
       valid_lft forever preferred_lft forever


*******2014-11-12补充内容************

介绍修改mysql密码的三种方法

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _11

解决mysql数据库中忘记root密码的的两种方法

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _12Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _13Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _14


*******2014-11-13补充内容************

mysqldump导出数据时排除某些表

mysqldump -u*** -p*** database --ignore-table=database.table1 --ignore-table=database.table2 > backup.sql


*******2015-09-14补充内容************

mysql主从复制中允许哪些库复制,忽略哪些库复制

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _15

Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _16

mysql> show master status;
+-------------------+----------+--------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------+------------------+-------------------+
| master-bin.000007 |      205 | t            | tt               |                   |
+-------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)


Linux运维必备Mysql知识_mysql 主从复制 半同步复制 主主 _17

在从库上有两个文件分别是master.info和relay-log.info文件

这两个文件分别对应着从库的两个线程 io线程 对应master.info; sql线程对应relay-log.info文件