PHP擴展模塊memcached長連接使用方法分析
網(wǎng)上廣泛流傳著一篇文章,講述php的兩個擴展模塊memcache和memcached的區(qū)別,其中特意強調(diào)了memcached與memcached一個很大的區(qū)別是memcached模塊不支持長連接。以至于后來很多年我都認為memcached是不支持長連接的,其實不然,memcached擴展模塊從很早的版本開始就已經(jīng)支持長連接了。從擴展模塊的源碼注視中我們就能看到:
/* {{{ Memcached::__construct([string persistent_id[, callback on_new[, string connection_str]]]))
Creates a Memcached object, optionally using persistent memcache connection */
static PHP_METHOD(Memcached, __construct)
{
從php的手冊身上我們可以看到memcached的擴展模塊提供的構(gòu)造函數(shù)提供一個參數(shù)persistent_id
可選項,手冊中這樣介紹:
默認情況下,Memcached實例在請求結(jié)束后會被銷毀。但可以在創(chuàng)建時通過persistent_id
為每個實例指定唯一的ID, 在請求間共享實例。所有通過相同的persistent_id
值創(chuàng)建的實例共享同一個連接。
這個參數(shù)的含義就是說如果你傳遞了一個命名id給到構(gòu)造方法,那么就會建立長連接,通常我們使用的都是PHP-FPM模式,這樣PHP-FPM進程就會和memcached服務(wù)簡歷一條長連接通道。我們也可以理解為persistent_id就是一個連接池名字,所有php-fpm進程都是這個連接池中的一員。
但我們需要注意的是php是解釋性語言,當(dāng)php第一次通過memached模塊建立起長連接后,切記后續(xù)的php執(zhí)行就不要再通過memcached的構(gòu)造函數(shù)構(gòu)建相同persistent_id命名的長連接,可以建立不同persistent_id名字的長連接,如果是相同的名字被php重復(fù)執(zhí)行,一定會導(dǎo)致php-fpm的進程異常導(dǎo)致與memcached的通信越來越慢,同時根據(jù)libmemcached的版本不同還會導(dǎo)致php產(chǎn)生coredump。
那么我們?nèi)绾伪苊鈫蝹€php-fpm在建立完以persistent_id命名的長連接后不再重復(fù)建立長連接呢?其實在PHP帶有評注的手冊上是有講解的,內(nèi)容如下:
When using persistent connections, it is important to not re-add servers.
This is what you do not want to do:
$mc = new Memcached('mc'); $mc->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true); $mc->addServers(array( array('mc1.example.com',11211), array('mc2.example.com',11211), ));
Every time the page is loaded those servers will be appended to the list resulting in many simultaneous open connections to the same server. The addServer/addServers functions to not check for existing references to the specified servers.
A better approach is something like:
$mc = new Memcached('mc'); $mc->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true); if (!count($mc->getServerList())) { $mc->addServers(array( array('mc1.example.com',11211), array('mc2.example.com',11211), )); }
通過使用getServerList()方法來檢查當(dāng)前執(zhí)行使用的php-fpm進程容器中是否已經(jīng)存在相同名字的長連接資源,如果存在就不要重復(fù)使用addServers() 方法來新增長連接配置。
相關(guān)文章
php中判斷字符串是否全是中文或含有中文的實現(xiàn)代碼
php中判斷字符串是否全是中文或含有中文的實現(xiàn)代碼,主要是利用正則匹配中文判定。2011-09-09PHP實現(xiàn)簡單ajax Loading加載功能示例
這篇文章主要介紹了PHP實現(xiàn)簡單ajax Loading加載功能的方法,結(jié)合實例形式分析了ajax加載的原理、操作技巧與相關(guān)注意事項,需要的朋友可以參考下2016-12-12php將圖片保存入mysql數(shù)據(jù)庫失敗的解決方法
這篇文章主要介紹了php將圖片保存入mysql數(shù)據(jù)庫失敗的解決方法,詳細分析了php將圖片保存入數(shù)據(jù)庫遇到的問題及對應(yīng)的解決方法,并總結(jié)了相關(guān)的技巧,具有一定的參考借鑒價值,需要的朋友可以參考下2014-12-12PHP中使用localhost連接Mysql不成功的解決方法
這篇文章主要介紹了PHP中使用localhost連接Mysql不成功的解決方法,但使用127.0.0.1則沒有問題,本文也可以說是對連接MySQL主機使用127.0.0.1與localhost的區(qū)別的講解,需要的朋友可以參考下2014-08-08php Notice: Undefined index 錯誤提示解決方法
字面意思就是未定義的索引,一般情況下是因為程序開發(fā)作者判斷不嚴謹導(dǎo)致。一般不會影響程序的運行,具體的解決方法可以參考下。2010-08-08