伴随网站业务规模和访问量的逐步发展,原本由单台服务器、单个域名的迷你网站架构已经无法满足发展需要。
此时我们可能会购买更多服务器,并且启用多个二级子域名以频道化的方式,根据业务功能将网站分布部署在独立的服务器上;或通过负载均衡技术(如:DNS轮询、Radware、 F5、LVS等)让多个频道共享一组服务器。
OK,头脑中我们已经构思了这样的解决方案,不过进入深入开发后新的技术问题又随之而来:
我 们把网站程序分布部署到多台服务器上,而且独立为几个二级域名,由于Session受实现原理的局限(PHP中Session默认以文件的形式保存在本地 服务器的硬盘),使得我们的网站用户不得不经常在几个频道间来回输入用户名、密码登入,导致用户体验大打折扣;另外,原本程序可以直接从用户 Session变量中读取的资料(如:昵称、积分、登入时间等),因为无法跨服务器同步更新Session 变量,迫使开发人员必须实时读写数据库,从而增加了数据库的负担。
于是,解决网站跨服务器之间的Session共享方案需求变得迫切起来,最终催生了多种解决方案,下面列举4种较为可行的方案进行对比探讨:
1. 基于NFS的Session共享
NFS是Net FileSystem的简称,最早由Sun公司为解决Unix网络主机间的目录共享而研发。
这 个方案实现最为简单,无需做过多的二次开发,仅需将共享目录服务器mount到各频道服务器的本地session目录即可,缺点是NFS依托于复杂的安全 机制和文件系统,因此并发效率不高,尤其对于session这类高并发读写的小文件,会由于共享目录服务器的io-wait过高,最终拖累前端WEB应用 程序的执行效率。
2. 基于数据库的Session共享
首 选当然是大名鼎鼎的Mysql数据库,并且建议使用内存表Heap,提高session操作的读写效率。这个方案的实用性比较强,相信大家普遍在使用,它 的缺点在于 session的并发读写能力取决于Mysql数据库的性能,同时需要自己实现session淘汰逻辑,以便定时从数据表中更新、删除 session记录,当并发过高时容易出现表锁,虽然我们可以选择行级锁的表引擎,但不得不否认使用数据库存储Session还是有些杀鸡用牛刀的架势。
3. 基于Cookie的Session共享
这 个方案我们可能比较陌生,但它在大型网站中还是比较普遍被使用。原理是将全站用户的Session信息加密、序列化后以Cookie的方式,统一种植在根 域名下(如:.host.com),利用浏览器访问该根域名下的所有二级域名站点时,会传递与之域名对应的所有Cookie内容的特性,从而实现用户的 Cookie化Session 在多服务间的共享访问。
这个方案的优点无需额外的服务器资源;缺点是由于受http协议头信心长度的限制, 仅能够存储小部分的用户信息,同时Cookie化的 Session内容需要进行安全加解密(如:采用DES、RSA等进行明文加解密;再由MD5、SHA-1等算法进行防伪认证),另外它也会占用一定的带 宽资源,因为浏览器会在请求当前域名下任何资源时将本地Cookie附加在http头中传递到服务器。
4. 基于Memcache的Session共享
Memcache由于是一款基于Libevent多路异步I/O技术的内存共享系统,简单的Key + Value数据存储模式使得代码逻辑小巧高效,因此在并发处理能力上占据了绝对优势,目前本人所经历的项目达到2000/秒 平均查询,并且服务器CPU消耗依然不到10%。
另外值得一提的是Memcache的内存hash表所特有的Expires数据过期淘汰机制,正好和Session的过期机制不谋而合,降低了过期Session数据删除的代码复杂度,对比“基于数据库的存储方案”,仅这块逻辑就给数据表产生巨大的查询压力。
参考:
PHP实现多服务器session共享之memcache共享
http://imysql.cn/?q=node/215
PHP实现多服务器session共享之NFS共享
http://imysql.cn/?q=node/202
分享到:
相关推荐
在这个场景中,我们关注的是如何在Tomcat集群环境中实现Session共享,以便提高应用程序的可扩展性和可用性。标题和描述提到的“session共享包”是解决这一问题的关键。 **什么是Session?** 在Web应用中,Session是...
为了解决这个问题,我们可以采用以下几种策略: 1. **Cookieless Session**:ASP.NET允许我们设置应用程序使用Cookieless Session,即通过URL编码的方式传递Session ID。这样,即使在不同域名之间,只要URL被正确...
Tomcat7提供了几种session共享策略,包括以下几种常见方法: 1. **JVM-RMI**:这是Tomcat默认的session复制方式。每个服务器都将session对象复制到其他服务器,通过Java远程方法调用(RMI)实现。这种方式简单易用...
2. **选择session复制策略**:Tomcat提供了几种session复制策略,包括基于内存的复制和基于JDBC的复制。在这个场景下,我们将采用基于第三方存储的策略,即使用`org.apache.catalina.session.PersistentManagerBase`...
在Java中实现session共享通常涉及到以下几个关键步骤: 1. **添加依赖**:首先,需要在项目的构建文件(如Maven的pom.xml或Gradle的build.gradle)中添加对memcached客户端库(如spymemcached或xmemcached)的依赖...
此外,使用Redis进行Session共享时,还需要注意以下几点: - **安全性**:由于Session通常包含敏感信息,如用户ID,因此在使用Redis时应考虑数据加密。 - **性能**:频繁的Session读写操作可能影响Redis性能,适当...
通常,我们可以使用以下几种方法实现session共享: 1. **Redis Session Store**: Spring Boot可以与Redis集成,将session存储在Redis中。这样,所有服务都可以访问同一个session存储,实现session共享。需要配置`...
然而,集群环境下的session共享问题是个棘手的问题,因为它涉及到用户状态的维护和一致性。本篇将深入探讨如何在Tomcat8的集群环境中使用memcache来解决session共享的问题。 首先,让我们理解什么是session。...
这通常涉及到服务器集群的部署,其中Session共享是一个核心问题。本篇文章将探讨如何利用Redis、Tomcat和Nginx来实现Session共享,以便在分布式环境中保持用户状态的一致性。 首先,让我们了解一下Session的概念。...
Memcached是一种高性能、分布式的内存对象缓存系统,常被用来解决session共享的问题。本篇将详细阐述如何利用Memcached配置session共享,并涉及所需依赖的jar包。 首先,Memcached作为一个缓存服务,能够存储会话...
有几种常见的解决方案: 1. **Cookie-Based**:将`session ID`存储在cookie中,每次请求时由客户端携带。这种方式简单但安全性较低,因为`session ID`可能被窃取。 2. ** Sticky Session**:`Nginx`配置中启用`...
在ASP.NET中实现跨子域共享SESSION,主要有以下几种方法: 1. **Cookie-Based Sharing**: 这是最常见的方法,通过设置Cookie的`Domain`属性来实现。将Session ID存储在Cookie中,并设置Cookie的域为父域,如`....
Tomcat 之间的 Session 共享 Tomcat 之间的 Session 共享是指在分布式 Tomcat 环境中,多个 Tomcat 实例...Tomcat 之间的 Session 共享是分布式 Tomcat 环境中的一种重要机制,可以提高系统的可用性、性能和可扩展性。
在Java_session共享配置中,Jedis负责在Tomcat服务器之间同步session数据,将用户的session信息存储在Redis中,而不是传统的基于Cookie或服务器内存的方式。 最后,`kuanrf-tomcat-redis-session-manage-1.0.jar`是...
为了解决这个问题,我们可以采取以下几种策略: 1. **Session复制**:这是一种简单的解决方案,即每当一个服务器上的Session数据发生变化时,都会广播这个变化到所有其他服务器。这种做法要求服务器之间有高效的...
处理Session跨域问题通常涉及到多个网站或应用之间共享用户身份验证信息。Session是Web应用程序用来存储用户特定数据的一种机制,通常存储在服务器端,而Session ID通过Cookie在客户端与服务器之间传递。当用户在...
以下是几种常见的Session共享方法: 1. **粘性会话(Sticky Sessions)**:这是最简单的实现方式,负载均衡器会记住用户第一次访问哪个服务器,然后将所有后续请求路由到同一台服务器。这种方法简单但不健壮,如果...
实现跨域名的Session共享主要依赖于以下几个关键技术和方法: 1. **Cookie的Domain属性**:默认情况下,Cookie只能由设置它的域名读取。但通过设置Cookie的`Domain`属性,可以让其他子域或指定域读取到这个Cookie。...
Tomcat提供了以下几种Session共享策略: 1. **粘滞会话(Sticky Sessions)**:这是最简单的解决方案,通过负载均衡器将用户的请求定向到最初创建Session的服务器。虽然实现简单,但可能会导致服务器负载不均,且当...
可以采用以下几种方式实现Nginx+Tomcat的Session共享: 1. Sticky Session:通过Nginx配置,确保用户的所有请求都路由到最初处理其请求的Tomcat实例。 2. 共享存储:使用Redis、Memcached等缓存服务作为共享存储,将...