Sky's blog

我和我追逐的梦

常用链接

统计

其他链接

友情链接

最新评论

resin的session id reuse特性(3)--总结

    从对resin源码的追踪到resin配置文件中的设置,可以明确的看到,resin在设计上是提供了session id 的reuse功能,而且resin.conf默认就是打开reuse的。惭愧的是,我一直不知道......

    事情要从前段时间的工作谈起,我被要求设计出一套合适的方案来解决目前公司现有的几个前台模块各自为政的问题。其中最核心的两个就是多机负载分担和统一认证功能。目前公司产品中多机负载有两种方式: 1. 纯resin,放弃了对HttpSession和本地资源的使用 2. apache + resin,需要传递所有需要用到的参数,因为麻烦所有干脆只有一个单一入口,因为使用了HttpSession,因此虽然页面跳转进来了,但是由于没有原来的jsessionid无法利用上一次进入该模块时的session,造成要重新创建新的session,非常的吐血。

    之后针对apache + resin的多机分布方案进行了调研,随即发现这个方案的核心就在于jsessionid参数的传递。在研究jsessionid传递的时候无意中发现使用cookie传递jsessionid到另外一个webapp,这个webapp新生成的HttpSession的id(就也是jsessionid),居然和传递过来的上一个webapp的jsessionid相同!

    惊喜万分啊,依照这个特性,完全可以在各个webapp之间只传递jsessionid这一个参数。负责登录的"主webapp"在HttpSession中保存用户资料,所有其他webapp都可以使用jsessionid作为标志到"主webapp"来获取这些用户资料,只要"主webapp"提供一个简单的接口即可。随后编码测试了一下,发现这个方案非常好的解决了我目前的问题,简直完美了: apache + resin多机分布,多webapp之间页面任意跳转,简单到只要携带一个jsessionid(这个还可以放cookie)就可以跨webapp四处乱跑。

    随即编码测试了一遍,验证这个方法的的确可行。稍后我再将这个方案的详细情况整理出来分享给大家。

    这个方案基石,就是jsessionid的传递和jsessionid的重用。在这次方案探索之前,我对jsessionid重用完全没有概念,也根本不知道resin已经有对这个特性的支持。一路摸索过来,几经周折,最后发现原来resin早就准备好了现成的解决方案,为类似我这种多webapp的系统提供session id reuse的支持。

    想起了这句词:“众里寻她前百度,蓦然回首,那人却在灯火阑珊处”。呵呵,颇有感觉。

    后记: 看来对resin的了解还是不够深入啊,否则如果之前对session id reuse有了解的话,应该可以直接就想到这个方案了。这次能误打误撞的发现,运气着实不错。另外似乎tomcat好象不提供类似的特性支持,稍后再继续研究。

posted on 2007-12-28 16:28 sky ao 阅读(1748) 评论(4)  编辑  收藏 所属分类: web

评论

# re: resin的session id reuse特性(3)--总结 2007-12-28 18:32 lizongbo


手工加行代码或者配置配置文件,实现把sessionid的cookie的作用域设为顶级域名,path设置为"/"根目录的效果应该就可以了啊。

Tomcat是支持配置sessionid cookie 的 path到"/"的。


  回复  更多评论   

# re: resin的session id reuse特性(3)--总结[未登录] 2007-12-28 19:55 飘然

呵呵,lizongbo应该是没有看懂我的帖子,是jsessionid 的reuse,不是jsessionid放在cookie里面传递。

session id reuse的表现在于两个不同的webapp里面建立两个session,但是jsessionid是一样的。  回复  更多评论   

# re: resin的session id reuse特性(3)--总结[未登录] 2007-12-28 19:56 飘然

不同的webapp,他们的session是不一样的,不能相互访问。  回复  更多评论   

# re: resin的session id reuse特性(3)--总结[未登录] 2009-05-12 13:35 ben

你好.我也在关注这一块儿的东西.具体实现方式能不能再详细点呢?呵呵,我是菜鸟  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问