MySQL的主从复制+双主模式

MySQL的主从复制

部署环境:

MySQL master 192.168.40.21

MySQL slave  192.168.40.22

思路:

当主MySQL上进行数据上的操作或者变化时,主MySQL上的二进制日志文件(binary log)会随之产生变化,这时从MySQL上开启I/O线程和sql线程;

I/O线程是对主MySQL上二进制日志文件进行读取,读取到从MySQL的中继日志文件上(relay log)

sql线程是读取和执行中继日志文件上数据,整过程就是实现主从复制的过程,实现后的效果是当主MySQL有变动,从的也会随之同步变动,也可称为主备模式

搭建主从:

搭建前提需要注意两台服务上的时间问题,时间上需要同步一致。如果不一致,可以一下操作:

主MySQL上安装NTP

[[email protected] ~]# yum -y install ntp

[[email protected] ~]# vim /etc/ntp.conf

#手动添加

22  server 127.127.1.0
23  fudge 127.127.1.0 startum 8

重启NTP

[[email protected] ~]#chkconf ntpd on   #开机启动

在从MySQL上搭建时间同步,安装ntpdate

[[email protected] ~]# yum -y install ntpdate

[[email protected] ~]# ntpdate 192.168.40.21

配置主MySQL服务器

[[email protected] ~]# cat /etc/my.cnf

#手动添加在MySQLD下

log-bin=mysql-bin
log-slave-updates=true
server-id =11

[[email protected] ~]#/etc/init.d/msyql restart

#进入MySQL里,给从服务权限

mysql> grant replication slave on *.*to‘myslave‘@‘192.168.40.%‘identified by ‘123123‘;

mysql> flush privileges;       #刷新授权表

mysql> show master status;   #查看当前二进制文件

配置从MySQL服务器  

[[email protected] ~]# vim /etc/my.cnf

relay-log=relay-log-bin

relay-log-index=slave-relay-bin.index
server-id =12  #id不能与主服务一样

重新启动MySQL并且进入

mysql> change master to

mysql> master_host=‘192.168.40.21‘,master_user=‘myslave‘,master_password=‘123123‘,master_log_file=‘mysql-bin.000036‘,master_log_pos=267;

mysql> start slave

mysql> show slave status\G;

图片上前两行yes代表IO线程和SQL线程都没问题,现在来测试下!

在主MySQL上创建一个www库

现在查看从MySQL的库是否有变化

可以看出从MySQL已经实时更新数据了,出现了www库!

MySQL双主模式

搭建环境以及思路:

在上面的实验环境的基础上,反向搭建主从,也就是说在上一个实验环境的基础上在从上面做一个主,在主上做一个从,即一台MySQL是另一台的主也是从 ,然后再安装keepalived进行高可用和故障切换

搭建过程:

在上一个案例的从上搭建一个主

其实,配置过程和之前案一样,只不过是方向配置,过程就不写这么详细了

修改配置文件/etc/my.cnf

#手动添加

log-bin=mysql-bin
log-slave-updates=true
server =20

重启MySQL并进入给从服务权限

mysql> grant replication slave on *.*to‘myslave‘@‘192.168.40.%‘identified by‘123123‘;

mysql> flush privileges;

mysql> show master status;

 

在上个案例主上配置从

修改配置文件/etc/my.cnf

#手动添加

relay-log=relay-log-bin
relay-log-index=slave-bin.index
server-id =22

重启服务并且登录

mysql> change master to

mysql> master_host=‘192.168.40.22‘,master_user=‘myslave‘,master_password=‘123123‘,master_log_file=‘mysql-bin.000002‘,master_log_pos=501;

mysql> start slave

mysql> show slave status\G

双主配置成功,现在需要编写一个健康MySQL的脚本和安装一个keepalived高可用软件,因为之前做集群的时候已经安装了,所以就不在安装keepalived

脚本:

#!/bin/bash
#by:Dfengshuo
#检测端口脚本
#检测mysql 3306端口是否开启,如果没有开启尝试开启
jc=`ps -C mysqld -no-header|wc -l`
if [ $jc -eq 0 ];then
/etc/init.d/mysqld restart
sleep 2
#如果mysql尝试开启失败,那么就关闭keepalived服务,进行vip飘移
jc2=`ps -C haproxy -no-header |wc -l`
if [ $jc -eq 0 ];then
/etc/init.d/keepalived stop
fi
fi

[[email protected] ~]# scp mysql.sh 192.168.40.22:/root    #把脚本发给192.168.40.22 root下

修改keepalived的配置文件

修改192.168.40.22上的keepalived配置文件,因刚刚把脚本发在root下了,所以不用在写脚本了

配置完之后重启keepalived服务查看vip是否存在

