您的位置:首页 > 编程语言 > PHP开发

Yii2 主从 数据库

2016-07-05 15:57 477 查看
配置方法 参考资料:http://www.linuxidc.com/Linux/2015-07/120134.htm

读写分离(Read/Write Splitting)。

1.原理:让主数据库(master)处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库(slave)处理SELECT查询操作。

2.好处:备份数据库,分担数据库压力,承受更大的访问量。

是怎么分配主从数据库的:

Yii2\db\Command.php prepare 方法

if ($forRead || $forRead === null && $this->db->getSchema()->isReadQuery($sql))
{
$pdo = $this->db->getSlavePdo();
} else {
$pdo = $this->db->getMasterPdo();
}


Yii2\db\Schema.php isReadQuery 方法

public function isReadQuery($sql)
{
$pattern = '/^\s*(SELECT|SHOW|DESCRIBE)\b/i';
return preg_match($pattern, $sql) > 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: