簡介:這是轉 memcache儲存php的session 解決多伺服器的session問題的詳細頁面,介紹了和php,php, memcached 轉 memcache儲存php的session 解決多伺服器的session問題有關的知識、技巧、經驗,和一些php源碼等。
class='pingjiaF' frameborder='0' src='http://biancheng.dnbcw.info/pingjia.php?id=360988' scrolling='no'>
PECL :: Package :: memcache 2.1.1 版本的 Changelog 中有一條:
- Added experimental session storage support. You can use memcached as session storage.
也就是可以直接用 memcache 來作 PHP 的 session.save_handler。
1. 安裝 memcached,還是那套 ./configure; make; make install,注意 memcached 用 libevent 來作事件驅動,所以要先安裝有 libevent。
2. 安裝 pecl::memcache,用 pecl 命令列工具安裝:
pecl install memcache
或直接從源碼安裝:
phpize
./configure
make
make install
將 php.ini 中 extension=memcache.so 開啟,重啟一下 apache,查看 phpinfo 中的 Registered save handlers 會有 files user memcache 這3個可用。
3. 修正設定檔,在 php.ini 中全域設定:
session.save_handler = memcache
session.save_path = tcp://127.0.0.1:11211
或者某個目錄下的 .htaccess :
php_value session.save_handler memcache
php_value session.save_path tcp://127.0.0.1:11211
再或者在某個一個應用中:
ini_set(session.save_handler, memcache);
ini_set(session.save_path, tcp://127.0.0.1:11211);
應用多個 memcached server 時用逗號,隔開,並且和 Memcache::addServer() 文檔中闡明的一樣,可以帶額外的參數persistent、weight、timeout、retry_interval 等等,類似這樣的:tcp://host1:port1?persistent=1&weight=2,tcp://host2:port2 。
4. 啟動 memcached:
memcached -d -l 127.0.0.1 -p 11212 -m 128
5. 在程式中應用 memcache 來作 session 儲存,用例子測試一下:
___FCKpd___6
6. 用 sessionid 去 memcached 裡查詢一下:
<?php
$memcache = memcache_connect(localhost, 11211);
var_dump($memcache->get(19216821213c65cedec65b0883238c278eeb573e077));
SESSION[TEST3] = time();
print <br><br>;
print session_id();
?>
會有看到
string(37) TEST|i:1177556731;TEST3|i:1177556881;
這樣的輸出,證明 session 正常工作。
用 memcache 來儲存 session 在讀寫速度上會比 files 時快很多,而且在多個伺服器須要共用 session 時會比較方便,將這些伺服器都配置成應用同一組 memcached 伺服器就可以,減少了額外的工作量。缺點是 session 資料都儲存在 memory 中,持久化方面有所欠缺,但對 session 資料來說也不是很大的問題。
愛J2EE關注Java邁克爾傑克遜視頻站JSON線上工具
http://biancheng.dnbcw.info/php/360988.html pageNo:1