- 相關推薦
PHP 驅動 MongoDB 的技巧
在php中使用mongodb你必須使用 mongodb 的 php驅動。以下就是小編精心介紹PHP 驅動 MongoDB 的技巧,希望對大家有幫助!
當與mongodb復制集建立連接時,驅動程序首先嘗試連接并驗證集群中每個非 隱藏的節(jié)點。如果一個節(jié)點是“down”狀態(tài),將跳過。
創(chuàng)建索引有時會阻塞新的連接
然而,如果一個節(jié)點是“UP”狀態(tài),但是持有寫鎖,那么驗證將沒法執(zhí)行下去,因此該驅動程序將被掛起了。
在mongodb 2.6版本前,在建立索引時的通病。所有的在前臺或后臺創(chuàng)建索引,在secondary端將在前臺創(chuàng)建。
在PHP驅動程序的1.5.3版本會有所改進,在創(chuàng)建索引時,允許驗證到second節(jié)點驗證。
減少is_master_interval值
對于對可用性要求高的應用程序來說,建議檢查默認的驅動程序運行時的配置設置。
mongo.is_master_interval選項控制著在復制集重新選舉時驅動如何快速恢復。
is_master_interval選項默認值為15s,設置驅動發(fā)送“isMaster”請求每個mongod實例的時間間隔。這些請求幫助驅動程序判斷復制集的拓撲結構,具體的來說,就是請求檢測哪個節(jié)點是primary并可以接收寫操作。
建議將該值設置為1或2秒,以讓驅動程序在集群選舉或故障轉移時,能夠迅速的定位到primary節(jié)點。當然啦,這也取決于有多少客戶端以及ping的頻率。
注意,當primary節(jié)點發(fā)生變化時,如選舉或故障轉移,總是會有幾秒鐘驅動程序會收到一個“MongoConnectionException” 信息 “No candidate servers found”。這些異常需要在你的代碼中進行處理,否則會終止應用程序。
理解連接處理方式并配置連接TimeoutMS
PHP驅動程序不使用連接池。因此,建議你每個PHP進程創(chuàng)建一個連接。但是,如果web應用程序有許多PHP工作進程,將會創(chuàng)建很多新的數(shù)據(jù)庫連接,PHP驅動程序不能共享進程之間的連接。因此,當網(wǎng)絡節(jié)點慢,服務器繁忙時,PHP應用程序創(chuàng)建初始數(shù)據(jù)庫連接時特別容易受到阻礙。
在這種情況下,建議你自定義connectionTimeoutMS 選項和注意php.ini中的mongo.ping_interval選項。
connectionTimeoutMS
PHP驅動程序不顯示的定義一個默認的連接超時。相反,默認值由php.ini文件中的default_socket_timeout選項決定,默認是60秒。連接將等待60秒斷開,時間有些長,需要降低些。
強烈建議通過連接字符串的URI選項中顯示設置connectionTimeoutMS選項。將其設置為5到30秒之間的值。
mongo.ping_interval
mongo.ping_interval默認值為5秒。該選項設置驅動程序發(fā)送ping請求到每個mongod實例發(fā)現(xiàn)“down”節(jié)點的時間間隔,用于跟蹤驅動程序的服務器黑名單。告訴驅動程序哪些節(jié)點忽略。
【PHP 驅動 MongoDB 的技巧】相關文章:
幾個php技巧11-07
PHP小技巧07-12
PHP開發(fā)的安全技巧10-14
PHP性能優(yōu)化技巧09-22
PHP代碼優(yōu)化技巧09-10
PHP常用開發(fā)技巧10-24
php的幾個小技巧09-07
PHP開發(fā)安全技巧08-10