前言:
原理与思想
这里选用GTID主从复制模式Mysql主从复制模式,是为了更加确保主从复制的正确性、健康性与易配性。这里作的是两服务器A,B各有Mysql实例3310,两个实例间互为主从
主从复制模式采用GTID主从复制模式,在服务器A,B上配置keepalived负载均衡,经过VIP链接数据库,目的是一旦有某数据库宕机,keepalived 就会当即建VIP执行另一台
健康的数据库实例上,实现快速切换,避免单点故障,从而保证业务的正常运行。
这里只作了 双主+keepalived , 对于读写要求很大大的环境,推荐架构是,双主多从(能够经过集群管理软件MMM来实现高可用架构)读写分离,固然代价也是比较高的 。
读写分离实现方法:
一、程序实现:程序端预留接口,当对于已经在运行的环境,从新修改程序,貌似不大现实
二、Mysql_proxy :官方的一种实现方式,可是官方建议不要再生产环境中使用,因此不推荐
三、Amoeba 软件分离 (推荐使用)
架构图:
1、环境要求:
服务器A: |
192.168.1.31 |
系统环境:CetnOS6.五、Mysql-5.6.19(主从)、Keepalived(master) |
服务器B: |
192.168.1.32 |
系统环境:CetnOS6.五、Mysql-5.6.19(从主)、Keepalived(back) |
2、安装Mysql 与 主从配置
(mysql安装步骤略)
这里服务器A上配置实例为3310,服务器B上的实例也为3310 (双主一样端口号的好处是在故障切换的时候)
安装好mysql后修改配置文件
一、修改A服务器上的mysql配置文件my.cnf
在my.cnf文件里加入参数(注意不要重复定义参数)
server-id = 201 //这里的ID号与从库上或者主库上的ID必须保证不同
log-bin=mysql-bin //能够自定义 这里定义为 log-bin=/data/log-bin/log-bin-3310
binlog_format=row //主从复制模式
log-slave-updates=true //slave 更新是否记入日志
gtid-mode=on // 启用gtid类型,不然就是普通的复制架构
enforce-gtid-consistency=true //强制GTID 的一致性
master-info-repository=TABLE //主服信息记录库=表 /文件
relay-log-info-repository=TABLE //中继日志信息记录库
sync-master-info=1 //同步主库信息
slave-parallel-workers=4 //从服务器的SQL 线程数,要复制库数目相同
binlog-checksum=CRC32 // 校验码 ,能够自定义
master-verify-checksum=1 //主服校验
slave-sql-verify-checksum=1 //从服校验
binlog-rows-query-log_events=1 //二进制日志详细记录事件
report-port=3310 //提供复制报告端口,当前实例端口号
report-host=192.168.1.31 //提供复制报告主机,本机的ip地址
二、修改B服务器上的mysql配置文件my.cnf
在my.cnf文件里加入参数(注意不要重复定义参数)
server-id = 202 //这里的ID号与从库上或者主库上的ID必须保证不惟一
log-bin=mysql-bin //能够自定义 这里定义为 log-bin=/data/log-bin/log-bin-3310
binlog_format=row //主从复制模式
log-slave-updates=true //slave 更新是否记入日志
gtid-mode=on // 启用gtid类型,不然就是普通的复制架构
enforce-gtid-consistency=true //强制GTID 的一致性
master-info-repository=TABLE //主服信息记录库=表 /文件
relay-log-info-repository=TABLE //中继日志信息记录库
sync-master-info=1 //同步主库信息
slave-parallel-workers=4 //从服务器的SQL 线程数,要复制库数目相同
binlog-checksum=CRC32 // 校验码 ,能够自定义
master-verify-checksum=1 //主服校验
slave-sql-verify-checksum=1 //从服校验
binlog-rows-query-log_events=1 //二进制日志详细记录事件
report-port=3310 //提供复制报告端口,当前实例端口号
report-host=192.168.1.32 //提供复制报告主机,本机的ip地址
replicate-wild-ignore-table=mysql.%
replicate-wild-ignore-table=test.%
replicate-wild-ignore-table=performance_schema.% mysql
(能够在配置文件里加入,做用屏蔽要复制的库)sql
三、受权
A服务器mysql实例3310:
grant replication slave,replication client on *.* to slave@'192.168.1.32'identified by '123456';
B服务器mysql实例3310:
grant replication slave,replication client on *.* to slave@'192.168.1.32'identified by '123456';
================================================================================
A服务器mysql实例3310:
change master to master_host='192.168.1.32',master_port=3310,master_user='slave',master_password='123456',master_auto_position=1;
注意:这里要是不配置参数master_port=3311,默认的会去找3306
B服务器mysql实例3310:
change master to master_host='192.168.1.31',master_port=3310,master_user='slave',master_password='123456',master_auto_position=1;
==================================================================================
A、B服务器上开启主从复制:start slave;
四、查看状态
A服务器:show slave status\G;show processlist;
B服务器:show slave status\G; show processlist;
#show processlist;
五、到这里A、B服务器间基于GTID主从复制模式已经配置好了,测试下
在A服务器3310实例上:drop databse test;B服务器3310上查看状态:show databases;
在B服务器3310实例上:create database wll_test; A服务器上3310上查看状态:show databases;
3、安装配置Keepalived负载均衡器
一、官网下载www.keepalived.org
在A服务器和B服务器上安装keepalived
#tar zxvf keepalived-1.2.20.tar.gz
#cd keepalived-1.2.20.tar.gz
#./configure --sysconf=/etc --with-kernel-dir=/usr/local/src/kernels/2.6.32-573.el6.x86_64
#make&&make install
#ln -s /usr/local/sbin/keepalived /sbin/
#ln -s /usr/local/keepalived-1.2.20 /usr/local/keepalived
#chkconfig --level 35 keepalived on
二、配置keepalived
#配置A服务器
#配置B服务器
三、# /etc/keepalived/change_mysql.sh 脚本内容为强杀死keepalived进程
四、#配置好后开启两服务器 keepalived
#/etc/init.d/keepalived start
#ps aux | grep keepalived
五、查看状态
# ip a
keepalived的工做机制是:每2秒检查一次real_server的监控状态,一旦发现数据库down了,此时VIP就会转移到另一台上,从而实现故障快速切换,用户在经过VIP链接
基本能够保持一直链接状态。
4、测试切换
先检查服务器A与服务器B上的Mysql实例与keepalived是否都为开启状态
一、此时VIP在服务器B上
在B服务器上将Mysql实例3310 stop
# /etc/init.d/mysqld_3310 stop
能够看到VIP立刻就切换到了服务器A 192.168.1.31这台上
二、客户端链接数据库
基本不会有影响
后续:欢迎评判!