久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

ThinkPHP框架分布式數據庫連接方法詳解

這篇文章主要介紹了ThinkPHP框架分布式數據庫連接方法,結合實例形式詳細分析了thinkPHP框架針對分布式數據庫的連接方法、操作技巧與相關注意事項,需要的朋友可以參考下

本文實例分析了ThinkPHP框架分布式數據庫連接方法。分享給大家供大家參考,具體如下:

Thinkphp作為國內的一款流行框架,相信使用的人一定不在少數。本篇我們來分析一下Thinkphp中比較重要的一部分——分布式數據庫的連接。

當然了,我們在這里不是去將如何使用模型去對數據庫進行增刪改查。我們是對其底層的連接代碼做一個分析,可以幫助大家更好的理解thinkphp對數據庫的操作。方便我們以后的使用。

一、單一數據庫的連接

在使用的時候,單一數據庫的連接配置非常簡單。我們只需要在配置文件中配置一下的信息即可。

'DB_TYPE' => 'mysql',
'DB_HOST' => '192.168.5.102',
'DB_NAME' => 'databasename',
'DB_USER' => 'user',
'DB_PWD' => 'password',
'DB_PORT' => '3306',
'DB_PREFIX' => 'onmpw_',

設置完成以后就可以使用了。默認情況下就是單一的數據庫連接。

二、分布式數據庫的連接

單一數據庫的連接很簡單,我們著重分析一下分布式數據庫的連接。

'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 表示的是集中式(也就是單一服務器)。

該選項的實現是在類 Think\Db\Dirver中

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數組中。至于是如何解析配置文件的,這里我們不做介紹,感興趣的可以參考Think\Db類。

$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));  // 每次隨機連接的數據庫
}

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

下面小編就為大家分享一篇ThinkPHP整合datatables實現服務端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP長連接實現與使用方法,結合實例形式較為詳細的分析了php長連接的概念、功能、實現與使用方法,需要的朋友可以參考下
這篇文章主要介紹了PHP使用Redis長連接的方法,結合實例形式詳細分析php操作redis長連接的使用方法及相關注意事項,需要的朋友可以參考下
下面小編就為大家分享一篇thinkphp3.2.0 setInc方法 源碼全面解析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了php代碼實現mysql連接池效果,需要的朋友可以參考下
這篇文章主要介紹了tp5(thinkPHP5)操作mongoDB數據庫的方法,結合實例形式簡單分析了mongoDB數據庫及thinkPHP5連接、查詢MongoDB數據庫的基本操作技巧,需要的朋友可以參考下
主站蜘蛛池模板: 精品自拍视频 | 色综合久久88色综合天天 | www网站在线观看 | 香蕉久久久久久 | 精品乱码一区二区三四区视频 | а_天堂中文最新版地址 | 91豆花视频 | 国产欧美日韩在线一区 | 国产一级片免费视频 | 99久久久久久久久 | 国产japanhdxxxx麻豆 | www.操.com | 欧美成人精品一区二区男人看 | 国产高清免费 | 91资源在线| 欧美日韩成人 | 久久99蜜桃综合影院免费观看 | 亚洲国产成人精品女人 | 午夜精品一区二区三区在线播放 | 久在线视频播放免费视频 | 99免费在线观看 | 久久久性| 久草色播| 亚洲精品黑人 | 国产精品一区二区在线播放 | 国产韩国精品一区二区三区 | 国产成人精品999在线观看 | 中文字幕一区二区三区精彩视频 | 欧洲亚洲视频 | 久久网站免费视频 | 欧美日韩精品一区二区三区视频 | 久久欧美高清二区三区 | 亚洲精品区 | 中文在线一区 | 天天综合久久 | 久久免费电影 | 色婷婷国产精品 | 日韩网站在线观看 | 91影片| 日韩一区二区免费视频 | 中文字幕亚洲视频 |