YII2中配置MySQL读写分离

Posted 幽篁晓筑

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了YII2中配置MySQL读写分离相关的知识,希望对你有一定的参考价值。

 

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

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

return [
    ‘components‘ => [
        ‘db‘ => [
            // 主库配置
            ‘class‘ => ‘yiidbConnection‘,
            ‘dsn‘ => ‘mysql:host=localhost;dbname=master_test‘,
            ‘username‘ => ‘username‘,
            ‘password‘ => ‘password‘,
            ‘charset‘ => ‘utf8‘,

            // 从库的通用配置
            ‘slaveConfig‘ => [
                ‘username‘ => ‘username‘,
                ‘password‘ => ‘password‘,
                ‘attributes‘ => [
                    // 使用一个更小的连接超时
                    // 这里每个从库都共同地指定了 10 秒的连接超时时间,
                    // 这意味着,如果一个从库在 10 秒内不能被连接上,它将被视为“挂掉的”。
                    // 你可以根据你的实际环境来调整该参数。
                    PDO::ATTR_TIMEOUT => 10,
                ],
            ],

            // 从库的配置列表
            ‘slaves‘ => [
                [‘dsn‘ => ‘mysql:host=localhost;dbname=slaves_test‘],
                [‘dsn‘ => ‘mysql:host=localhost;dbname=slaves_test2‘],
            ],
        ],
    ],
];

 

以上是关于YII2中配置MySQL读写分离的主要内容,如果未能解决你的问题,请参考以下文章

yii2的数据库读写分离配置

MySQL+MyCat分库分表 读写分离配置MySQL+MyCat分库分表 读写分离配置

mysql主从配置,读写分离

MySQL主从复制与读写分离配置及实操

Mysql主从配置,实现读写分离

Mysql主从配置,实现读写分离