在实际开发中,为了服务更好的响应,通常会设置数据库的读写分离,主库负责写入更新等操作,从库负责读操作。
以下是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)"> ];
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。