轉 memcache儲存php的session 解決多伺服器的session問題

來源:互聯網
上載者:User

簡介:這是轉 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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.