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 的三种格式 STATEMENTROWMIXED,详见 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)

此处需记录 FilePosition 两个值,下面从库的 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 主从复制的更多相关文章

  1. MySQL Percona server 5.5 安装审计插件

    近期,公司要求对MySQL 数据库上操作进行审计:通过了解MySQL 官方企业版(付费版)本中集成了audit_log审计插件,但是社区开源版本中并不包含该插件,也没提供下载.进一步了解 MariaD ...

  2. MySQL Study之--Percona Server版本号

    MySQL Study之--Percona Server版本号 1.简单介绍      Percona 为 MySQL 数据库server进行了改进.在功能和性能上较 MySQL 有着非常显著的提升. ...

  3. Linux 下 YUM 安装 Percona Server 5.6

    Percona Server 是 MySQL 的衍生版,专注于 Linux/BSD 下 MySQL 数据库服务器的改进, 在功能和性能上较 MySQL 有着显著的提升. Percona Server ...

  4. MySQL社区版升级到Percona Server

    出于磁盘空间的考虑,在调研以后把磁盘空间紧张的库的引擎改为tokudb,(在改为tokudb引擎之前是innodb引擎,已经压缩过,但空间还是紧张)关于tokudb的优势各位自行查阅相关资料.要启用t ...

  5. mysql 5.7/percona server/mariadb 10.2安装与服务器参数优化

    建议使用percona server linux generic版,从https://www.percona.com/downloads/Percona-Server-LATEST/下载,现在不在推荐 ...

  6. MySQL 系列(四)主从复制、备份恢复方案生产环境实战

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

  7. percona server 二进制安装下编译tpcc-mysql的坑

    出于习惯,percona server的部署都是通过二进制包自动化安装,结果遇到一个硕大无比的坑,编译TPCC-MySQL时出现警告 10:49:36 root@DB-Master:~/tpcc-my ...

  8. Percona Server 5.6.33-79.0 发布

    Percona Server 5.6.33-79.0 发布了,该版本基于 MySQL 5.6.33,包含了所有的 bug 修复,是Percona Server 5.6 系列中的正式版本.该版本主要是修 ...

  9. 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 ...

随机推荐

  1. PAT MOOC dataStructure 4-1

    数据结构练习 4-1 AVL 树 1. 题目: Input Specification: Each input file contains one test case. For each case, ...

  2. spring mvc+mybatis+sql server简单配置

    context.xml配置文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=&qu ...

  3. PHP数组函数: array_walk()与 array_map() 的区别

    详细的介绍如下: PHP数组函数: array_walk() PHP数组函数: array_map() 实际应用中的一点区别与总结: array_walk() 主要用于对某个数组的迭代,相当于 for ...

  4. CentOS6.3安装MongoDB2.2 及 安装PHP的MongoDB客户端

    下载源码:(放到 /usr/local/src 目录下) 到官网 http://www.mongodb.org/downloads 下载源码 https://fastdl.mongodb.org/li ...

  5. 进阶系列五【绝对干货】----Git教程

    一.介绍 1.1Git是什么? Git是目前世界上最先进的分布式版本控制系统.什么是版本控制系统?请自行百度. 1.2Git与SVN对比有什么特点? SVN是集中式版本控制系统.版本库是集中放在中央服 ...

  6. Android多线程通信机制

    掌握Android的多线程通信机制,我们首先应该掌握Android中进程与线程是什么. 1. 进程 在Android中,一个应用程序就是一个独立的进程(应用运行在一个独立的环境中,可以避免其他应用程序 ...

  7. Ubuntu远程vnc配置

    1. 安装xrdp 使用快捷键"Ctrl+Alt+T"打开一个终端窗口,输入"sudo apt-get install xrdp"-->回车-->输 ...

  8. 如何让页眉随章节的不同而变化(Word 2010)

    在一般情况下,我们将页眉设置完成后,所有章节的页眉都是一样的. 但在某些时候,我们需要让不同的章节拥有各自不同的页眉.那么该如何设置呢? 1. 我们以下图的文件为例,该文件一共包括4个实验,暂未设置页 ...

  9. HTML5本地缓存数据

    //HTML5本地缓存数据 function putObj(key, data) { if (!!window.localStorage) { var obj = { "key": ...

  10. C++ 基础知识复习(二)

    异常处理部分: 23. 在c++的异常处理中,除了提供异常的关键字语法支持以外,其标准库中支持异常处理而封装异常类也很好的为应用程序中异常处理判断使用提供直接的帮助.C++语言中针对异常处理提供了三个 ...