1. 主从复制:主数据库有写操作,从数据库自动同步。从数据库通过I/O线程去请求主数据库的binlog日志文件(二进制日志,包含SQL的增删改查等,用来做备份恢复等),并写到中继日志中,SQL线程会读取中继日志,并解析成具体操作同步数据到从数据库。
2. 读写分离:数据库层面:主数据库复制写,从数据库复制读。软件(代码)层面:通过读写分离中间间,比如MyCat、shardingsphere等实现。
具体实现
数据库层面
1. 需要打开主库的二进制日志功能,通过配置文件修改。
(1)服务器ID命名
(2)日志功能开启
修改完后,重启sql服务,通过命令查看日志状态
(3)创建一个用户,并赋予replication slave权限。
2. 从库设置
(1)服务命名
(2)配置相关参数,重启服务
(3)连接主机,执行同步命令
代码程序层面
这里使用shardingsphere实现读写分离。
(1)相关jar引用
(2)读写分离配置
以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家
或者关注咱们下面的知乎专栏PHP7进阶架构师zhuanlan.zhihu.com
作者: knbsyoo
来源:https://www.cnblogs.com/knsbyoo/p/11532415.html