? 实验环境
- 系统环境
查看系统版本命令:cat /etc/redhat-release
data:image/s3,"s3://crabby-images/a35c9/a35c934fff8866015ef4f5374afa5157ebe2d759" alt="技术分享图片"
- 本实验是编译安装的Mysql ,坑太多,以后不建议采用编译安装的方式
data:image/s3,"s3://crabby-images/abb25/abb25f7059d12d91013c71ecbcc7d436b31a4bd9" alt="技术分享图片"
- 启动Mysql前首先执行以下命令,创建链接
ln -s /usr/local/mysql/bin/mysql /usr/bin
- Mysql初始的root密码存放在/root/.mysql_secret
找到密码后连接数据库,一定要修改root密码,然后重新启动Mysql
? 搭建Master-Master-slave
MySQL01:192.168.4.63 Master1
MySQL02:192.168.4.64 Master2
MySQL03:192.168.4.65 Slave1
Master1与Master2互为主备,Slave1是Master1,Master2的备机(多源复制)
-
首先实现Master1,Master2互为主备的功能
-
修改/etc/my.cnf,添加如下内容:
data:image/s3,"s3://crabby-images/2d686/2d6863da00268f1cf6412dc4900d9cb9d45a40b0" alt="技术分享图片"
data:image/s3,"s3://crabby-images/0d1f1/0d1f158bb4bcd7e1940325324840fbbf3b7d5fe4" alt="技术分享图片"
多源复制加入了一个叫做Channel的概念,只需要在每个语句最后使用For Channel来进行区分。由于复制的原理没有改变,在没有开启GTID的时候从库需要master-info-repository、relay-log-info-repository设置为table,否则会报错:
data:image/s3,"s3://crabby-images/ee8ba/ee8ba13106f09e9a5b84f1d2c837d8368b56bf57" alt="技术分享图片"
- 授权同步帐号
data:image/s3,"s3://crabby-images/92226/922269a8ec8066ca3c2d7c3504f6b1cf7ef7542b" alt="技术分享图片"
data:image/s3,"s3://crabby-images/bd4a2/bd4a25ed4f4ae018dbbb7538a6822d113434b4ec" alt="技术分享图片"
- 查出M1和M2的文件和Pos值
data:image/s3,"s3://crabby-images/280f4/280f4c9c84985efb98683f6c73cf51dd36626644" alt="技术分享图片"
data:image/s3,"s3://crabby-images/a1f0d/a1f0d2b2b0b0497d9967f150a22b5759dab5b644" alt="技术分享图片"
-
执行命令将M1,M2设置为互为主备
data:image/s3,"s3://crabby-images/b401a/b401a80c838dd2d08977aa923889631706671b5e" alt="技术分享图片"
data:image/s3,"s3://crabby-images/ccb4a/ccb4accf5a3ba88647a60f95212d3b7616732855" alt="技术分享图片"
- 查看slave状态
data:image/s3,"s3://crabby-images/e8a7f/e8a7fed2dfc047a6f813937556a2314e0b46fd52" alt="技术分享图片"
data:image/s3,"s3://crabby-images/602eb/602eb9529b922a57843e2cbe3f1ffffceaaa7b1e" alt="技术分享图片"
- 实现Slave1多源复制功能,即S1为M1,M2的共有备机
- 授权同步帐号
data:image/s3,"s3://crabby-images/8f0c7/8f0c7d3e3d3c94716c8d8602e7d558936f17031c" alt="技术分享图片"
data:image/s3,"s3://crabby-images/fec40/fec40289c10c17b9f5bb2f623d8f6a2f0f6ea135" alt="技术分享图片"
- 执行命令将S1作为M1,M2的备机
data:image/s3,"s3://crabby-images/8b072/8b0723efc4bfab5086e369a60b23d9cb1a1d4993" alt="技术分享图片"
- 查看Slave状态
data:image/s3,"s3://crabby-images/bcdef/bcdeffe82ba4db26126a3bc235c1c44b0aacce90" alt="技术分享图片"
data:image/s3,"s3://crabby-images/77b4c/77b4cf656f70f9fbbfdd2fcdd3029e386a5b126f" alt="技术分享图片"
注:至此已实现多主单备的配置,亦称多源复制。Msql5.7以上版本可使用GTID模式实现此功能
数据库的备份是DBA一项非常重要的工作,本案例中我们采用xtrabackup完成数据备份需求
- 在Slave1安装xtrabackup
data:image/s3,"s3://crabby-images/c8ac0/c8ac0f0209f94290fb54e4c2c4313efc63681477" alt="技术分享图片"
2.安装完成后,你就能在/etc/yum.repos.d 下看到一个percona-release.repo文件
data:image/s3,"s3://crabby-images/18b23/18b235aa3a563b687a2ee4cef4d32b13c68327c8" alt="技术分享图片"
3.测试Repository,确保Percona XtraBackup相关包已经在Repository中
data:image/s3,"s3://crabby-images/bd37d/bd37d12d02224d4773356a882696d8ec494e5851" alt="技术分享图片"
4.安装Percona XtraBackup包
data:image/s3,"s3://crabby-images/e4d8a/e4d8af7564778603038c773f472b9d66620b39c7" alt="技术分享图片"
5.查看安装结果
- 创建备份用户
备份数据库的用户需要具有相应权限,如果要使用一个最小权限的用户进行备份,则可基于如下命令创建此类用户:
data:image/s3,"s3://crabby-images/f412a/f412a04c1b011a23239e30da2026f4c0d5389c27" alt="技术分享图片"
data:image/s3,"s3://crabby-images/72d03/72d03e789974c379f2ff691ad80f89444761ef61" alt="技术分享图片"
- 执行完整备份:
innobackupex --user=root --password=cbichina_123 /extrabackup
执行完成后,会自动创建当前时间的文件夹
data:image/s3,"s3://crabby-images/09699/0969917e3070866d5317657e27b2a094ce026d1a" alt="技术分享图片"
利用 --apply-log的作用是通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态。
innobackupex --apply-log /extrabackup/2018-03-06_18-15-40/
-
执行增量备份
此命令执行结束后,innobackupex命令会在/backup目录中创建一个新的以时间命名的目录以存放所有的增量备份数据。另外,在执行过增量备份之后再一次进行增量备份时,其--incremental-basedir应该指向上一次的增量备份所在的目录。
innobackupex --incremental /extrabackup/ --user=root--password=cbichina_123
- 还原
请确保信息的最行一行出现“innobackupex: completed OK!”。
innobackupex --copy-back /extrabackup/2018-03-06_18-15-40/
Mysql5.7.12多源复制 xtrabackup
原文:http://blog.51cto.com/12906823/2085967