1,模擬web集群
我啟動(dòng)了二個(gè)memcached進(jìn)程,分別模擬二臺服務(wù)器
/usr/local/bin/memcached -d -m 20 -u zhangy -p 12000 -P ./memcached.pid
/usr/local/bin/memcached -d -m 20 -u zhangy -p 13000 -P ./mem.pid
2,修改php的配置
vi /usr/local/php/lib/php.ini
session.save_handler = "memcache"
memcache.hash_strategy = "consistent"
session.save_path = "tcp://127.0.0.1:13000?weight=10,tcp://127.0.0.1:12000"
說(shuō)明:第一行,session的儲存方式是memcache;第二行,memcache的hash算法是consistent;第三行,session儲存的地位;
3,重起apache
查看phpinfo
Session Supportenabled
Registered save handlersfiles user sqlite memcache
Registered serializer handlersphp php_binary
緊接著(zhù)下面是
session.save_pathtcp://127.0.0.1:13000,tcp://127.0.0.1:12000tcp://127.0.0.1:13000,tcp://127.0.0.1:12000
4,做個(gè)簡(jiǎn)單測試
a),準備文件session.php
查看復制打印<?php
session_start();
$_SESSION['username'] = "abcabc";
echo session_id();
?>
b),顯示session內容文件
查看復制打印<?php
$mem = new Memcache;
$mem->addServer("127.0.0.1",12000)or die ("Could not add server 12000");
$mem->addServer("127.0.0.1",13000)or die ("Could not add server 13000");
$val = $mem->get('qp0mrob2ovcqle3u4lbr4obsa5'); //echo session_id();
echo $val;
?>
c),結果是username|s:6:"abcabc";
5,關(guān)于memcache的api
網(wǎng)上有很多關(guān)于memcache的api,你也可以自己寫(xiě)一個(gè),php.net里面memcache的方法說(shuō)的很清楚,并且例子很多,做起來(lái)很快。我是把thinkphp里面的有關(guān)于cache的類(lèi)庫拿出來(lái),整合到自己的代碼中。這個(gè)類(lèi)庫中不光包括memcahce,還有其他的一些cache。網(wǎng)上有關(guān)memcache的api思想差不多,大同小異,思想差不多,我覺(jué)得都是拿過(guò)來(lái),山寨一下就是個(gè)新的。自己去找一下吧。