设为首页 收藏本站
查看: 704|回复: 0

[经验分享] mysql主从备份、主从切换的例子

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2013-12-26 08:56:43 | 显示全部楼层 |阅读模式
实施环境:

两台Linux机器

SerA ip:10.0.0.232

SerB ip:10.0.0.234

Demo1:主从模式

Master:SerA    Slave:SerB

在SerA和SerB上分别建立用于同步的账号(也可以不新建账号,直接给其他账号分配访问权限)

[html] view plaincopy
use mysql;  

delete from user;  

grant all privileges on *.* to '$username'@'%' identified by '$password' with grant option;  

flush privileges;   
上面是为了安全,删除了一些用户(一般都要把默认的没有密码的用户删除)
StepA:

SerA配置为Master,在SerA上在my.cnf中添加:

[html] view plaincopy
replicate-do-db=$database  

server-id=1  
指定binlog(因为时通过binlog实现数据同步的)
配置完后重启数据库服务,用show master status可以看到Master信息。

StepB:

在SerB的my.cnf中指定

[html] view plaincopy
replicate-do-db=$database  

server-id=2  
指定binlog
配置完后重启数据库服务,用show slave status可以看到Slave信息。

(在MySQL5.1以后,my.cnf中已经去除了master-host等参数,应该在启动服务之后通过change master to ...命令来实现配置,也可以在启动的时候添加这些参数。下面是change master to ...示例)

bin/mysql -u$username -p$password -e "stop slave;change master tomaster_host='$mysqlMasterHost',master_port=3306,master_user=$username,master_password=$password;start slave;"

mysqlMasterHost是Master的IP,

master_port是Master的端口,

master_user和master_password是用于同步的账号和密码

还有master_log_file和master_log_pos参数指定同步数据的位置。

可以在mysql命令模式下执行change master,之后start slave

注意:由于设置了slave的配置信息,mysql在数据库目录下生成master.info

所以如有要修改相关slave的配置要先删除该文件。否则修改的配置不能生效。

这样就可以实现主从配置,此时在SerA指定数据库中加入数据,SerB中相应的数据库也会添加数据。

模拟Mysql主从切换:

假设SerA现在无法提供服务,只需在SerB上执行show master status记录master_log_file和master_log_pos,停止ServB的slave。

在SerA上执行change master 到SerB,并且指定master_log_file和master_log_pos,这样就可以恢复在SerA宕机期间存到SerB上的数据。

看一些配置和查看命令的结果:

18193313-74fc7307498b4118b3f98f3fcf6123d0.jpg

18192857-31df56be64be45afadcf3c73422eaa82.jpg

注意Slave_IO_Running和Slave_SQL_Running的状态都必须是YES

18193114-50130eee4b98424aa43bb51b0ae90e69.jpg


Demo2:双机互备

双机互备只是两台机器同时做Master和Slave,

即在SerA上使它的Master指向SerB,SerB的Maser指向SerA,

配置其实和Mysql主从模式是一样的。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-12299-1-1.html 上篇帖子: 如何开启MYSQL远程连接权限 下篇帖子: centos5.4下mysql主从复制 mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表