Laravel数据库读写分离怎样实现?有哪些方法?
Admin 2021-10-23 群英技术资讯 884 次浏览
本文主要给大家分享的是Laravel数据库读写分离的方法,Laravel数据库读写分离配置范例如下,下文还有代码分享,需要的朋友可以参考了解看看,接下来我们就直接看代码:
配置范例
'mysql' => [ 'driver' => 'mysql', 'write' => [ 'host' => '192.168.1.180', ], 'read' => [ ['host' => '192.168.1.182'], ['host' => '192.168.1.179'], ], ... ]
或
'mysql' => [ 'driver' => 'mysql', 'write' => [ 'host' => '192.168.1.180', ], 'read' => [ 'host' => [ '192.168.1.182', '192.168.1.179' ], ], ... ]
扩展配置范例
'mysql' => [ 'driver' => 'mysql', 'write' => [ 'host' => '192.168.1.180', 'username' => 'write', 'password' => 'write', ], 'read' => [ [ 'host' => '192.168.1.182', 'username' => 'read1', 'password' => 'read1', ], [ 'host' => '192.168.1.179', 'username' => 'read2', 'password' => 'read2', ], ], ... ]
或者
'mysql' => [ 'driver' => 'mysql', 'write' => [ 'host' => '192.168.1.180', 'username' => 'write', 'password' => 'write', ], 'read' => [ 'host' => [ '192.168.1.179', '192.168.1.182', ], 'username' => 'read', 'password' => 'read', ], ... ]
公司数据库架构为一主多从,从库访问地址为唯一地址,该处方便负载均衡及扩展从库。所以最终线上采用的配置
'mysql' => [ 'driver' => 'mysql', 'write' => [ 'host' => '192.168.1.180', 'username' => 'write', 'password' => 'write', ], 'read' => [ 'host' => '192.168.1.179' 'username' => 'read', 'password' => 'read', ], ... ]
代码分析
授人以鱼不如授人以渔,之所以配置如此灵活的原因,以及如何查找到这些配置方式。主要通过查找代码,分析代码;相关代码都在下面粘出,这里就不做解释了,代码能说明一切;
路径:vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectionFactory.php
代码:
class ConnectionFactory
{
...
/**
* Get the read configuration for a read / write connection.
*
* @param array $config
* @return array
*/
protected function getReadConfig(array $config)
{
$readConfig = $this->getReadWriteConfig($config, 'read');
if (isset($readConfig['host']) && is_array($readConfig['host'])) {
$readConfig['host'] = count($readConfig['host']) > 1
? $readConfig['host'][array_rand($readConfig['host'])]
: $readConfig['host'][0];
}
return $this->mergeReadWriteConfig($config, $readConfig);
}
...
/**
* Get a read / write level configuration.
*
* @param array $config
* @param string $type
* @return array
*/
protected function getReadWriteConfig(array $config, $type)
{
if (isset($config[$type][0])) {
return $config[$type][array_rand($config[$type])];
}
return $config[$type];
}
...
/**
* Merge a configuration for a read / write connection.
*
* @param array $config
* @param array $merge
* @return array
*/
protected function mergeReadWriteConfig(array $config, array $merge)
{
return Arr::except(array_merge($config, $merge), ['read', 'write']);
}
...
}
class Arr
{
...
/**
* Get all of the given array except for a specified array of items.
*
* @param array $array
* @param array|string $keys
* @return array
*/
public static function except($array, $keys)
{
static::forget($array, $keys);
return $array;
}
...
/**
* Remove one or many array items from a given array using "dot" notation.
*
* @param array $array
* @param array|string $keys
* @return void
*/
public static function forget(&$array, $keys)
{
$original = &$array;
$keys = (array) $keys;
if (count($keys) === 0) {
return;
}
foreach ($keys as $key) {
$parts = explode('.', $key);
while (count($parts) > 1) {
$part = array_shift($parts);
if (isset($array[$part]) && is_array($array[$part])) {
$array = &$array[$part];
} else {
$parts = [];
}
}
unset($array[array_shift($parts)]);
// clean up after each pass
$array = &$original;
}
}
...
}
以上就是Laravel数据库读写分离的设置方法啦,希望本文对大家有帮助,想要了解更多Laravel数据库读写分离的内容,可以继续浏览群英网络其他相关的文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
今天小编就为大家分享一篇laravel 解决groupBy时出现的错误 isn't in Group By问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
本文介绍一个php实现的购物车代码,功能实现完整,具有一定的参考价值。这里我们为你提供个简单的php购物车代码,从增加购物产品与发生购买了,在商城开发中,这个功能是
这篇文章主要介绍了Thinkphp 3.2框架使用Redis的方法,结合实例形式详细分析了thinkPHP3.2操作redis的常用方法、相关注意事项与问题解决方法,需要的朋友可以参考下
6.0中间件分为系统中间件和应用中间件,本文就详细的介绍一下Thinkphp6.0中间件的具体使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
php中__callStatic方法的使用:1、当要调用的静态方法不存在或者权限不足时候会自动调用。2、与__call()方法相同,接受方法名和数组作为参数。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008