现在测试keepalived宕机后,vip是否飘移

由此可见,vip已经飘移到40.22上了,测试成功!!!

=====文中如有错误,欢迎指出!=====

原文地址:https://www.cnblogs.com/Dfengshuo/p/9451027.html

时间: 2024-11-05 13:49:59

MySQL的主从复制+双主模式的相关文章

Centos 6.5 下搭建Mysql 5.6双主模式

环境:centos 6.5  mysql 5.6 service DB1: 192.168.235.134 service DB2: 192.168.235.149 1.设置同步账号密码及权限 Service DB1 mysql> grant all privileges on *.* to [email protected] identified by '123' with grant option; Query OK, 0 rows affected (0.02 sec) mysql> f

通过KeepAlived搭建MySQL双主模式的高可用集群系统

企业级MySQL集群具备高可用.可扩展.易管理.低成本的特点.下面将介绍企业环境中经常应用的一个解决方案,即MySQL的双主互备架构,主要设计思路是通过MySQL Replication技术将两台MySQL Server互相将对方作为自己的Master,自己又同时作为对方的Slave来进行复制.这样就实现了高可用构架中的数据同步功能,同时,将采用KeepAlived来实现Mysql的自动failover.在这个构架中,虽然两台MySQL Server互为主从,但同一时刻只有一个MySQL Ser

Mysql + keepalived 实现双主热备读写分离【转】

Mysql + keepalived 实现双主热备读写分离 2013年6月16日frankwong发表评论阅读评论 架构图 系统:CentOS6.4_X86_64软件版本:Mysql-5.6.12,Keepalived-1.2.7环境简介:1.Master-A 192.168.1.168 (Mysql+Keepalived)2.Master-B 192.168.1.169 (Mysql+Keepalived)3.写入VIP 192.168.100 (168主,169从)4.读取VIP 192.1

keepalived双主模式实现nginx高可用及LNAMMP架构

keepalived双主模式实现nginx高可用及LNAMMP架构 一.利用keepalived实现nginx调度器高可用: 二.构建LNAMMP架构: 1) Nginx既是前端调度器,又是缓存服务器: 2) 将php的session缓存于memcached中: 3) 在Apache和php上部署Discuz论坛程序: 4) 使用https连接,即使用户使用的是http协议也可以以https协议进行访问: ---------------------------------------------

ansible实现nginx双主模式反代,keepalived高可用,memcached缓存

ansible自动化运维工具配置ngnix前端反代到后端真实机,并设置keepalived高可用,在后端一台真实主机上配置httpd,mysql,php-fpm:设置memcached缓存服务器在这台真实主机上:(因为本人电脑配置问题,无法开启那么多虚拟机,所以就简单构建了一下) IP配置: Directory1(MASTER): eno16777736:172.16.72.5 eno16777736:0:172.16.72.1(虚拟VIP) eno33554976:192.168.72.1 e

KeepAlived双主模式高可用集群

一.keepalived简介 keepalived是vrrp协议的实现,原生设计目的是为了高可用ipvs服务,keepalived能够配置文件中的定义生成ipvs规则,并能够对各RS的健康状态进行检测:通过共用的虚拟IP地址对外提供服务:每个热备组内同一时刻只有一台主服务器提供服务,其他服务器处于冗余状态,若当前在线的服务器宕机,其虚拟IP地址将会被其他服务器接替(优先级决定接替顺序),实现高可用为后端主机提供服务.   二.keepalived组件 Keepalived组件介绍 core:ke

haproxy高可用以及双主模式(二)

haproxy主备 虚拟VIP:192.168.33.130 把haproxy-01的配置文件拷贝到haproxy-02机器相应的目录即可 [email protected] haproxy]# scp haproxy.cfg [email protected]:/etc/haproxy/ haproxy.cfg                                     100% 3520     3.4KB/s   00:00 启动haproxy-02服务 [[email pro

mysql数据库复制—双主

一.实现环境 centos master1:172.16.20.245 master2:172.16.20.219 两数据库均是新安装 二.master1安装配置 1配置文件 #vim /etc/my.cnf server-id = 10 log-bin = mysql-bin log-bin-index = mysql-bin.index binlog-format = mixed relay-log = relay-mysql relay-log-index = relay-mysql.in

haproxy+keepalived主备与双主模式配置

Haproxy+Keepalived主备模式 主备节点设置 主备节点上各安装配置haproxy,配置内容且要相同 global log 127.0.0.1 local2 chroot /var/lib/haproxy pidfile /var/run/haproxy.pid maxconn 4000 user haproxy group haproxy daemon defaults #defaults段默认值对frontend和backend和listen段生效 mode http #运行模式