MySQL(Percona Server) 5.6 主从复制
MySQL(Percona Server) 5.6.15
主库:192.168.2.21
从库:192.168.2.22
例如我们同步的数据库为:test。 如果需要同步多个数据库下面会有说明。
MySQL 主从复制原理
1. master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events,可以通过show binlog events进行查看);
2. slave将master的binary log events拷贝到它的中继日志(relay log);
3. slave重做中继日志中的事件,将改变反映它自己的数据。
主库(192.168.2.21):
主库开放 3306 端口
# /sbin/iptables -I INPUT -s 192.168.2.0/24 -p tcp --dport 3306 -j ACCEPT # service iptables save
查看开放的端口:
# service iptables status
或
# iptables -L -n
授权同步账户
mysql> GRANT REPLICATION SLAVE ON *.* TO rep@'192.168.2.22' IDENTIFIED BY '123';
mysql> flush privileges;
授权格式为:GRANT REPLICATION SLAVE ON *.* TO username@'ipaddress' IDENTIFIED BY 'password'
。
现在可以在 192.168.2.22 从库上测试是否可以访问:
# /usr/local/mysql/bin/mysql -h192.168.2.21 -urep -p123
配置主库 my.cnf
# vi /etc/my.cnf [mysqld]
log-bin=mysql-bin #开启 MYSQL 二进制日志
server-id=1 #主库服务器 ID,注意服务器 ID 不能重复
binlog-do-db=test #需要做主从备份的数据库名,如果复制多个数据库,重复设置这个选项即可
expire-logs-days=7 #只保留 7 天的二进制日志,以防磁盘被日志占满
binlog_format=MIXED #设置 binlog 的格式为 MIXED
binlog 的三种格式 STATEMENT
、ROW
、MIXED
,详见 MySQL Binlog ROW 和 STATEMENT 选择。
可以通过 show variables like 'binlog_format';
查看。
保存,重启 MySQL:
# service mysql restart
拷贝主库需要同步的数据到从库
进入 mysql 终端 /usr/local/mysql/bin/mysql -uroot -p
:
设置主库成只读状态
mysql> use test;
mysql> FLUSH TABLES WITH READ LOCK;
重置 binlog 日志
mysql> RESET MASTER;
查看运行状态
mysql> SHOW MASTER STATUS\G;
******************* 1. row *******************
File: mysql-bin.000001
Position: 120
Binlog_Do_DB: test
Binlog_Ignore_DB:
Executed_Gtid_Set:
1 row in set (0.00 sec)
此处需记录 File
和 Position
两个值,下面从库的 CHANGE MASTER TO
命令中需要用到这两个值。
接下来切换到从库服务器
,导出主库中需要同步的数据,并导入到从库:
# /usr/local/mysql/bin/mysqldump -h192.168.2.21 -urep -p test > dumptest.db
# /usr/local/mysql/bin/mysql -uroot -p test < dumptest.db
再回到主库服务器
, 解锁主库数据库只读状态
mysql> UNLOCK TABLES;
从库(192.168.2.22):
配置从库 my.cnf
# vi /etc/my.cnf [mysqld]
server-id=2 #从库服务器 ID,注意服务器 ID 不能重复
replicate-do-db=test #需要做复制的数据库名,如果复制多个数据库,重复设置这个选项即可
slave-skip-errors=1032,1062,126,1114,1146,1048,1396 #自动跳过的错误代码,以防复制出错被中断
如果数据库中有不需要同步的表可以添加 replicate-ignore-table=table_name,...
配置项,自动跳过这些表。
保存,重启 MySQL:
# service mysql restart
指定主库
进入 MySQL 终端:
mysql> CHANGE MASTER TO
MASTER_HOST='192.168.2.21',
MASTER_USER='rep',
MASTER_PASSWORD='123',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=120;
启动从库连接
mysql> start slave;
查看从库状态
mysql> SHOW SLAVE STATUS\G;
......
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
......
两个 Yes 成功。
测试
现在可以在主库中插入/更新数据,添加表等操作,看从库是否可以同步相应的数据。
问题
在最后使用 SHOW SLAVE STATUS\G;
查看 slave 运行状态时,有一个错误:
Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.
server uuid 是从 MySQL 5.6 开始添加进来的, 由于我偷了个懒,从库是直接在 VirtualBox 中 Clone 的主库,所以 /var/lib/mysql/auto.cnf
文件中的 server-uuid
的值是一样的。 随便改一个值,但是值的格式不能变,不与群组中的其他 server-uuid 重复即可。
改完之后,重启 mysql:
# service mysql restart
再次使用 SHOW SLAVE STATUS\G;
查看状态正常。
附两个小命令:
mysql> SHOW SLAVE HOSTS; #需在 master 中执行,查看 slave 列表,包括相应的 server-uuid 值
mysql> show variables like 'server_uuid'; #查看本机的 server-uuid 值
Good Luck!
MySQL(Percona Server) 5.6 主从复制的更多相关文章
- MySQL Percona server 5.5 安装审计插件
近期,公司要求对MySQL 数据库上操作进行审计:通过了解MySQL 官方企业版(付费版)本中集成了audit_log审计插件,但是社区开源版本中并不包含该插件,也没提供下载.进一步了解 MariaD ...
- MySQL Study之--Percona Server版本号
MySQL Study之--Percona Server版本号 1.简单介绍 Percona 为 MySQL 数据库server进行了改进.在功能和性能上较 MySQL 有着非常显著的提升. ...
- Linux 下 YUM 安装 Percona Server 5.6
Percona Server 是 MySQL 的衍生版,专注于 Linux/BSD 下 MySQL 数据库服务器的改进, 在功能和性能上较 MySQL 有着显著的提升. Percona Server ...
- MySQL社区版升级到Percona Server
出于磁盘空间的考虑,在调研以后把磁盘空间紧张的库的引擎改为tokudb,(在改为tokudb引擎之前是innodb引擎,已经压缩过,但空间还是紧张)关于tokudb的优势各位自行查阅相关资料.要启用t ...
- mysql 5.7/percona server/mariadb 10.2安装与服务器参数优化
建议使用percona server linux generic版,从https://www.percona.com/downloads/Percona-Server-LATEST/下载,现在不在推荐 ...
- MySQL 系列(四)主从复制、备份恢复方案生产环境实战
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- percona server 二进制安装下编译tpcc-mysql的坑
出于习惯,percona server的部署都是通过二进制包自动化安装,结果遇到一个硕大无比的坑,编译TPCC-MySQL时出现警告 10:49:36 root@DB-Master:~/tpcc-my ...
- Percona Server 5.6.33-79.0 发布
Percona Server 5.6.33-79.0 发布了,该版本基于 MySQL 5.6.33,包含了所有的 bug 修复,是Percona Server 5.6 系列中的正式版本.该版本主要是修 ...
- Percona Server 5.6.13-61.0 首个 GA 版本发布
Percona Server 5.6 的首个 GA 版本发布了,版本号是 5.6.13-61.0 ,该版本基于 MySQL 5.6.13 改进内容包括: New Features: Percona S ...
随机推荐
- STL学习之运算符(<<)重载问题和仿函数的实现
/* 运算符<<的重载一直报错, 友原函数中可以访问到类的私有成员*/#include<iostream>using namespace std; class MyIn ...
- centos安装PHP服务器步骤
方法一.使用网友开发的EZHTTP程序包一键安装. 可以参考地址http://www.centos.bz/2013/08/ezhttp-tutorial/ http://www.cnblogs.com ...
- jdbctemplate中的批量更新使用,BigDecimal与造型的联系和区别
//jdbctemplate批量新增的使用MENU_ID_LIST是前端页面传递到后端控制层,再由控制层传到实现层的List //JdbcTemplate是spring jdbctemplate通过注 ...
- jQuery UI 实现图片循环显示,常用于网站首页banner广告切换
http://www.runoob.com/try/try.php?filename=jqueryui-example-position-cycler <!doctype html>< ...
- 一个简单的servlet的demo
javaweb 的应用我们需要参考javaee api 查找servlet接口 javax.servletInterface Servlet All Known Subinterfaces: Ht ...
- cf596d
题意:有一排等高的树木,高度都为h.给出每棵树在数轴上的坐标,每次有可能是最左边或者最右边的立着的树倒下,概率都是0.5.最终所有树都倒下.每棵树在倒下的时候有p的概率向左倒,1-p的概率向右倒.如果 ...
- XCode4.5.6,iOS6.1下测试 判断当前设备,及其联网状态等; 关于设备插上后XCode检测不出的情况的说明
目录[-] 一.判断设备 二.判断网络连接状态 三.设备不显示的解决办法 一.判断设备 01 //设备名称 02 return [UIDevice currentDevice].name; 03 ...
- 配置https
引子: 最近在一篇文章中了解到EFF(电子前哨基金会)为了推广https协议,成立了一个let'sencrypt项目,可以发放免费的证书,此证书可以被大多数主流浏览器所信任,这个邪恶的念头一爆发,就让 ...
- 【Java EE 学习 45】【Hibernate学习第二天】【对象的三种状态】【一对多关系的操作】
一.对象的三种状态. 1.对象有三种状态:持久化状态.临时状态.脱管状态(游离状态) 2.Session的特定方法能使得一个对象从一个状态转换到另外一个状态. 3.三种状态的说明 (1)临时状态:临时 ...
- new 等于 malloc加构造函数
1.new 是c++中的操作符,malloc是c 中的一个函数 2.new 不止是分配内存,而且会调用类的构造函数,同理delete会调用类的析构函数,而malloc则只分配内存,不会进行初始化类成员 ...