PHP中使用memcache存儲session的三種配置方法
更新時間:2014年04月05日 19:50:30 投稿:junjie
下面簡單說下PHP項目分布式部署中,SESSION的同步方案中的一種,使用Memcache來存儲SESSION。并總結(jié)了三種配置方式,需要的朋友可以參考下
1、直接修改php.ini配置文件
復(fù)制代碼 代碼如下:
session.save_handler = memcache //設(shè)置session的儲存方式為memcache
memcache.hash_strategy = "consistent"//設(shè)置memcache的hash算法
session.save_path = "tcp://127.0.0.100:11211" //設(shè)置session儲存的位置,多臺memcache用逗號隔開,例如:tcp://127.0.0.1:11211,tcp://127.0.0.1:12000
2、利用目錄下的 .htaccess 文件配置
復(fù)制代碼 代碼如下:
php_value session.save_handler "memcache"
php_value session.save_path "tcp://127.0.0.1:11211"
說明:這個只是針對Apache的,目前使用Nginx的比較多,也不推薦此方式。
3、在項目的PHP文件中修改配置
復(fù)制代碼 代碼如下:
ini_set("session.save_handler", "memcache");
ini_set("session.save_path", "tcp://127.0.0.100:11211");
ini_set("session.save_path", "tcp://127.0.0.100:11211");
4、測試?yán)?br />
復(fù)制代碼 代碼如下:
//測試session讀取是否正常
session_start();
$_SESSION['username'] = "jb51.net";
echo session_id();
//從Memcache中讀取session
$m = new Memcache();
$m->connect('localhost', 11211);
//或者這樣
//$mem->addServer("127.0.0.1", 11211) or die ("Can't add Memcache server 127.0.0.1:12000");
//根據(jù)session_id獲取數(shù)據(jù)
//本機(jī)
//$session = $m->get(session_id()); //session_id:d527b6f983bd5e941f9fff318a31206b
//另一臺服務(wù)器,已知session id
$session = $m->get("d527b6f983bd5e941f9fff318a31206b");
echo $session."<br/>"; //會得到這樣的數(shù)據(jù):username|s:16:"pandao";,解析一下就可以得到相應(yīng)的值了
echo session_id()."<br/>";
exit;
上面只是一些簡單的說明,其實(shí)說點(diǎn)題外話,一般來說,做分布式,那肯定是有服務(wù)器權(quán)限的,所以推薦第一種。
相關(guān)文章
php版微信公眾平臺開發(fā)之驗(yàn)證步驟實(shí)例詳解
這篇文章主要介紹了php版微信公眾平臺開發(fā)之驗(yàn)證步驟,結(jié)合實(shí)例形式詳細(xì)分析了php微信公眾平臺驗(yàn)證的操作步驟與相關(guān)參數(shù)含義,需要的朋友可以參考下2016-09-09php實(shí)現(xiàn)的支付寶網(wǎng)頁支付功能示例【基于TP5框架】
這篇文章主要介紹了php實(shí)現(xiàn)的支付寶網(wǎng)頁支付功能,結(jié)合實(shí)例形式分析了基于TP5框架框架的支付寶網(wǎng)頁支付功能具體操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-09-09使用PHP實(shí)現(xiàn)阻止用戶上傳成人照片或者裸照
這篇文章主要介紹了使用PHP實(shí)現(xiàn)阻止用戶上傳成人照片或者裸照,方法和思路都非常的不錯,推薦給大家,需要的朋友可以參考下2014-12-12