尝试搭建MySQL master-slave主从复制的环境


本文摘自PHP中文网,作者巴扎黑,侵删。

环境为centos 7.2+mysql 5.7,网上教程很多,原理也不复杂(深知自己踩的坑还不够)

正常情况下,配置起来比较简单。另外,根据个人感受,MySQL的复制感觉要比SQL Server的复制要清爽很多(尽管功能上可能有一些差异)。

master服务器,首先是开启了二进制日志,同时设置server-id为一个具体的数值

1,创建复制用户

  GRANT REPLICATION SLAVE ON *.* to 'repl_test'@'120.77.147.***' identified by '123456';

2,记录master日志文件和日志位置

  show master status;

从库上

  1,设置主服务器

CHANGE MASTER TO
MASTER_HOST='120.77.159.43',
MASTER_USER='repl_test',
MASTER_PASSWORD='123456',
MASTER_PORT = 8000,
MASTER_LOG_FILE='mysql-bin.000047',
MASTER_LOG_POS=3112;

  2,启动从服务器上的复制

  start slave;

  show slave status 查看丛库的状态

  

数据同步测试

  主服务器上创建一个新的DB,随即同步到从服务器

   主服务器上创建一个表,写入数据,也同步到从服务器上(阿里云免费申请的两台ECS云服务器,主从延迟很小,感觉不超过1秒)

中间遇到一点小问题,在show slave status的时候,发现Slave_IO_Running是正常启动的,但是Slave_SQL_Running没有启动

Slave_IO_Running: Yes
Slave_SQL_Running: No

参考这里之后,解决

set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;客户端运行,用来跳过几个事件,只有当同步进程出现错误而停止的时候才可以执行。

stop slave ;
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
start slave

可能是老了,容易感慨,
之前一直对linux有一种畏惧感,或者说有一种固化思维:linux(这么难)我肯定不会--->那我干吗去动他--->必然肯定不会
自从看到某个之前也没有接触linux的朋友在接触没几天之后,常用的操作命令打的呼呼地,然后自己从0开始装虚拟机,基本问题都能帮助解决
自此深受鼓舞,不敢说入门,也大概知道linux是怎么回事了

再次感慨,人跟人真的比不了,说的好听一点是有部分人“能力强”,说不好听一点或者现实一点,那就是人家智商高,有啥办法,只能一步一步慢慢来,行动起来,不怕慢,就怕干,不要对那些在某些方面看起来很牛逼的人弄的东西,产生胆怯心理。

行动可以改变思维方式。

以上就是尝试搭建MySQL master-slave主从复制的环境的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

mysql的事务特性概念梳理总结

mysql的隔离级别是如何实现的

认识mysql insert into ... select的锁问题

mysql如何设置客户端为gbk

mysql数据类型教程示例详解

mysql如何改表的字符集

mysql如何避免全屏扫描?

mysql8.0.21.0社区版安装教程(图文详解)

mysql 多实例的安装

mysql between and 包含边界吗

更多相关阅读请进入《master-slave》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

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



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...