本文摘自PHP中文网,作者coldplay.xixi,侵删。
mysql视频教程栏目介绍主从复制
相关免费学习推荐:mysql视频教程
数据库复制对于系统高可用、高性能的提升扮演者很重要的角色,本文就mysql主从复制涉及相关知识进行总结,如果您恰好在从事这方面工作,希望能够对您有所帮助。
1 主库配置
1.1 my.cnf配置:
在主库配置文件my.cnf中进行如下基本配置:
1 2 3 4 5 |
|
默认复制全部数据库,如果需要指定数据库,请参照第7节(复制过滤)。
1 2 3 |
|
1.2 添加复制账户:
复制账户添加以及权限设置:
1 2 |
|
2 备库配置
在备库配置文件my.cnf中进行如下基本配置:
1 2 3 4 5 6 7 8 9 10 |
|
同样可以过滤待同步的数据库,或者表,参考复制过滤一节。
3 数据库远程备份
数据库远程备份可以选择mysqldump(逻辑备份)进行热备,但对于数据量较大时会比较慢,Xtrabackup(物理备份)也可以对mysql数据库进行热备(这里使用innobackupex-1.5.1),Xtrabackup可以实现innoDB等数据库的在线备份,速度较快且不影响正常读写。这里对全库进行备份。
3.1 创建备份账户
在主服务器创建用户backup(使用最小权限),用于数据库备份。
1 2 |
|
3.2 数据库完全备份
完全备份和恢复准备两个步骤都是在主库服务器完成。
1 2 3 4 |
|
3.3 恢复准备
一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据文件仍处理不一致状态。“准备”的主要作用正是通过回滚未提交的事务及同步已经提交的事务至数据文件也使得数据文件处于一致性状态。
innobakupex命令的--apply-log选项可用于实现上述功能。如下面的命令:
1 2 3 4 5 6 |
|
在实现“准备”的过程中,innobackupex通常还可以使用--use-memory选项来指定其可以使用的内存的大小,默认通常为100M。如果有足够的内存可用,可以多划分一些内存给prepare的过程,以提高其完成速度。
3.4 数据拷贝
将主服务器上准备好的数据库拷贝到从服务器。(当然也可以打包后再拷贝)
1 |
|
3.5 数据恢复
在数据恢复之前首先关闭从服务器mysql服务,并从备份文件夹中的xtrabackup_binlog_info文件中获取当前正在使用的二进制日志文件,以及备份这一刻为止二进制日志事件的位置。如果datadir目录不为空,还需要清空datadir目录。
innobackupex命令的--copy-back选项用于执行恢复操作,其通过复制所有数据相关的文件至mysql服务器datadir目录中来执行恢复过程。innobackupex通过backup-my.cnf来获取datadir目录的相关信息(也可以通过--defaults-file指定my.cnf目录,还要确保datadir路径为空)
1 2 3 4 5 6 7 |
|
请确保如上信息的最后一行出现“innobackupex: completed OK!”。
当数据恢复至datadir目录以后,还需要确保所有数据文件的属主和属组均为正确的用户,如mysql,否则,在启动mysqld之前还需要事先修改数据文件的属主和属组。如:
1 |
|
4 主从连接
4.1 开启从数据库
1 |
|
如果开启mysql失败,可以通过查看错误日志寻找失败原因。
4.2 建立主从连接
从库通过复制账户连接到主库:(slave必须处于stop状态才能使以下连接生效)
1 2 |
|
注:如果这里在进行主从连接的时候一直连不上master,有一个可能的原因是my.cnf配置文件中绑定了本机,即bind-address = 127.0.0.1,我们要做的就是将其注释掉,否则外部机器是访问不了的。
开启slave:
1 |
|
查看slave状态,可以发现IO线程和SQL线程已处于开启状态,有非常多表征从库连接状态的变量(这些变量同样可以用于设置主从监控),在这里不一一做介绍。
1 2 3 4 5 |
|
4.3 常用监控命令
1 2 3 4 5 6 7 8 |
|
5 从库延迟较大
如果发现从库延迟较大,就需要找到延迟大的原因。参数 innodb_flush_log_at_trx_commit对mysql的写入效率影响较大,有三个取值:
1 2 3 |
|
取1时的IO耗费最大,虽然一致性和完整性方面效果最好,但是写入效率最低,而这也是导致从库延迟较大的原因(如果服务器配置较高或许会好些)。取0时mysql写入性能很好,但如果 mysqld 进程崩溃,通常会导致最后 1s 的日志丢失 。取2时的写入性能也很好,每次事务提交会写入日志文件,但并不会立即刷写到磁盘,日志文件会每秒刷写一次到磁盘。这时如果 mysqld 进程崩溃,由于日志已经写入到系统缓存,所以并不会丢失数据;在操作系统崩溃的情况下,通常会导致最后 1s 的日志丢失。
6 混合模式复制
正常情况下使用使用基于语句的复制,而对不安全的语句则切换到基于行的复制。主要有以下几种情况:
- 该语句调用了:
- UUID函数
- 用户自定义函数
- CURRENT_USER或USER函数
- LOAD_FILE函数
- 一个语句同时更新了两个或者两个以上含有AUTO_INCREMENT列的表
- 语句使用了服务器变量
- 存储引擎不允许使用基于语句的复制,例如,mysql cluster引擎
7 复制过滤
有时候我们不需要对数据库中所有的库进行复制,或者不想对指定库中的某些表进行复制操作,那么我们就需要对复制进行一定的过滤配置,以达到更合理的复制效果。
1. 基于master
1 2 |
|
2. 基于slave
针对数据库进行的过滤:
1 2 3 4 5 |
|
以上复制过滤方式乍一看没有问题,其实还是有需要注意的地方。因为这些过滤方式的效果与复制方式有关系。如果是基于语句的复制,binlog-do-db、binlog-ignore-db、replicate-do-db、replicate-ignore-db与跨库(如use库内和use外)有关系,这一点需要注意。
8 日志清理
暴力清理:(没有主从复制的情况下)
1 2 |
|
条件清理
如果存在主从复制关系,则应当使用purge的方式来清理bin日志,语法如下:
1 2 |
|
用户删除列于在指定的日志或日期之前的日志索引中的所有二进制日志,同时这些日志也会从日志索引文件的清单中删除。
1 2 3 4 |
|
定时清理
参数:expire_logs_days
说明:二进制日志自动删除/过期的天数。默认值为'0',即没有过期的
示例:expire_logs_days = 5,代表日志的有效时间为5天
什么时候会删除过期日志?
1 |
|
什么时候会触发log flush?
1 2 3 |
|
写在最后
本文只是结合自己的学习以及实践过程进行了相关总结,如有不妥之处望您批评指正。推荐大家学习《高可用MYSQL》、《高性能MYSQL》两本书,最重要的还是实践实践再实践,欢迎交流,共同进步。
想了解更多编程学习,敬请关注php培训栏目!
以上就是mysql的主从复制的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
mysql如何正确地利用aes_encrypt()与aes_decrypt()加解密
mysql中加减乘除与求余和求平均值以及查询不等于某数值的实例
更多相关阅读请进入《mysql》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。