信息发布→ 登录 注册 退出

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

发布时间:2025-11-15

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

如果您正在搭建高可用的PHP网站架构,需要确保主数据库的数据变更能够实时同步到从数据库,以实现负载均衡或数据备份,则必须正确配置主从数据库的实时同步功能。以下是实现该目标的具体步骤:

一、配置主数据库(Master)

主数据库负责处理所有的写操作,并将数据变更记录到二进制日志中,供从数据库读取和应用。

1、编辑主数据库的配置文件 my.cnf 或 my.ini,通常位于 /etc/mysql/my.cnf 或 /usr/local/etc/my.cnf。

2、在 [mysqld] 段落下添加以下配置项:

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 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 提高数据安全性。

标签:# delete  # 要使  # 每隔  # 并将  # 可在  # 也可  # 均为  # 如果您  # 数据同步  # 重启  # 负载均衡  # 数据库  # database  # table  # position  # mysql  # var  # 线程  # int  # pdo  # format  # select  # if  # 架构  # sql  # php网站  # 配置文件  # ssl  # word  # php  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!