mysql读写分离实现_MySql读写分离实现

1. 主从复制:主数据库有写操作,从数据库自动同步。从数据库通过I/O线程去请求主数据库的binlog日志文件(二进制日志,包含SQL的增删改查等,用来做备份恢复等),并写到中继日志中,SQL线程会读取中继日志,并解析成具体操作同步数据到从数据库。

2. 读写分离:数据库层面:主数据库复制写,从数据库复制读。软件(代码)层面:通过读写分离中间间,比如MyCat、shardingsphere等实现。

具体实现

数据库层面

  1. 需要打开主库的二进制日志功能,通过配置文件修改。

(1)服务器ID命名

6eb2cbf1b27cfedfa01a9e82fbac9aaf.png

(2)日志功能开启

344af7863586ee5a7a6c2e8291c1af87.png

修改完后,重启sql服务,通过命令查看日志状态

b074e6d325803b719f550d40483ea9d5.png

(3)创建一个用户,并赋予replication slave权限。

8bf20fff8b07a1c505fb4f940b186957.png

  2. 从库设置

(1)服务命名

30b247ece4e0b4ee7b3f2f359c03e220.png

(2)配置相关参数,重启服务

0caf74a016b36f6be3e145ac6ae1df92.png

(3)连接主机,执行同步命令

8f17e990a0c2cf36aab1490989db25ce.png

代码程序层面

这里使用shardingsphere实现读写分离。

(1)相关jar引用

16401fe7a89b662285745520b039d433.png

(2)读写分离配置

1ab60510da380b8028ad3d9c6018037f.png

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要戳这里PHP进阶架构师>>>视频、面试文档免费获取

或者关注咱们下面的知乎专栏

PHP7进阶架构师​zhuanlan.zhihu.com
2d1752e95719a7089ac6ac93114135ba.png
作者: knbsyoo
来源:https://www.cnblogs.com/knsbyoo/p/11532415.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值