色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

PHP模塊 Memcached功能多于Memcache

比如說PECL里有兩個Memcached的模塊,Memcache和Memcached,目前大部分php環境里使用的是名字里不帶d的Memcache版本,這個版本釋出的比較早,是一個原生版本,與之對應的帶d的Memcached版本則是建立在libmemcached的基礎上,所以說Memcached版本的功能更全一些。

安裝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,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 河北省| 阜康市| 石城县| 榆林市| 大石桥市| 江北区| 黔南| 益阳市| 台州市| 鹿泉市| 马龙县| 景宁| 防城港市| 伊春市| 富民县| 乌鲁木齐县| 满城县| 沂南县| 松滋市| 兴宁市| 沾化县| 平和县| 嘉善县| 崇文区| 上思县| 公主岭市| 海林市| 米泉市| 临安市| 宜宾市| 海门市| 巫溪县| 武强县| 绥化市| 文登市| 嘉善县| 唐海县| 闻喜县| 凉城县| 浪卡子县| 鹿邑县|