Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2153862
  • 博文数量: 227
  • 博客积分: 10521
  • 博客等级: 上将
  • 技术积分: 3452
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-20 14:59
个人简介

低调做人,高调做事!

文章分类

全部博文(227)

文章存档

2013年(4)

2012年(8)

2011年(16)

2010年(24)

2009年(92)

2008年(83)

分类: LINUX

2010-08-21 14:00:30

这几天在实现nginx集群的过程中,发现session使用存在问题,登录页面后有时候需要重复登录,和开发部沟通后,决定采用memcached来实现session的共享,这也是各大型网站推荐的方式。

开发部开始写了一些用memcache来保存session的代码后,测试效果不是很理想,还是存在问题,后来在一个blog上发现可以直接在php.ini中设定使用memcache作为session处理,而且无须另外编码,大大较少了开发成本,方法是:

修改php.ini中的以下值
session.save_handler = memcache
session.save_path = 'tcp://192.168.100.100:12000'

重新启动apache,查看phpinfo就知道设置是否生效。


如果只想在特定的应用里使用memcache储存session,可以使用ini_set的方法对以上两个参数进行设定:
ini_set("session.save_handler", "memcache");
ini_set("session.save_path", "192.168.100.100:12000");

注:使用多个 memcached server 时用逗号”,”隔开,可以带额外的参数”persistent”、”weight”、”timeout”、”retry_interval” 等等,

类似这样的:"tcp://host:port?persistent=1&weight=2,tcp://host2:port2"。


要测试一下是否真正用上了memcache,可以先捕足到使用的PHPSESSID,再作为KEY用memcach去读一下,就清楚了,测试代码如下:

创建一个set_session.php代码:

//set_session.php
session_start();
if (!isset($_SESSION['admin'])) {
$_SESSION['TEST'] = 'chentao';
}
print $_SESSION['admin'];
print "\n";
print session_id();
?>


创建一个get_session.php代码:

//get_session.php
$mem = new Memcache;
$mem->connect("192.168.100.100", 12000);
var_dump($mem->get('9a971ff6b459d59950035e9aa5dbf88f'));
?>

在命令行,或者页面都可以执行,如果输出结果为:
string(16) "admin|s:3:"chentao";"
就证明 session 正常工作。

在生产环境里,你也可以查看调度服务器的访问日志,同一IP地址前后访问的服务器不一样,仍然可以共享session,比如我的nginx调度日志如下:

[root@localhost conf]# tail /var/log/nginx/test_access_log | awk {'print $1,$6,$7'} | sort
192.168.8.236 192.168.1.4:8080 200
192.168.8.236 192.168.1.9:8080 200
192.168.8.239 192.168.1.9:8080 200
192.168.8.239 192.168.1.9:8080 200
192.168.8.239 192.168.1.9:8080 200
192.168.8.26 192.168.1.4:8080 200
192.168.8.26 192.168.1.4:8080 200
192.168.8.26 192.168.1.4:8080 200
192.168.8.26 192.168.1.9:8080 200
阅读(12435) | 评论(3) | 转发(1) |
给主人留下些什么吧!~~

huifeideluotuo2010-08-24 16:25:42

ip_hash指令无法保证后端服务器的负载均衡,可能有些后端服务器接收的请求多,有些后端服务器接收的请求少;这样失去了负载均衡的意义.

chinaunix网友2010-08-24 11:19:03

为啥不用ip hash试试?

chinaunix网友2010-08-24 08:57:52

Download More than 1000 free IT eBooks: http://free-ebooks.appspot.com