YII2中配置MySQL读写分离

 

在实际开发中,为了服务更好的响应,通常会设置数据库的读写分离,主库负责写入更新等操作,从库负责读操作。

以下是YII2中配置MysqL读写分离,一主多从设置。设置好后,这些从库其中之一将被建立起连接并执行读操作,而主库将被用来执行写操作。 这样的读写分离将通过以下配置自动地完成。

return [
    'components' => [
        'db' => [
            // 主库配置
            'class' => 'yii\db\Connection','dsn' => 'MysqL:host=localhost;dbname=master_test','username' => 'username','password' => 'password','charset' => 'utf8', 从库的通用配置
            'slaveConfig' => [
                'username' => 'username','attributes' => [
                     使用一个更小的连接超时
                    // 这里每个从库都共同地指定了 10 秒的连接超时时间,
                    // 这意味着,如果一个从库在 10 秒内不能被连接上,它将被视为“挂掉的”。
                    // 你可以根据你的实际环境来调整该参数。
                    PDO::ATTR_TIMEOUT => 10,1)">
                ],1)">
            ],1)"> 从库的配置列表
            'slaves' => [
                ['dsn' => 'MysqL:host=localhost;dbname=slaves_test'],1)">
                ['dsn' => 'MysqL:host=localhost;dbname=slaves_test2'],1)">
        ],1)">
    ],1)">
];

 

相关文章

1、将Yii2.0advanced版中应用主体frontend或backend应用复制...
Yii2restfulAPI文档一、配置模块:1.Config/main.php:  2...
Yii在framework/i18n/data/%lang%.php文件中有很多翻译.这...
在Yii2中,官方的页面多语言解决方案有两个:方案1,使用Yii...
Yii2.0对数据库查询的一些简单的操作1234567891011121314151...
数据查询User::find()->all();此方法返回所有数据;User:...