MySQL热机双备之双主同步复制配置
此配置方案来源于csdn前辈博客,奈何找不到出处了,抱拳!!!
1. MySQL同步机制概述
MySQL支持单向、异步复制,复制过程中一台服务器充当主服务器,一台或多台服务器充当从服务器,双主同步要求两台服务器互为主从即可。
MySQL的同步机制基于主服务器把所有的对数据库的更新操作记录在二进制日志中,并维护日志文件索引以跟踪日志。从服务器在日志中读取最后一次更新的位置,并接收从那时起发生的所有更新,然后封锁并等待主服务器的下一次更新通知。因此,启用同步机制,主服务器必须启用二进制日志,每个从服务器接受来自主服务器上二进制日志中记录的更新操作,其实从服务器执行的是来自主服务器日志中记录的sql拷贝。所以启用同步时要求主从服务器的二进制日志文件相一致,否则同步失败。
MySQL同步功能由3个线程(主服务器master上1个,从服务器slave上2个)来实现。执行START SLAVE语句后,slave就创建一个I/O线程。I/O线程连接到master上,并请求master发送二进制日志中的语句。master创建一个线程来把日志的内容发送到slave上。这个线程在master上执行SHOW PROCESSLIST语句后的结果中的 Binlog Dump 线程便是。slave上的I/O线程读取master的Binlog Dump线程发送的语句,并且把它们拷贝到其数据目录下的中继日志(relay logs)中。第三个是SQL线程,salve用它来读取中继日志,然后执行它们来更新数据。
如上所述,每个mster/slave上都有3个线程。每个master上有多个线程,它为每个slave连接都创建一个线程,每个slave只有I/O和SQL线程。在MySQL中执行SHOW PROCESSLIST语句就会告诉我们所关心的master和slave上发生的情况。
2. 配置环境
操作系统:Linux
环境:MySQL
A、B两台服务器
A- ip:192.168.204.128
B- ip:192.168.204.129
要求A、B两台服务器可通信
关闭两台服务器防火墙
3同步配置
3.1在主从服务器上创建同步账号
在A服务器上创建一个B服务器可登陆的账号,进入到mysql终端创建同步账号为:rootnew,密码为:123456;
Mysql>grant all privileges on *.* to ‘rootnew’@’192.168.204.129’ identified by ‘123456’;
Mysql>flush privileges;
在B服务器上创建一个A服务器可登陆的账号:
Mysql>grant privileges on *.* to ‘newroot’@’192.168.204.128’ identified bu ‘123456’;
Mysql>flush privileges;
此时在A、B服务器上的mysql数据库中各有一个newroot用户:
3.2主服务器数据库备份(新装数据库忽略此步骤)
3.3修改主从服务器配置文件
在A、B服务器上创建空的zyyt_antm数据库,打开A服务器的my.cnf文件,在文件中[mysqld]下添加如下内容:(各操作系统的my.cnf文件位置不一样,我的是在/etc/mysql/下)
skip-name-resolve
server-id=1 #必须与其他服务器不同,且必须为1到232–1之间的一个正整数值
#i am master
log-bin=mysql-bin #二进制文件
binlog-do-db=zyyt_antm #要同步的数据库,此处我直接用单位项目做测试
binlog-ignore-db=information_schema #不同步的数据库
binlog-ignore-db=db_Im
binlog-ignore-db=db_Mdr
binlog-ignore-db=db_mrs
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=test
slave-skip-errors=1032,1062
重启A服务器的mysql服务:
~# /etc/inti.d/mysql restart
重启成功表明A服务器配置成功。
打开B服务器的my.cnf文件,在[mysqld]节点下添加同样内容:
skip-name-resolve
server-id=2 #必须与其他服务器不同,且必须为1到232–1之间的一个正整数值
#i am master
log-bin=mysql-bin #二进制文件
binlog-do-db=zyyt_antm #要同步的数据库
binlog-ignore-db=information_schema #不同步的数据库
binlog-ignore-db=db_Im
binlog-ignore-db=db_Mdr
binlog-ignore-db=db_mrs
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=test
slave-skip-errors=1032,1062
重启B服务器的mysql服务。
3.4指定主从服务器同步信息
1.在A服务器上查看当前二进制日志文件和偏移量值:
Mysql>show master status\G;
记录mysql二进制文件中的file和position值;
2.在B服务器上指定更新点(根据上面样例修改MASTER_LOG_FILE值为样例结果中的file值;修改MASTER_LOG_POS值为样例结果中的position值)。
Mysql>stop slave;
Mysql>change master to master_host=’192.168.204.128’,master_port=3306,master_user=’rootnew’,master_password=’123456’,master_log_file=’mysql-bin.000012’,master_log_pos=154;
Mysql>start slave;
3.在B服务器上查看当前二进制日志名和偏移量:
Mysql>show master status;
记录mysql二进制文件中的file值和position值
4. 在A服务器上指定更新点(根据上面样例修改MASTER_LOG_FILE值为样例结果中的file值;修改MASTER_LOG_POS值为样例结果中的position值)。
Mysql>stop slave;
Mysql>change master to master_host=’192.168.204.129’,master_port=3306,master_user=’rootnew’,master_password=’123456’,master_log_file=’mysql-bin.000010’,master_log_pos=154;
Mysql>start slave;
5.重启A、B服务器的mysql服务。
3.5检查数据库同步状态
1.查看A、B服务器数据库同步状态,主要查看Slave_IO_Running与Slave_SQL_Running这两字段显示为yes就可以。
Mysql>show slave status\G;
2.查看A、B服务器的同步线程状态:
Mysql>show processlist\G;
若输入命令后出现概述所述的三个线程,则证明配置成功。
MySQL热机双备之双主同步复制配置的更多相关文章
- InnoSQL HA Suite的实现原理与配置说明 InnoSQL的VSR功能Virtual Sync Replication MySQL 5.5版本引入了半同步复制(semi-sync replicaiton)的功能 MySQL 5.6支持了crash safe功能
InnoSQL HA Suite的实现原理与配置说明 InnoSQL的VSR功能Virtual Sync Replication MySQL 5.5版本引入了半同步复制(semi-sync repl ...
- MySQL数据库的主从同步复制配置
一.主从同步机制原理 MYSQL主从同步是在MySQL主从复制(Master-Slave Replication)基础上实现的,通过设置在Master MySQL上的binlog(使其处于打开状态), ...
- Mysql 半同步复制配置
以下是配置和监控半同步复制: 1. 半同步复制功能以plugin的方式接入MySQL,需要在主库与从库两端同时开启半同步的支持,具体配置如下: On the master mysql> INST ...
- MySQL + KeepAlived + LVS 单点写入主主同步高可用架构实验
分类: MySQL 架构设计 2013-05-08 01:40 5361人阅读 评论(8) 收藏 举报 mysql 高可用 keepalive ㈠ 实战环境 服务器名· IP OS MySQL odd ...
- mysql 主从master-slave同步复制 配置,为读写分离准备
1.为方便,我在一个windows下安装两个mysql实例,端口分别是 3306.3307 打开 my.ini 或 my-default.ini 文件 配置 basedir datadir 和port ...
- MySQL半同步复制配置
ansible-playbook -f 3 endpoint/mysql.yml -e "exec=fileConfig" -e "db_action=setAll&qu ...
- mysql数据库备份,主从复制及半同步复制
1.使用mysqldump备份数据库并通过备份及二进制日志还原数据(备份完后再写入数据,然后再删库) mysqldump -A --single-transaction -F --master-dat ...
- 烂泥:mysql5.5主从同步复制配置
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 在上篇文章<烂泥:学习mysql数据库主从同步复制原理>中,我们介绍了有关mysql主从复制的基本原理.在这篇文章中,我们来实际测试下mys ...
- mysql5.5主从同步复制配置
在上篇文章<烂泥:学习mysql数据库主从同步复制原理>中,我们介绍了有关mysql主从复制的基本原理.在这篇文章中,我们来实际测试下mysql5.5的主从同步复制功能. 注意mysql5 ...
随机推荐
- 全网最详细!Centos7.X 搭建Grafana+Jmeter+Influxdb 性能实时监控平台
背景 日常工作中,经常会用到Jmeter去压测,毕竟LR还要钱(@¥&*...),而最常用的接口压力测试,我们都是通过聚合报告去查看压测结果的,然鹅聚合报告的真的是丑到家了,作为程序猿这当然不 ...
- 【Java并发基础】Java线程的生命周期
前言 线程是操作系统中的一个概念,支持多线程的语言都是对OS中的线程进行了封装.要学好线程,就要搞清除它的生命周期,也就是生命周期各个节点的状态转换机制.不同的开发语言对操作系统中的线程进行了不同的封 ...
- mongo 的 中文社区的 文档还是 挺不错的
英文文档也奉上: http://api.mongodb.com/csharp/2.2/html/T_MongoDB_Bson_Serialization_Attributes_BsonIdAttrib ...
- 创建认证提供器 安全性与收尾工作 精通ASP-NET-MVC-5-弗瑞曼
- 团队项目——Alpha1版本
团队项目-Alpha版本发布1 一.格式描述 这个作业属于哪个课程 https://edu.cnblogs.com/campus/xnsy/GeographicInformationScience/ ...
- Commvault逻辑架构及组件说明
在学习和使用Commvault软件的过程中,经常会碰到一些术语和缩写,初学者可能并不是很清楚这些术语和缩写的具体含义,接下来我们梳理一下Commvault软件中这些属于和缩写的含义,有可能一次不能梳理 ...
- ros中坐标系管理系统
首先安装小海龟实例的功能包ros-melodic-turtle-tf qqtsj ~ sudo apt install ros-melodic-turtle-tf [sudo] qqtsj ...
- c++中静态成员函数
静态成员函数 静态成函数和静态成员数据相同,他们都属于某一个类的静态成员而不是某一个对象的成员. 静态数据成员的使用方法和注意事项 1.静态数据成员在定义或说明时前面加上关键字static 2.初始化 ...
- C语言之灵魂 指针学习
指针是c语言的难点 称之为c语言的灵魂一点也不为过,不过指针用好了能事半功倍,用不好bug满天飞. 一.指针的概念 指针也是变量只不过是特殊的变量,指针的值是另一个变量的地(也就是变量所在的内存地址) ...
- SDL初始化和创建窗口
//初始化SDL2和创建一个窗口,并且将屏幕绘制成大红色 #include <iostream> extern "C" { #include <SDL.h> ...