Mysql主主同步详细操作过程
此处是在公司线上部署mysql双主时所记录的文档,为安全,IP都改为内网IP。
版本信息:
#mysql -V
mysql Ver 14.14 Distrib 5.5.37, fordebian-linux-gnu (x86_64) using readline 6.2
1、主库开启bin-log功能,配置server-id
修改my.cf配置文件,开启bin-log功能,配置server-id。
#cat /etc/mysql/my.cnf
[myqld]
server-id = 1
log_bin =/var/log/mysql/
slave-net-timeout = 60
#salve-net-timeout默认是3600秒,缩短时间是为了防止双YES的假象
#(事实上我已遇到,参考地址:http://www.cnblogs.com/billyxp/p/3470376.html)
如果要指定同步或不同步哪些库,可使用如下参数
#binlog-do-db=osyunweidb #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行
#binlog-ignore-db=mysql #不同步mysql系统数据库
2、确认bin-log与server-id是否开启:
查看命令 show variables like 'log_bin'; show variables like 'server_id';
mysql> show variables like 'log_bin';
+---------------+-------+
|Variable_name | Value |
+---------------+-------+
|log_bin | ON |
+---------------+-------+
1 rowin set (0.00 sec)
mysql>show variables like 'server_id';
+---------------+-------+
|Variable_name | Value |
+---------------+-------+
|server_id | 1 |
+---------------+-------+
1 rowin set (0.00 sec)
3、创建复制授权用户
mysql> grant replication slave on *.* to replication@'%'identified by '123456'; #授权该用户对所有表都能进行复制
mysql>flush privileges; #刷新权限
4、锁表,记录log-bin文件名和位置
mysql>flush tables with read lock; #锁定所有表,此时数据库不能写入数据
QueryOK, 0 rows affected (0.05 sec)
mysql>show master status; #查看最新bin-log文件及位置
+------------------------+------------+-------------------+-------------------------+
|File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------------+------------+-------------------+-------------------------+
|mysql-bin.000001 | 26314 | | |
+------------------------+------------+-------------------+-------------------------+
1row in set (0.00 sec)
5、锁表状态全备mysql数据
由于退出当前mysql登陆窗口,锁表功能就失效,需克隆一个会话进行全备。
#mysqldump-uroot -p -A -B >/tmp/mysql_bak_2014_10_30.sql.gz
看下备份数据大小,确认备份成功。
#ls -l /tmp/mysql_bak_2014_10_30.sql.gz
-rw-r--r--1 root root 339222 10月 3011:01 /tmp/mysql_bak_2014_10_30.sql.gz
6、解除锁表
mysql>unlock tables;
或直接quit退出即可。
7、从库开启bin-log功能,配置server-id
从库开启bin-log功能后,待会在主上在配置同步,互为主从就完成了。
#cat /etc/mysql/my.cnf
[myqld]
server-id = 2
log_bin =/var/log/mysql/mysql-bin.log
slave-net-timeout = 60
#salve-net-timeout默认是3600秒,缩短时间是为了防止双YES的假象
#(参考地址:http://www.cnblogs.com/billyxp/p/3470376.html)
#/etc/init.d/mysqlrestart
8、确认从库bin-log与server-id是否开启
查看命令 show variables like 'log_bin'; show variables like 'server_id';
mysql>show variables like 'log_bin';
+---------------+-------+
|Variable_name | Value |
+---------------+-------+
|log_bin | ON |
+---------------+-------+
1row in set (0.00 sec)
mysql>show variables like 'server_id';
+---------------+-------+
|Variable_name | Value |
+---------------+-------+
|server_id | 2 |
+---------------+-------+
1row in set (0.00 sec)
9、从库导入主库的全备数据
在从库上解压数据。
#gzip-d mysql_bak_2014_10_30.sql.gz
登陆mysql导入数据
mysql>source /root/mysql_bak_2014_10_30.sql
10、记录从库bin-log信息
因为在从库导入全备数据时,此时主库与从库的内容是一致的,但是bin-log位置不一定一致。
mysql>show master status; #查看最新bin-log文件及位置
+------------------------+------------+-------------------+-------------------------+
|File |Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------------+------------+-------------------+-------------------------+
|mysql-bin.000003 | 2328055 | | |
+------------------------+------------+-------------------+-------------------------+
1row in set (0.00 sec)
11、从库设置同步主库
此处binlog文件与位置状态,是主库在步骤4锁表时show master status查看的位置状态。
CHANGE MASTER TO
MASTER_HOST='10.0.0.2',
MASTER_PORT=8306,
MASTER_USER='replication',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=26314;
12、开启从库同步并确认同步是否成功
使用start slave开启同步功能,使用show slave status\G查看同步是否成功
mysql>start slave;
QueryOK, 0 rows affected (0.00 sec)
mysql>show slave status\G #\G不按表格输出
***************************1. row ***************************
Slave_IO_State: Waiting formaster to send event
Master_Host: 10.0.0.2
Master_User: replication
Master_Port: 8306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 136270
Relay_Log_File:mysqld-relay-bin.000002
Relay_Log_Pos: 72697
Relay_Master_Log_File: mysql-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: 98758
Relay_Log_Space: 110366
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: 622 #查看主从同步延迟,延迟大则可能需要优化
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
1row in set (0.00 sec)
#sql线程与IO线程都是YES,slave配置成功。
13、主库设置同步从库
由于从库是全备导入,原先在主库上配置的复制帐户也同样导入,所以这里不用在从库上新授权复制用户。
从库上的binlog文件与位置状态,是从库在刚导入时show master status查看到的位置状态。
CHANGEMASTER TO
MASTER_HOST='172.16.0.2',
MASTER_PORT=3306,
MASTER_USER='replication',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000003',
MASTER_LOG_POS=2328055;
#修改相应信息,直接把这些配置在mysql中粘贴即可。
14、开启同步并确认同步是否成功
使用start slave开启同步功能,使用show slave status\G查看同步是否成功
mysql>start slave;
QueryOK, 0 rows affected (0.00 sec)
mysql>show slave status\G
***************************1. row ***************************
Slave_IO_State: Waiting formaster to send event
Master_Host: 172.16.0.2
Master_User: replication
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000007
Read_Master_Log_Pos: 107
Relay_Log_File:mysqld-relay-bin.000006
Relay_Log_Pos: 253
Relay_Master_Log_File: mysql-bin.000007
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: 107
Relay_Log_Space: 556
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: 2
1row in set (0.00 sec)
#IO线程与sql线程都是正常。
15、互为主从测试
在两台mysql各创建一个库,看两边是否都能进行同步。
分别在主库上执行 create database test01;
从库上执行create database test02;
看两台数据库上执行show databases;,看是否都有test01表和test02表。
我的经过测试,双主测试成功。
Mysql主主同步详细操作过程相关推荐
- 运维工程师必备之MySQL数据的主从复制、半同步复制和主主复制详解
一.MySQL复制概述 ⑴.MySQL数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费 ...
- MySQL数据库实现主主同步
前言 MySQL主主同步实际上是在主从同步的基础上将从数据库也提升成主数据库,让它们可以互相读写数据库,从数据库变成主数据库:主从相互授权连接,读取对方binlog日志并更新到本地数据库的过程,只要对 ...
- 最全 MySQL主从同步与主主同步
目录 同步原理 主从复制实际配置与取消主从 Slave_IO_Running:Connecting :处理 /var/lib/mysql/目录下的数据库文件 主从复制下主服务器 主从复制下从服务器 同 ...
- mysql双主不同步问题
1:碰到的问题 mysql双主数据库数据不同步 错误提示类似于:1032等,不仅1032我跳过后还有其他的各种问题 查询网上后,基本是两种解决方案1:直接跳过这一步错误,但是因为不同步太多了,跳过之后 ...
- MySQL主主数据同步
原文链接:http://blog.csdn.net/xyang81/article/details/52562571 MySQL主主同步和主从同步的原理一样,只是双方都是主从角色. 环境 操作系统版本 ...
- Java mysql同步复制_MySQL数据的主从复制、半同步复制和主主复制详解
一.MySQL复制概述 ⑴.mysql数据的复制的基本介绍 目前MySQL数据库已经占去数据库市场上很大的份额,其一是由于MySQL数据的开源性和高性能,当然还有重要的一条就是免费~不过不知道还能免费 ...
- mysql主主复制、主从复制、半同步的实现
实验前提:两台服务器 Master server:172.16.23.1 slave server:172.16.23.2 一.mysql主从服务器实现 简单介绍: MySQL支持单向.异步复制,复制 ...
- MYSQL 的 MASTER到MASTER的主主循环同步
刚刚抽空做了一下MYSQL 的主主同步. 把步骤写下来,至于会出现的什么问题,以后随时更新.这里我同步的数据库是TEST 1.环境描述. 主机:192.168.0.231(A) 主机:19 ...
- MySQL主主(双主)数据同步
1. 两台mysql都可以读写,互为主备,默认只是用一台(masterA)负责数据的写入,另一台(masterB)备用: 2. masterA是masterB的主库,masterB又是masterA的 ...
最新文章
- Linux那些事儿 之 戏说USB(27)设备的生命线(十)
- oracle修改备库状态,Oracle-CRSCTL命令显示备库状态不正确
- 获取枚举类型的 中文 描述 和值
- 传雅虎有意收购Hulu 竞争者达6家
- 通信 / DHCP 四次握手
- 64测试cpu稳定性_SuperPI-圆周率计算与CPU性能与稳定性测试
- android群英传神兵利器pdf,《Android群英传:神兵利器》勘误
- B8.软件工程与设计模式
- python 1秒启动一个下载服务器
- C#基础 数据类型 类型转换
- 使用 IIS 进行 ASP.NET 2.0 成员/角色管理(2):实现
- quartusII编译时出现Error (119013): Current license file does not support the EP4CE6F17C8 device
- python cpk计算器_CPK公式
- 十分钟入门 Kafka,通俗易懂地理解分布式消息系统!!
- 云计算淡定从容的大局观
- python实现图片rgb通道分离
- unity-光照实时GI(Realtime GI)
- Java--依照PDF模板进行数据的填充并输出
- Android APP跳转微信小程序和APP跳转支付宝小程序传参
- javascript事件侦听器是什么东西,用来干哈子
热门文章
- 斐波那契数列(二)--矩阵优化算法
- 搜索算法(三)--DFS/BFS求解宝岛探险问题(JAVA )
- Linux Kettle 闪退问题解决方案
- 后台长期运行进程的三种方式
- MongoDB服务无法注册
- android 自定义属性 双向绑定,如何解决:“在使用自定义视图实现双向数据绑定时,找不到属性’android:text’”的getter?...
- php 数组元素往后移动,php 二维数组 元素移动
- pytorch .item_60分钟入门PyTorch,官方教程教授第一个深度学习模型(附链接)
- Netty 5用户指南
- 从有赞裁员,看SCRM的挑战与机遇