经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
laravel学习:主从读写分离配置的实现 - it-world
来源:cnblogs  作者:it-world  时间:2019/11/6 8:52:42  对本文有异议

本篇文章给大家带来的内容是关于laravel学习:主从读写分离配置的实现,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

/**

 * 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的配置应该如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

'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'    => '',

]

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

'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变化来确定配置是否生效

原文链接:http://www.cnblogs.com/it-3327/p/11799611.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号