ThinkPHP内置了分布式数据库的支持,包括主从式数据库的读写分离,但是分布式数据库必须是相同的数据库类型。
配置DB_DEPLOY_TYPE
为1 可以采用分布式数据库支持。如果采用分布式数据库,定义数据库配置信息的方式如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<?php
return
array
(
'DB_DEPLOY_TYPE'
=> 1,
// 设置分布式数据库支持
'DB_RW_SEPARATE'
=> true,
// 分布式数据库的读写是否分离
'DB_TYPE'
=>
'mysql'
,
// 数据库类型
'DB_HOST'
=>
'192.168.33.110,192.168.33.111,192.168.33.112'
,
// 数据库服务器地址
'DB_NAME'
=>
'kp_account'
,
// 数据库名称
'DB_USER'
=>
'root,root,root'
,
// 数据库用户名
'DB_PWD'
=>
''
,
// 数据库密码
'DB_PORT'
=>
'3306,3306,3306'
,
// 数据库端口
'DB_PREFIX'
=>
'acc_'
,
// 数据表前缀
'DB_MASTER_NUM'
=> 2
);
|
在读写分离的情况下,默认第一个数据库配置是主服务器的配置信息,负责写入数据,如果设置了DB_MASTER_NUM
参数,则可以支持多个主服务器写入。其它的都是从数据库的配置信息,负责读取数据,数量不限制。每次连接从服务器并且进行读取操作的时候,系统会随机进行在从服务器中选择。
还可以设置DB_SLAVE_NO
指定某个服务器进行读操作。
小结:
TP框架内置的分布式数据库处理,在默认的情况下,如果没有设置DB_MASTER_NUM
参数,就会是默认第一个数据库作为写操作,其他是读数据库;如果设置了DB_MASTER_NUM
参数,例如上面的数据库配置信息里面把DB_MASTER_NUM
参数设置为2,在没有并发的情况下,写操作一直会是192.168.33.111这个数据库;有不对的地方还望多多指教!