利用XtraBackup做mysql不停机重做主从复制

不停机做mysql主从同步,可以使用mysqldump,但是这个效率比较低,利用XtraBackup来实现这个,效率比较高!


一 xtrabackup安装:

yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL

rpm -ivh percona-xtrabackup-2.2.12-1.el6.x86_64.rpm


安装libenv:

wget ftp://rpmfind.net/linux/atrpms/el6-x86_64/atrpms/stable/libev-4.04-2.el6.x86_64.rpm


XtraBackup软件下载地址:

软件下载地址:https://www.percona.com/software/mysql-database/percona-xtrabackup



二 核对mysql的版本:

利用xtrabackup做全备和恢复的,Mysql的版本最好一致!

检查mysql版本:

 /webser/mysql55/bin/mysql -V

/webser/mysql55/bin/mysql  Ver 14.14 Distrib 5.5.21, for Linux (x86_64) using readline 5.1

三.在master服务器上在线备份数据库:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx  /tmp/


备份指定的数据库:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxxx --include='abc.*|salt.*'  /tmp/


注意多个库之间用“|”符号隔开!


PS:/tmp/为备份目录;

然后通过scp方式把master上


四.slave机器上操作;

1)关闭mysql服务;

然后清空mysql数据目录下文件,例如本机mysql的数据目录是:/webser/mysql55/var/ 


2)开始恢复数据

假设备份文件的路径在:/tmp/2016-04-29_16-00-54


恢复日志文件:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx --apply-log /tmp/2016-04-29_16-00-54/

恢复数据文件:

innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx --copy-back /tmp/2016-04-29_16-00-54/


3)修改数据目录权限:

chown -R mysql:mysql /webser/mysql55/var  

4)安全方式启动mysql,查看是否有异常;

/webser/mysql55/bin/mysqld_safe --defaults-file=/webser/mysql55/etc/my.cnf &

如果没有异常报错,就关闭mysql

 /webser/mysql55/bin/mysqladmin -uroot -p shutdown


5)查看binlog日志文件的位置值,做主从同步:

cat /tmp/2016-04-29_16-00-54/xtrabackup_binlog_info 
wwwmaster.000458    1022022953

6)在slave机器上做主从相关操作:

CHANGE MASTER TO
MASTER_HOST='192.168.3.xxx',
MASTER_USER='mysql_rep',
MASTER_PASSWORD='xxxx',
MASTER_PORT=33066,
MASTER_LOG_FILE='wwwmaster.000458',
MASTER_LOG_POS=1022022953;

启动主从同步:

start slave;



参考链接:

http://blog.chinaunix.net/uid-20682026-id-3319204.html

http://wsgzao.github.io/post/xtrabackup/


碰到的问题:

1)启动后报错:

[root@GuoletaoTest02 etc]# /etc/init.d/mysql55 start

Starting MySQL (Percona Server)...The server quit without u[FAILED]PID file (/data/mysql55/var/GuoletaoTest02.pid).

查看错误日志:

160429 16:47:12 [ERROR] Can't open the mysql.plugin table. Please run mysql_upgrade to create it.

解决办法:

 ./mysql_install_db --user=mysql --basedir=/webser/mysql55/ --datadir=/data/mysql55/var/

执行以上语句,问题即可解决!


优秀的个人博客,低调大师

微信关注我们

原文链接:https://blog.51cto.com/shineforever/1769084

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。

Sublime Text 一个代码编辑器

Sublime Text 一个代码编辑器

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。