溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在PHP中使用memcached擴(kuò)展模塊實(shí)現(xiàn)長(zhǎng)連接

發(fā)布時(shí)間:2021-03-17 15:59:27 來(lái)源:億速云 閱讀:188 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

如何在PHP中使用memcached擴(kuò)展模塊實(shí)現(xiàn)長(zhǎng)連接?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

memcached擴(kuò)展模塊從很早的版本開(kāi)始就已經(jīng)支持長(zhǎng)連接了。從擴(kuò)展模塊的源碼注視中我們就能看到:

/* {{{ 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的手冊(cè)身上我們可以看到memcached的擴(kuò)展模塊提供的構(gòu)造函數(shù)提供一個(gè)參數(shù)persistent_id可選項(xiàng),手冊(cè)中這樣介紹:

      默認(rèn)情況下,Memcached實(shí)例在請(qǐng)求結(jié)束后會(huì)被銷毀。但可以在創(chuàng)建時(shí)通過(guò)persistent_id為每個(gè)實(shí)例指定唯一的ID, 在請(qǐng)求間共享實(shí)例。所有通過(guò)相同的persistent_id值創(chuàng)建的實(shí)例共享同一個(gè)連接。 

這個(gè)參數(shù)的含義就是說(shuō)如果你傳遞了一個(gè)命名id給到構(gòu)造方法,那么就會(huì)建立長(zhǎng)連接,通常我們使用的都是PHP-FPM模式,這樣PHP-FPM進(jìn)程就會(huì)和memcached服務(wù)簡(jiǎn)歷一條長(zhǎng)連接通道。我們也可以理解為persistent_id就是一個(gè)連接池名字,所有php-fpm進(jìn)程都是這個(gè)連接池中的一員。

     但我們需要注意的是php是解釋性語(yǔ)言,當(dāng)php第一次通過(guò)memached模塊建立起長(zhǎng)連接后,切記后續(xù)的php執(zhí)行就不要再通過(guò)memcached的構(gòu)造函數(shù)構(gòu)建相同persistent_id命名的長(zhǎng)連接,可以建立不同persistent_id名字的長(zhǎng)連接,如果是相同的名字被php重復(fù)執(zhí)行,一定會(huì)導(dǎo)致php-fpm的進(jìn)程異常導(dǎo)致與memcached的通信越來(lái)越慢,同時(shí)根據(jù)libmemcached的版本不同還會(huì)導(dǎo)致php產(chǎn)生coredump。

    那么我們?nèi)绾伪苊鈫蝹€(gè)php-fpm在建立完以persistent_id命名的長(zhǎng)連接后不再重復(fù)建立長(zhǎng)連接呢?其實(shí)在PHP帶有評(píng)注的手冊(cè)上是有講解的,內(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),
  ));
}

通過(guò)使用getServerList()方法來(lái)檢查當(dāng)前執(zhí)行使用的php-fpm進(jìn)程容器中是否已經(jīng)存在相同名字的長(zhǎng)連接資源,如果存在就不要重復(fù)使用addServers() 方法來(lái)新增長(zhǎng)連接配置。

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI