|
安裝Memcached版本的php模塊
wget http://download.tangent.org/libmemcached-0.35.tar.gz
tar zxf libmemcached-0.35.tar.gz
cd libmemcached-0.35
./configure
make
make install
wget http://pecl.php.NET/get/memcached-1.0.0.tgz
tar zxf memcached-1.0.0.tgz
cd memcached-1.0.0
phpize
./configure
make
make install
打開php.ini加上:
extension = "memcached.so"
這樣安裝就結束了,你可以通過下列命令來確認:
php -m | grep mem
演示Memcached版本的新功能
先虛構一個問題,假設counter初始值是一個整數,不使用increment方法,通過get/set完成每次加一。
在Memcache版本里,我們只能按照大致如下的方式來進行:
$m = new Memcache();
$m->addServer('localhost', 11211);
$v = $m->get('counter');
$m->set('counter', $v + 1);
由于get/set這兩個動作無法作為一個原子來操作,所以當多個進程同時處理時,會出現丟失的可能,更讓人惱火的是,你根本就不知道什么時候出現丟失。
再看看Memcached版本里,我們是如何做的:
$md = new Memcached();
$md->addServer('localhost', 11211);
$v = $md->get('counter', null, $token)
$md->cas($token, 'counter', $v + 1);
cas是Memcached版本里提供的功能,說白了就是一個樂觀鎖的功能,如果你把$token的值var_dump出來,就會發現$token其實就是一個版本號,如果通過get得到的$token版本號在cas的時候不對應,就說明已經有別的操作更新了,此時cas操作會失敗,至于如何繼續操作,就看你自己了。
注:如果你想手動重現一下沖突的情況,可在get和cas之間sleep若干秒,并拷貝兩份腳本,先后執行。
順便說一句,推薦的Memcached版本模塊的哈希設置如下:
$md->setOption(Memcached::OPT_DISTRIBUTION, Memcached::DISTRIBUTION_CONSISTENT);
$md->setOption(Memcached::OPT_HASH, Memcached::HASH_CRC);
總結
Memcached版本還有很多Memcache沒有的功能,比如通過getByKey, setByKey等自動支持多個服務器,就不贅述了,該用哪個擴展已經不言自明了。
補充:http://code.google.com/p/memcached/wiki/phpClientComparison
php技術:PHP模塊 Memcached功能多于Memcache,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。