以前我写过一篇关于web集群时,session同步怎么解决的文章。博文名称是
1,模拟web集群
我启动了二个memcached进程,分别模拟二台服务器
/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"
说明:第一行,session的储存方式是memcache;第二行,memcache的hash算法是consistent;第三行,session储存的地位;
3,重起apache
查看phpinfo
Session Support
enabled
Registered save handlers
files user sqlite memcache
Registered serializer handlers
php php_binary
紧接着下面是
session.save_path
tcp://127.0.0.1:13000,tcp://127.0.0.1:12000
tcp://127.0.0.1:13000,tcp://127.0.0.1:12000
4,做个简单测试
a),准备文件session.php
session_start();
$_SESSION['username'] = "abcabc";
echo session_id();
?>
b),显示session内容文件
$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,关于memcache的api
网上有很多关于memcache的api,你也可以自己写一个,php.net里面memcache的方法说的很清楚,并且例子很多,做起来很快。我是把thinkphp里面的有关于cache的类库拿出来,整合到自己的代码中。这个类库中不光包括memcahce,还有其他的一些cache。网上有关memcache的api思想差不多,大同小异,思想差不多,我觉得都是拿过来,山寨一下就是个新的。自己去找一下吧。
该博文介绍了如何在web集群中通过memcached解决session同步问题。博主启动了两个memcached进程模拟两台服务器,并在PHP配置中设置session保存为memcache,使用一致性哈希策略,并指定session保存路径。通过phpinfo()验证配置生效,并通过测试代码展示session数据的读取。文章还提及可以参考PHP官方文档或第三方库来进一步理解和使用memcache API。

被折叠的 条评论
为什么被折叠?



