如何配置php网站数据实时同步_主从数据库实时同步配置方法

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

如何配置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、启动从库复制线程:

ViiTor实时翻译
ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

ViiTor实时翻译 116
查看详情 ViiTor实时翻译

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应用连接读写分离

在完成主从同步后,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=1innodb_flush_log_at_trx_commit=1 提高数据安全性。

以上就是如何配置php网站数据实时同步_主从数据库实时同步配置方法的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号