电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

PHP如何將session保存到memcached中?如何分布式保存PHP session

瀏覽:4日期:2022-09-13 11:40:40
session_set_save_handler無關的memcached保存session的方法

在memcached服務器上

1)下載memcached

#wget http://memcached.googlecode.com/files/memcached-1.4.15.tar.gz

2)由于memcached依賴libevent所以需要先安裝libevent庫,這里直接yum安裝

#yum install *libevent*

3)安裝memcached

#./configure --prefix=/usr/local/memcached#make#make install

4)啟動memcached

#/usr/local/memcached/bin/memcached -d -m 4096 -p 11211 -u root-d daemon ?-p port -u ?user -m memory

在web server服務器上

5)在web server上安裝php的memcache模塊

#/usr/local/php/bin/pecl install memcacheEnable memcache session handler support? [yes] : yes(這里選擇yes)

6)在php.ini中加入如下內容:

extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

7)修改php.ini中的session.save_handler及session.save_path為如下內容:

session.save_handler = memcachesession.save_path = 'tcp://memcached服務器ip:11211'

亦可在PHP程序中

ini_set(’session.save_handler’, ’memcache’);ini_set(’session.save_path’, ’tcp://memcached服務器ip:11211’);

注意:這種使用memcached保存session的方式與session_set_save_handler無關

安裝完memcached之后

在php.ini中

將session.save_handler 修改為memcache,并修改save_path指向memcached的地址和端口即可

session.save_handler = memcachesession.save_path = tcp://127.0.0.1:11211

memcache的PECL這個擴展非常強大,可以支持failover以及分布存儲。

使用方法很簡單,只需要在session.save_path的參數列表中,使用逗號分隔各個memcached服務器,如:

session.save_path = 'tcp://172.16.8.81:11211,tcp://172.16.8.82:11211,tcp://172.16.8.83:11211'

則保存的session會經過hash之后保存到各個memcached服務器中,而hash的算法memcache支持兩種,crc32以及fnv:

memcache.hash_function= {crc32,fnv}

文檔中很少有提到fnv算法的,據說其散列要比crc32更好,但是我通過以下小小的程序實驗之后,發現仍舊是crc32的散列算法分布的更加平均。

<?phpini_set('memcache.hash_function', 'crc32');$memcache = new Memcache;$memcache1 = new Memcache;$memcache2 = new Memcache;$memcache->addServer(’localhost’, 11211);$memcache->addServer(’localhost’, 11212);$memcache->flush();$memcache1->connect(’localhost’, 11211);$memcache2->connect(’localhost’, 11212);$fp1 = fopen('mem1.txt', 'w');$fp2 = fopen('mem2.txt', 'w');for ($i = 0; $i < 1000; $i++){$memcache->set($i, $i, 0, 1000);fwrite($fp1, $memcache1->get($i) . ' ');fwrite($fp2, $memcache2->get($i) . ' ');}fclose($fp1);fclose($fp2);

接著我就session的保存進行了測試

我開了3個memcached進程進行測試

<?phpini_set('memcache.hash_function', 'fnv');ini_set('error_reporting', 'E_CORE_ERROR');$memcache1 = new Memcache;$memcache1->connect(’localhost’, 11211);$memcache1->flush();$memcache2 = new Memcache;$memcache2->connect(’localhost’, 11212);$memcache2->flush();$memcache3 = new Memcache;$memcache3->connect(’localhost’, 11213);$memcache3->flush();$fp1 = fopen(’mem1.txt’, ’w’);$fp2 = fopen(’mem2.txt’, ’w’);$fp3 = fopen(’mem3.txt’, ’w’);for ($i = 0; $i < 1000; $i++){session_start();$ssid = session_id();echo $ssid;session_register('id');$_SESSION['id'] = $ssid;session_write_close();fwrite($fp1, $memcache1->get($ssid) . ’ ’);fwrite($fp2, $memcache2->get($ssid) . ’ ’);fwrite($fp3, $memcache3->get($ssid) . ’ ’);//session_destroy();}fclose($fp1);fclose($fp2);fclose($fp3);

比較奇怪的是 memcached2一般都會不被選中,

而1,3的內容是一致的??赡苁菫榱薴ailover,

而當我把1,3關閉后,2中將會出現內容,說明memcached2是正常工作的。

而不論我的散列算法使用crc32還是fnv,這種現象都存在,

最后我發現:這個測試程序存在問題。

因為在session_write_close之后,整個程序的session都是唯一的了。

也就是雖然循環了這么多次,里面包含了session_destroy調用,但是返回的session id都是同樣的。

這就導致了兩個文件中的內容一致而另一個文件中沒有內容,

基于此點,

我只能分次調用腳本,腳本修改如下:

<?phpini_set('memcache.hash_strategy', 'consistent');ini_set('memcache.hash_function', 'crc32');ini_set('error_reporting', 'E_CORE_ERROR');ini_set('memcache.allow_failover', '0');$memcache1 = new Memcache;$memcache1->connect(’localhost’, 10001);$memcache1->flush();$memcache2 = new Memcache;$memcache2->connect(’localhost’, 10002);$memcache2->flush();$memcache3 = new Memcache;$memcache3->connect(’localhost’, 10003);$memcache3->flush();$fp1 = fopen('mem1.txt', 'a+');$fp2 = fopen('mem2.txt', 'a+');$fp3 = fopen('mem3.txt', 'a+');session_start();$ssid = session_id();echo $ssid . 'n';session_register('id');$_SESSION['id'] = $ssid;//session_destroy();session_write_close();fwrite($fp1, $memcache1->get($ssid) . ' ');fwrite($fp2, $memcache2->get($ssid) . ' ');fwrite($fp3, $memcache3->get($ssid) . ' ');session_destroy();fclose($fp1);fclose($fp2);fclose($fp3);

然后再shell中重復運行多次,返回的ID不同了。

再打開mem*.txt文件查看,

發現3個文件中,每個session會保存在其中兩個文件,然后分布不同。

這證明了使用memcache來保存session,一個是做到了failover,第二會按照session id來做hash分布保存。

標簽: PHP
相關文章:
主站蜘蛛池模板: 电动卫生级调节阀,电动防爆球阀,电动软密封蝶阀,气动高压球阀,气动对夹蝶阀,气动V型调节球阀-上海川沪阀门有限公司 | 首页-恒温恒湿试验箱_恒温恒湿箱_高低温试验箱_高低温交变湿热试验箱_苏州正合 | 集装袋吨袋生产厂家-噸袋廠傢-塑料编织袋-纸塑复合袋-二手吨袋-太空袋-曹县建烨包装 | 浙江建筑资质代办_二级房建_市政_电力_安许_劳务资质办理公司 | 船用泵,船用离心泵,船用喷射泵,泰州隆华船舶设备有限公司 | 四川职高信息网-初高中、大专、职业技术学校招生信息网 | 好杂志网-首页 | 真空吸污车_高压清洗车厂家-程力专用汽车股份有限公司官网 | 电缆接头-防爆电缆接头-格兰头-金属电缆接头-防爆填料函 | 北京工业设计公司-产品外观设计-产品设计公司-千策良品工业设计 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 江西自考网-江西自学考试网| 展厅装修公司|企业展厅设计|展厅制作|展厅搭建—广州展厅装饰公司 | 阴离子_阳离子聚丙烯酰胺厂家_聚合氯化铝价格_水处理絮凝剂_巩义市江源净水材料有限公司 | 硬齿面减速机[型号全],ZQ减速机-淄博久增机械| 新材料分散-高速均质搅拌机-超声波分散混合-上海化烁智能设备有限公司 | 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 阿里巴巴诚信通温州、台州、宁波、嘉兴授权渠道商-浙江联欣科技提供阿里会员办理 | T恤衫定做,企业文化衫制作订做,广告T恤POLO衫定制厂家[源头工厂]-【汉诚T恤定制网】 | 沈飞防静电地板__机房地板-深圳市沈飞防静电设备有限公司 | 档案密集柜_手动密集柜_智能密集柜_内蒙古档案密集柜-盛隆柜业内蒙古密集柜直销中心 | 3A别墅漆/3A环保漆_广东美涂士建材股份有限公司【官网】 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 | 温湿度记录纸_圆盘_横河记录纸|霍尼韦尔记录仪-广州汤米斯机电设备有限公司 | 球形钽粉_球形钨粉_纳米粉末_难熔金属粉末-广东银纳官网 | 空冷器|空气冷却器|空水冷却器-无锡赛迪森机械有限公司[官网] | 聚丙烯酰胺_阴离子_阳离子「用量少」巩义亿腾厂家直销,售后无忧 聚合甘油__盐城市飞龙油脂有限公司 | 刺绳_刀片刺网_刺丝滚笼_不锈钢刺绳生产厂家_安平县浩荣金属丝网制品有限公司-安平县浩荣金属丝网制品有限公司 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠 | 口信网(kousing.com) - 行业资讯_行业展会_行业培训_行业资料 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 水质监测站_水质在线分析仪_水质自动监测系统_多参数水质在线监测仪_水质传感器-山东万象环境科技有限公司 | 真空搅拌机-行星搅拌机-双行星动力混合机-广州市番禺区源创化工设备厂 | 威廉希尔WilliamHill·足球(中国)体育官方网站 | 安全,主动,被动,柔性,山体滑坡,sns,钢丝绳,边坡,防护网,护栏网,围栏,栏杆,栅栏,厂家 - 护栏网防护网生产厂家 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 合肥地磅_合肥数控切割机_安徽地磅厂家_合肥世佳电工设备有限公司 | 上海小程序开发-小程序制作-上海小程序定制开发公司-微信商城小程序-上海咏熠 | 台式恒温摇床价格_大容量恒温摇床厂家-上海量壹科学仪器有限公司 | 华东师范大学在职研究生招生网_在职研究生招生联展网 | 退火炉,燃气退火炉,燃气热处理炉生产厂家-丹阳市丰泰工业炉有限公司 |