PHP语言之Larval 主从读写分离配置
小标 2018-07-26 来源 : 阅读 1060 评论 0

摘要:本文主要向大家介绍了PHP语言之Larval 主从读写分离配置,通过具体的内容向大家展示,希望对大家学习php语言有所帮助。

本文主要向大家介绍了PHP语言之Larval 主从读写分离配置,通过具体的内容向大家展示,希望对大家学习php语言有所帮助。

在DB的连接工厂中找到以下代码 .../vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectionFactory.php /** * Get the read configuration for a read / write connection.

在DB的连接工厂中找到以下代码
.../vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectionFactory.php

/**

 * Get the read configuration for a read / write connection.

 *

 * @param  array  $config

 * @return array

 */  protected function getReadConfig(array $config)  {  

    $readConfig = $this->getReadWriteConfig($config, 'read');  

      

    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 array_except(array_merge($config, $merge), ['read', 'write']);

}

工厂类通过随机获取读DB配置来进行读取操作,由此可推出DB的配置应该如下

'mysql' => [  

    'write'    => [  

        'host' => '192.168.1.180',  

    ],  

    'read'     => [  

        ['host' => '192.168.1.182'],  

        ['host' => '192.168.1.179'],  

    ],  

    'driver'    => 'mysql',  

    'database'  => 'database',  

    'username'  => 'root',  

    'password'  => '',  

    'charset'   => 'utf8',  

    'collation' => 'utf8_unicode_ci',  

    'prefix'    => '',

]  

加强版,支持多主多从,支持独立用户名和密码,配置如下

'mysql' => [  

    'write'    => [  

        [

            'host' => '192.168.1.180',

            'username'  => '',

            'password'  => '',

        ],  

    ],  

    'read'     => [  

        [

            'host' => '192.168.1.182',

            'username'  => '',

            'password'  => '',

        ],  

        [

            'host' => '192.168.1.179',

            'username'  => '',

            'password'  => '',

        ],  

    ],  

    'driver'    => 'mysql',  

    'database'  => 'database',     

    'charset'   => 'utf8',  

    'collation' => 'utf8_unicode_ci',  

    'prefix'    => '',

]  

验证
开启MySQL的general-log,通过tail -f的方式监控log变化来确定配置是否生效

以上就介绍了PHP的相关知识,希望对PHP有兴趣的朋友有所帮助。了解更多内容,请关注职坐标编程语言PHP频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved