이 글은 ThinkPHP 프레임워크의 분산 데이터베이스 연결 방법을 주로 소개하며, 분산 데이터베이스에 대한 thinkPHP 프레임워크의 연결 방법, 운영 기술 및 관련 주의 사항을 예제 형식으로 자세히 분석합니다.
이 글은 다음과 같습니다. ThinkPHP 프레임워크 분산 데이터베이스 연결 방법의 예를 분석합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
Thinkphp는 중국에서 인기 있는 프레임워크이고 이를 사용하는 사람이 많을 것이라고 생각합니다. 이 기사에서는 Thinkphp의 중요한 부분인 분산 데이터베이스 연결을 분석합니다.
물론 모델을 사용하여 데이터베이스를 추가, 삭제, 수정 및 쿼리하는 방법을 설명하기 위해 여기 있는 것은 아닙니다. 우리는 thinkphp의 데이터베이스 작동을 더 잘 이해하는 데 도움이 될 수 있는 기본 연결 코드를 분석하고 있습니다. 향후 사용을 용이하게 하기 위해.
1. 단일 데이터베이스 연결
사용하면 단일 데이터베이스의 연결 구성이 매우 간단합니다. 구성 파일에서 일부 정보만 구성하면 됩니다.
'DB_TYPE' => 'mysql', 'DB_HOST' => '192.168.5.102', 'DB_NAME' => 'databasename', 'DB_USER' => 'user', 'DB_PWD' => 'password', 'DB_PORT' => '3306', 'DB_PREFIX' => 'onmpw_',
설정이 완료된 후 사용하시면 됩니다. 기본값은 단일 데이터베이스 연결입니다.
2. 분산 데이터베이스 연결
단일 데이터베이스 연결은 매우 간단합니다. 분산 데이터베이스 연결을 집중적으로 분석해 보겠습니다.
'DB_TYPE' => 'mysql', 'DB_HOST' => '192.168.5.191,192.168.5.88,192.168.5.103', 'DB_NAME' => 'test,test,test', 'DB_USER' => 'masteruser,slaveuser,slaveuser', 'DB_PWD' => 'masterpass,slavepass,slavepass', 'DB_PORT' => '3306', 'DB_PREFIX' => '', 'DB_DEPLOY_TYPE' => 1, // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器) 'DB_RW_SEPARATE' => true, // 数据库读写是否分离 主从式有效 'DB_MASTER_NUM' => 1, // 读写分离后 主服务器数量 'DB_SLAVE_NO' => '', // 指定从服务器序号
위 구성에 따라 분산 데이터베이스에 연결합니다.
다음 옵션을 살펴보겠습니다
'DB_HOST'
분산 데이터베이스의 경우 서버가 여러 개인 경우 각 주소 사이를 쉼표로 구분하여 여러 서버 주소를 입력해야 합니다. 마스터-슬레이브 배포인 경우 이전 주소는 마스터 데이터베이스의 주소여야 합니다.
다음 사용자 이름, 비밀번호, 청취 포트 등은 물론 가능한 한 많이 적어 두세요. 각 데이터베이스의 사용자 이름과 비밀번호가 동일한 경우 하나만 작성할 수 있습니다.
이러한 옵션을 구문 분석하는 코드는 다음과 같습니다
$_config['username'] = explode(',',$this->config['username']); $_config['password'] = explode(',',$this->config['password']); $_config['hostname'] = explode(',',$this->config['hostname']); $_config['hostport'] = explode(',',$this->config['hostport']); $_config['database'] = explode(',',$this->config['database']); $_config['dsn'] = explode(',',$this->config['dsn']); $_config['charset'] = explode(',',$this->config['charset']);
'DB_DEPLOY_TYPE'=>1
1은 분산형, 0은 중앙 집중형(즉, 단일 서버)을 의미합니다.
이 옵션의 구현은 ThinkDbDirver
protected function initConnect($master=true) { if(!empty($this->config['deploy'])) // 采用分布式数据库 $this->_linkID = $this->multiConnect($master); else // 默认单数据库 if ( !$this->_linkID ) $this->_linkID = $this->connect(); }
$this->config['deploy']
가 'DB_DEPLOY_TYPE'
구성 옵션을 나타냅니다. 구성은 사용하기 전에 구문 분석되었으며 구성 항목은 $this->config
배열에 있습니다. 구성 파일을 구문 분석하는 방법은 여기에서 소개하지 않습니다. 관심 있는 분은 ThinkDb 클래스를 참조하세요. $this->config['deploy']
表示的就是'DB_DEPLOY_TYPE'
这个配置选项,上面的配置在使用之前都已经经过解析了,配置项都在$this->config
数组中。至于是如何解析配置文件的,这里我们不做介绍,感兴趣的可以参考ThinkDb类。
$this->multiConnect()
函数就是用来进行分布式连接的,如果'DB_DEPLOY_TYPE'
选项设置为1,该函数就会执行。否则直接执行$this->connect()
函数。
'DB_RW_SEPARATE'=>true
true 表示读写分离;false表示读写不分离。
这里需要注意的是,读写分离是以主从式数据库系统为前提的。该选项设置为true的时候主数据库写,从数据库读。
if($this->config['rw_separate']){ // 主从式采用读写分离 if($master) // 主服务器写入 $r = $m; else{ if(is_numeric($this->config['slave_no'])) {// 指定服务器读 $r = $this->config['slave_no']; }else{ // 读操作连接从服务器 $r = floor(mt_rand($this->config['master_num'],count($_config['hostname'])-1)); // 每次随机连接的数据库 } } }else{ // 读写操作不区分服务器 $r = floor(mt_rand(0,count($_config['hostname'])-1)); // 每次随机连接的数据库 }
$this->config['rw_separate']
为true的时候采用读写分离,为false的时候读写不分离。读写分离为什么必须是主从式的呢?因为从服务器不能写只能读,如果向从服务器写入数据的话,数据是没法同步的。这样就会造成数据不一致的情况。所以说,如果我们的系统是主从式的话,我们必须采用读写分离。也就是说DB_RW_SEPARATE选项必须配置为true。
'DB_MASTER_NUM'=>1
该选项后面的数字表示读写分离后,主服务器的数量。因此该选项也是用于主从式数据库系统。
下面的代码是选择主服务器。
$m = floor(mt_rand(0,$this->config['master_num']-1));
主从式数据库读取的时候选择从服务器读的核心代码
复制代码 代码如下:
$r = floor(mt_rand($this->config['master_num'],count($_config['hostname'])-1)); // 每次随机连接的数据库
其中$this->config['master_num']
$this->multiConnect()
함수는 분산 연결에 사용됩니다. 'DB_DEPLOY_TYPE'
옵션을 1로 설정하면 이 함수가 실행됩니다. 그렇지 않으면 $this->connect()
함수를 직접 실행하세요. 'DB_RW_SEPARATE'=>true
true는 읽기와 쓰기가 분리되어 있음을 의미하고 false는 읽기와 쓰기가 분리되지 않음을 의미합니다. 여기서 읽기와 쓰기의 분리는 마스터-슬레이브 데이터베이스 시스템을 기반으로 한다는 점에 유의해야 합니다. 이 옵션을 true로 설정하면 마스터 데이터베이스는 쓰고 슬레이브 데이터베이스는 읽습니다.if(is_numeric($this->config['slave_no'])) {// 指定服务器读 $r = $this->config['slave_no']; }else{ // 读操作连接从服务器 $r = floor(mt_rand($this->config['master_num'],count($_config['hostname'])-1)); // 每次随机连接的数据库 }
$this->config['rw_separate']
true인 경우 읽기와 쓰기가 분리됩니다. false인 경우 읽기와 쓰기가 분리되지 않습니다. 읽기와 쓰기의 분리가 왜 주인-슬레이브여야 합니까? 슬레이브 서버는 쓰기가 불가능하고 읽기만 가능하기 때문에 슬레이브 서버에 데이터를 쓰면 데이터를 동기화할 수 없습니다. 이로 인해 데이터 불일치가 발생합니다. 그러므로 우리 시스템이 마스터-슬레이브라면 읽기-쓰기 분리를 사용해야 합니다. 즉, DB_RW_SEPARATE 옵션을 true로 설정해야 한다. 🎜🎜'DB_MASTER_NUM'=>1🎜🎜🎜🎜 이 옵션 뒤의 숫자는 읽기 및 쓰기 분리 후의 마스터 서버 수를 나타냅니다. 따라서 이 옵션은 마스터-슬레이브 데이터베이스 시스템에서도 사용됩니다. 🎜🎜아래 코드는 메인 서버를 선택합니다. 🎜if($m != $r ){ $db_master = array( 'username' => isset($_config['username'][$m])?$_config['username'][$m]:$_config['username'][0], 'password' => isset($_config['password'][$m])?$_config['password'][$m]:$_config['password'][0], 'hostname' => isset($_config['hostname'][$m])?$_config['hostname'][$m]:$_config['hostname'][0], 'hostport' => isset($_config['hostport'][$m])?$_config['hostport'][$m]:$_config['hostport'][0], 'database' => isset($_config['database'][$m])?$_config['database'][$m]:$_config['database'][0], 'dsn' => isset($_config['dsn'][$m])?$_config['dsn'][$m]:$_config['dsn'][0], 'charset' => isset($_config['charset'][$m])?$_config['charset'][$m]:$_config['charset'][0], ); } $db_config = array( 'username' => isset($_config['username'][$r])?$_config['username'][$r]:$_config['username'][0], 'password' => isset($_config['password'][$r])?$_config['password'][$r]:$_config['password'][0], 'hostname' => isset($_config['hostname'][$r])?$_config['hostname'][$r]:$_config['hostname'][0], 'hostport' => isset($_config['hostport'][$r])?$_config['hostport'][$r]:$_config['hostport'][0], 'database' => isset($_config['database'][$r])?$_config['database'][$r]:$_config['database'][0], 'dsn' => isset($_config['dsn'][$r])?$_config['dsn'][$r]:$_config['dsn'][0], 'charset' => isset($_config['charset'][$r])?$_config['charset'][$r]:$_config['charset'][0], ); return $this->connect($db_config,$r,$r == $m ? false : $db_master);🎜마스터-슬레이브 데이터베이스에서 읽을 때 서버에서 읽은 핵심 코드를 선택하세요
코드 복사🎜 코드는 다음과 같습니다. 🎜 现在我们来看 $r == $m ? false : $db_master ,如果数据库读写不分离的情况下,读写是一台服务器的话 传给connect函数的值为false。或者是如果是主从分离的写的情况下传给connect的值也为false。通过上面代码我们看到,如果$r和$m不相等的情况下,会设置$db_master。其实也就是相当于一台备用的,如果选择的$r服务器出现故障不能连接,将会去连接$db_master。 connect()函数的第三个参数其实是表示当$db_config这台服务器连接故障时是否选择备用的连接。false表示不重连,其它值即表示重新连接。 其核心代码如下 这种方式,对于主从式来说,$r和$m肯定不会相同。因此如果说在读取数据的时候,选择的那台从服务器出现故障的话,那主服务器即是备用的,最后会去主服务器读取。能保证数据读取的时效性。 但是,总感觉现在还不太完善。如果说有多台从服务器,在读取的时候选择的那台从服务器和主服务器都出现了故障,那数据岂不是就读取失败了。这时候如果能再次读取其它的从服务器的话那应该是更有保障。当然了,目前的thinkphp的功能已经相当完善,足够我们使用了。但是还是希望thinkphp以后越来越完善。 相关推荐:try{
if(empty($config['dsn'])) {
$config['dsn'] = $this->parseDsn($config);
}
if(version_compare(PHP_VERSION,'5.3.6','<=')){
// 禁用模拟预处理语句
$this->options[PDO::ATTR_EMULATE_PREPARES] = false;
}
$this->linkID[$linkNum] = new PDO( $config['dsn'], $config['username'], $config['password'],$this->options);
}catch (\PDOException $e) {
if($autoConnection){ //$autoConnection不为false,而是默认的主服务器
trace($e->getMessage(),'','ERR');
return $this->connect($autoConnection,$linkNum); //出现异常,使用递归函数重新连接
}elseif($config['debug']){
E($e->getMessage());
}
}
🎜여기서 $this->config['master_num']
는 마스터 서버 수를 나타냅니다. 🎜🎜🎜🎜'DB_SLAVE_NO'=> ''🎜🎜🎜🎜데이터를 읽는 데 사용되는 슬레이브 서버의 일련 번호를 지정합니다. 설정하지 않으면 마스터 서버 수를 기준으로 슬레이브 서버 수를 계산한 후 무작위로 하나를 선택하여 읽어옵니다. 🎜rrreee🎜위는 각 옵션의 기능 구현 코드에 대한 간단한 설명입니다. 🎜🎜연결 부분을 살펴보겠습니다🎜rrreee🎜이렇게 보면 위의 각 구성 옵션에 대한 코드를 소개할 때 $r과 $m의 역할을 다들 이해하셔야 할 것 같습니다. 🎜try{
if(empty($config['dsn'])) {
$config['dsn'] = $this->parseDsn($config);
}
if(version_compare(PHP_VERSION,'5.3.6','<=')){
// 禁用模拟预处理语句
$this->options[PDO::ATTR_EMULATE_PREPARES] = false;
}
$this->linkID[$linkNum] = new PDO( $config['dsn'], $config['username'], $config['password'],$this->options);
}catch (\PDOException $e) {
if($autoConnection){ //$autoConnection不为false,而是默认的主服务器
trace($e->getMessage(),'','ERR');
return $this->connect($autoConnection,$linkNum); //出现异常,使用递归函数重新连接
}elseif($config['debug']){
E($e->getMessage());
}
}
위 내용은 ThinkPHP 프레임워크의 분산 데이터베이스 연결 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!