时间: 2020-09-4|tag:70次围观|0 条评论

 

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

以下是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',                'password' => 'password',                'attributes' => [                    // 使用一个更小的连接超时                    // 这里每个从库都共同地指定了 10 秒的连接超时时间,                    // 这意味着,如果一个从库在 10 秒内不能被连接上,它将被视为“挂掉的”。                    // 你可以根据你的实际环境来调整该参数。                    PDO::ATTR_TIMEOUT => 10,                ],            ],            // 从库的配置列表            'slaves' => [                ['dsn' => 'mysql:host=localhost;dbname=slaves_test'],                ['dsn' => 'mysql:host=localhost;dbname=slaves_test2'],            ],        ],    ],];

 

文章转载于:https://www.cnblogs.com/woods1815/p/12822209.html

原著是一个有趣的人,若有侵权,请通知删除

本博客所有文章如无特别注明均为原创。
复制或转载请以超链接形式注明转自起风了,原文地址《YII2中配置MySQL读写分离
   

还没有人抢沙发呢~