php实现主从分离
实现 MySQL 主从分离的 PHP 方案
主从分离(读写分离)是数据库优化的常见手段,通过将读操作分发到从库,写操作定向到主库,减轻主库压力。以下是 PHP 实现主从分离的几种方法:

使用 PDO 或 MySQLi 手动分离
创建两个数据库连接对象,分别指向主库和从库,在代码中根据操作类型选择连接:

// 主库连接(写操作)
$master = new PDO('mysql:host=master_host;dbname=db', 'user', 'password');
// 从库连接(读操作)
$slave = new PDO('mysql:host=slave_host;dbname=db', 'user', 'password');
// 写操作示例
$master->query("INSERT INTO users (name) VALUES ('John')");
// 读操作示例
$result = $slave->query("SELECT * FROM users");
使用中间件代理
通过中间件(如 ProxySQL、MySQL Router)自动路由读写请求,PHP 只需连接代理地址:
// 统一连接代理地址
$db = new PDO('mysql:host=proxy_host;dbname=db', 'user', 'password');
// 代理自动路由读写
$db->query("INSERT INTO logs (message) VALUES ('test')"); // 写操作到主库
$db->query("SELECT * FROM logs"); // 读操作到从库
框架内置支持
部分 PHP 框架(如 Laravel、ThinkPHP)内置读写分离配置。以 Laravel 为例:
// config/database.php 配置
'mysql' => [
'write' => [
'host' => 'master_host',
],
'read' => [
'host' => 'slave_host',
],
'sticky' => true, // 同一请求内读写保持一致性
];
// 代码中无需显式区分
DB::table('users')->insert(['name' => 'Jane']); // 自动写主库
DB::table('users')->get(); // 自动读从库
注意事项
- 主从延迟:从库同步可能存在延迟,对实时性要求高的查询可强制读主库。
- 连接池管理:高并发场景建议使用连接池(如 Swoole 的数据库连接池)。
- 故障转移:需监控从库状态,异常时自动降级到主库。
性能优化建议
- 使用预处理语句减少 SQL 解析开销
- 对从库配置多个读副本实现负载均衡
- 对高频查询考虑引入缓存层(如 Redis)






