利用memcache在web集群中同步会话session
时间:2015-09-20 23:42 来源:linux.it.net.cn 作者:IT
在之前中探讨了web集群中:web集群应用保持session同步的3种方法探讨
个人觉得用memcache来同步session是还是不错的,当然也可以通过redis来保存session php开启将Session存储到Redis缓存,下面是我的设置的利用memcache在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
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
1
<?php
2
session_start();
3
$_SESSION
[
'username'
] =
"abcabc"
;
4
echo
session_id();
5
?>
b),显示session内容文件
1
<?php
2
$mem
=
new
Memcache;
3
$mem
->addServer(
"127.0.0.1"
,12000)
or
die
(
"Could not add server 12000"
);
4
$mem
->addServer(
"127.0.0.1"
,13000)
or
die
(
"Could not add server 13000"
);
5
$val
=
$mem
->get(
'qp0mrob2ovcqle3u4lbr4obsa5'
);
//echo session_id(); 得到的session id
6
echo
$val
;
7
?>
(责任编辑:IT)
在之前中探讨了web集群中:web集群应用保持session同步的3种方法探讨 个人觉得用memcache来同步session是还是不错的,当然也可以通过redis来保存session php开启将Session存储到Redis缓存,下面是我的设置的利用memcache在web集群中同步会话session过程:
1,模拟web集群 我启动了二个memcached进程,分别模拟二台服务器
/usr/local/bin/memcached -d -m 20 -u zhangy -p 12000 -P ./memcached.pid
2,修改php的配置 vi /usr/local/php/lib/php.ini
session.save_handler = "memcache" 说明:第一行,session的储存方式是memcache;第二行,memcache的hash算法是consistent;第三行,session储存的地位; 3,重起apache 查看phpinfo session
紧接着下面是
4,做个简单测试 a),准备文件session.php
b),显示session内容文件
(责任编辑:IT) |