必须正确配置主从数据库的实时同步功能,具体步骤:一、配置主库,启用二进制日志并创建复制用户;二、配置从库,设置唯一server-id并启动复制线程;三、验证同步状态,确保IO和SQL线程正常运行并测试数据同步;四、PHP应用实现读写分离,写操作连主库,读操作优先连从库;五、定期监控同步状态,处理异常并优化参数保障数据安全。

如果您正在搭建高可用的PHP网站架构,需要确保主数据库的数据变更能够实时同步到从数据库,以实现负载均衡或数据备份,则必须正确配置主从数据库的实时同步功能。以下是实现该目标的具体步骤:
一、配置主数据库(Master)
主数据库负责处理所有的写操作,并将数据变更记录到二进制日志中,供从数据库读取和应用。
1、编辑主数据库的配置文件 my.cnf 或 my.ini,通常位于 /etc/mysql/my.cnf 或 /usr/local/etc/my.cnf。
2、在 [mysqld] 段落下添加以下配置项:
立即学习“PHP免费学习笔记(深入)”;
server-id=1
log-bin=mysql-bin
binlog-format=mixed
expire_logs_days=7
3、重启MySQL服务使配置生效:systemctl restart mysql。
4、登录MySQL命令行,创建用于从库复制数据的专用账户:
CREATE USER ‘repl’@’%’ IDENTIFIED BY ‘your_password’;
GRANT REPLICATION SLAVE ON *.* TO ‘repl’@’%’;
FLUSH PRIVILEGES;
5、获取当前主库的二进制日志文件名和位置:
SHOW MASTER STATUS;
记录输出中的 File 和 Position 值,后续配置从库时需要使用。
二、配置从数据库(Slave)
从数据库通过I/O线程连接主库并拉取二进制日志,再由SQL线程回放日志内容,从而实现数据同步。
1、编辑从数据库的配置文件 my.cnf,在 [mysqld] 段落下添加:
server-id=2
relay-log=mysql-relay-bin
log-slave-updates=1
read-only=1
2、重启从库MySQL服务:systemctl restart mysql。
3、登录从库MySQL,执行 CHANGE MASTER TO 命令,连接主库:
CHANGE MASTER TO
MASTER_HOST=’主库IP地址’,
MASTER_USER=’repl’,
MASTER_PASSWORD=’your_password’,
MASTER_LOG_FILE=’之前记录的File值’,
MASTER_LOG_POS=之前记录的Position值;
4、启动从库复制线程:
START SLAVE;
三、验证主从同步状态
确认从库是否成功连接主库并持续同步数据,需检查复制线程的运行状态。
1、在从库执行命令:
SHOW SLAVE STATUSG
2、重点查看以下两个字段:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
3、若两者均为Yes,表示同步正常;若为No,需根据 Last_Error 字段排查问题。
4、可在主库执行插入测试数据的操作,例如:
CREATE DATABASE IF NOT EXISTS test_sync;
USE test_sync;
CREATE TABLE t1 (id INT PRIMARY KEY, name VARCHAR(50));
INSERT INTO t1 VALUES (1, ‘test’);
5、登录从库检查该表和数据是否存在,确认是否完成同步。
四、配置PHP应用连接读写分离
在完成主从同步后,PHP应用程序应合理分配读写请求,提升系统性能。
1、修改PHP项目的数据库配置文件,区分读写连接:
$db_write = new PDO(“mysql:host=主库IP;dbname=your_db”, $user, $pass);
$db_read = new PDO(“mysql:host=从库IP;dbname=your_db”, $user, $pass);
2、对 INSERT、UPDATE、DELETE 操作使用 $db_write 连接。
3、对 SELECT 查询操作优先使用 $db_read 连接。
4、对于强一致性要求的查询,仍应使用主库连接避免因同步延迟导致的数据不一致。
五、监控与维护同步稳定性
长期运行中需定期检查主从同步的健康状态,防止延迟或中断。
1、设置定时任务,每隔5分钟检查从库同步状态:
*/5 * * * * mysql -e “SHOW SLAVE STATUSG” | grep -E “(Slave_IO_Running|Slave_SQL_Running)” | grep -v “Yes” >> /var/log/slave_monitor.log
2、当出现同步错误时,常见处理方式包括:
STOP SLAVE;
SET GLOBAL sql_slave_skip_counter = 1;
START SLAVE;
3、也可通过跳过特定事务或重新初始化从库来恢复同步。
4、建议启用 sync_binlog=1 和 innodb_flush_log_at_trx_commit=1 提高数据安全性。
以上就是如何配置php网站数据实时同步_主从数据库实时同步配置方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1334909.html
微信扫一扫
支付宝扫一扫