首頁 >後端開發 >php教程 >php memcache與php memcached以及遇到的問題

php memcache與php memcached以及遇到的問題

高洛峰
高洛峰原創
2016-11-29 10:30:231217瀏覽

PHP有兩個memcache客戶端:php memcache和php memcached。
php memcache獨立用php實現,是老客戶端,從我們實踐中已發現有多個問題,而且功能少,屬性也可設置的少;
php memcached是基於原生的c的libmemcached的擴展,更加完善,建議替換為php memcached。

1. Php memcache的問題
1.1 分散式問題
php memcache預設會自動切換實例,所以有時取到舊數據,並且value飄忽不定。
網友分享的問題:
這幾天做某個產品的時候遇到一個小問題,現像比較詭異,產品用了兩台分散式的memcached伺服器。某一個計數器取回的數偶爾會不對,最後定位在php memcache client的failover機制上面。
我們知道,在memcached分散式環境下,某一個key是透過hash計算,分配到某一個memcached上面的。
如果php.ini裡面 memcache.allow_failover = 1的時候,在分散式環境下,某一台memcached出問題的話,會自動到其他的memcached嘗試,就會出現上面的問題。所以要設定 allow_failover = 0 那麼取不到時就直接回傳失敗而不會從其它mc上取,這樣以避免網路異常或server端異常時,經常切換實例,會取到舊資料。

1.2 高併發下穩定性問題
新浪微博提到的教訓:
php memcache換成php memcached,在高並發下穩定下極大提高;
另外功能更多,出錯碼更精確。

Twitter的快取經驗
多層次Cache,減輕某些cache節點宕掉後的影響,讀寫都cache;
將memcached api統一換為libmemcached(方便多語言存取memcached,讓分散式等各種規則都一致。 ]] )

第三個參數本來可設定timeout,單位秒,但無法修改。

測試了以下三種修改timeout的方法都無效:
1.3.1. 用memcache api Memcache::setServerParams不能修改;
1.3.2. 改memcache 原始碼vi php_memcache.h宏定義不能修改;
1.3.3 . php.ini內這個配置:default_socket_timeout = 60對本timeout無效。

2. memcache和memcached對比
Php memcache這個老客戶端在屬性設定方面可設定的很少;
出錯碼粒度很粗,出錯後難以定位;

而且功能欠缺一些:



有PHP於兩個客戶。一個是老年人,更廣泛的PECL /快取和其他新的,很少使用,功能更豐富的PECL /快取。

支援基礎等多個伺服器,設定值,得到的值,增量、減量和取得資料。

這裡有一些更先進的功能和資訊。

项目 pecl/memcache pecl/memcached
First Release Date 2004-06-08 2009-01-29 (beta)
Actively Developed Yes Yes
External Dependency None libmemcached
Automatic Key Fixup1 Yes No
Append/Prepend No Yes
Automatic Serialzation2 Yes Yes
Binary Protocol No Optional
CAS No Yes
Compression Yes Yes
Communication Timeout Connect Only Various Options
Consistent Hashing Yes Yes
Delayed Get No Yes
Multi-Get Yes Yes
Session Support Yes Yes
Set/Get to a specific server No Yes
Stores Numerics Converted to Strings Yes

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn