多服务器共享session问题

背景:

大网站会有多个应用,  运行不同的功能模块,使用不同的二级域名, 而用户系统是统一的,这时需要共享用户的session信息.

问题就是: 多个服务器之间共享session信息.

 

分析:

1. session跨域.

同根域:  

PHP代码实现 

<?php
ini_set('session.cookie_domain', '.infor96.com');
?>

非同根域:

??? 

保证了不同域名生成的session_id是一致的.

2. session数据存储问题.

1) nfs文件共享.    实现简单.   并发效率不高.

2) 数据库, mysql的heap内存表. 实用性不错. session的读写能力取决于mysql数据库的性能, 需要编码实现session淘汰逻辑.

3) memcache共享. memcahe过期淘汰机制和session的淘汰机制正好匹配. 推荐!

 

总结:

实际使用中可以根据业务需要和访问量来实现, 比如简单的用nfs就够了, 稍微复杂点的用数据库,

对高频率的访问就用memcache, 再高频次的就可以用redis(持久化存储, 高并发).

如果网站中的每个系统业务都比较复杂, 可以考虑用sso(单点登录)了.

posted on 2012-06-16 00:11  DavidYanXW  阅读(336)  评论(0编辑  收藏  举报