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

如果您正在搭建高可用的PHP网站架构,需要确保主数据库的数据变更能够实时同步到从数据库,以实现负载均衡或数据备份,则必须正确配置主从数据库的实时同步功能。以下是实现该目标的具体步骤:
主数据库负责处理所有的写操作,并将数据变更记录到二进制日志中,供从数据库读取和应用。
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 值,后续配置从库时需要使用。
从数据库通过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 STATUS\G
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应用程序应合理分配读写请求,提升系统性能。
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 STATUS\G" | 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网站数据实时同步_主从数据库实时同步配置方法的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号