转载
一、问题起源
大型网站通常有多个服务器,并且使用多个二级域名。这样一台服务器产生的session就不能为所有服务器所共享。这样用户在一个地方登录就不能全部通行
(以下来自http://nio.infor96.com/sharing-php-session-data-between-servers ,我略作修改)
二、PHP SESSION 的工作原理
在解决问题之前,先来了解一下 PHP SESSION 的工作原理。在客户端(如浏览器)登录网站时,被访问的 PHP 页面可以使用 session_start() 打开 SESSION,这样就会产生客户端的唯一标识 SESSION ID(此 ID 可通过函数 session_id() 获取/设置)。SESSION ID 可以通过两种方式保留在客户端,使得请求不同的页面时,PHP 程序可以获知客户端的 SESSION ID;一种是将 SESSION ID 自动加入到 GET 的 URL 中,或者 POST 的表单中,默认情况下,变量名为 PHPSESSID;另一种是通过 COOKIE,将 SESSION ID 保存在 COOKIE 中,默认情况下,这个 COOKIE 的名字为 PHPSESSID。这里我们主要以 COOKIE 方式进行说明,因为应用比较广泛。
那么 SESSION 的数据保存在哪里呢?当然是在服务器端,但不是保存在内存中,而是保存在文件或数据库中。默认情况下,php.ini 中设置的 SESSION 保存方式是 files(session.save_handler = files),即使用读写文件的方式保存 SESSION 数据,而 SESSION 文件保存的目录由 session.save_path 指定,文件名以 sess_ 为前缀,后跟 SESSION ID,如:sess_c72665af28a8b14c0fe11afe3b59b51b。文件中的数据即是序列化之后的 SESSION 数据了。如果访问量大,可能产生的 SESSION 文件会比较多,这时可以设置分级目录进行 SESSION 文件的保存,效率会提高很多,设置方法为:session.save_path="N;/save_path",N 为分级的级数,save_path 为开始目录。当写入 SESSION 数据的时候,PHP 会获取到客户端的 SESSION_ID,然后根据这个 SESSION ID 到指定的 SESSION 文件保存目录中找到相应的 SESSION 文件,不存在则创建之,最后将数据序列化之后写入文件。读取 SESSION 数据是也是类似的操作流程,对读出来的数据需要进行解序列化,生成相应的 SESSION 变量。
三、多服务器共享 SESSION 的主要障碍及解决办法
通过了解 SESSION 的工作原理,我们可以发现,在默认情况下,各个服务器会各自分别对同一个客户端产生 SESSION ID,如对于同一个用户浏览器,A 服务器产生的 SESSION ID 是 30de1e9de3192ba6ce2992d27a1b6a0a,而 B 服务器生成的则是 c72665af28a8b14c0fe11afe3b59b51b。另外,PHP 的 SESSION 数据都是分别保存在本服务器的文件系统中。如下图所示:
确定了问题所在之后,就可以着手进行解决了。想要共享 SESSION 数据,那就必须实现两个目标:一个是各个服务器对同一个客户端产生的 SESSION ID 必须相同,并且可通过同一个 COOKIE 进行传递,也就是说各个服务器必须可以读取同一个名为 PHPSESSID 的 COOKIE;另一个是 SESSION 数据的存储方式/位置必须保证各个服务器都能够访问到。简单地说就是多服务器共享客户端的 SESSION ID,同时还必须共享服务器端的 SESSION 数据。
第一个目标的实现其实很简单,只需要对 COOKIE 的域(domain)进行特殊地设置即可,默认情况下,COOKIE 的域是当前服务器的域名/IP 地址,而域不同的话,各个服务器所设置的 COOKIE 是不能相互访问的,如 www.aaa.com 的服务器是不能读写 www.bbb.com 服务器设置的 COOKIE 的。这里我们所说的同一网站的服务器有其特殊性,那就是他们同属于同一个一级域,如:aaa.infor96.com 和 www.infor96.com 都属于域 .infor96.com,那么我们就可以设置 COOKIE 的域为 .infor96.com,这样 aaa.infor96.com、www.infor96.com 等等都可以访问此 COOKIE。PHP 代码中的设置方法如下:
<?phpini_set('session.cookie_domain', '.infor96.com');?>这样各个服务器共享同一客户端 SESSION ID 的目的就达到了。
第二个目标的实现可以使用文件共享方式,如 NFS 方式,但设置、操作上有些复杂。我们可以将数据放在memcache中。这样各个服务器就可以方便地访问同一个数据源,获取相同的 SESSION 数据了。
具体方法可以参考我的另一篇文章:http://blog.chinaunix.net/u/16928/showart_1737426.html
解决办法如下图所示:
详细可以参考:http://www.dabaoku.com/jiaocheng/biancheng/php/200910091037.shtml
分享到:
相关推荐
以下详细阐述了如何使用PHP实现多服务器共享SESSION数据的技术知识点。 首先,要理解PHP默认的SESSION管理机制是使用session.save_handler配置项指定的处理器来读写存储在session.save_path配置项指定的目录下的...
2. **共享SESSION数据存储**:数据存储位置必须可被所有服务器访问。这通常涉及到改变默认的SESSION存储机制,比如从文件系统改为数据库,或者使用分布式缓存系统如Redis或Memcached。这样,无论哪个服务器接收到...
2. 配置Redis服务器,用于存储Session数据。 3. 在应用程序中使用Spring Session代替传统的HTTPSession。 4. 使用Nginx或其他反向代理服务器来管理多个实例,并将请求分发到不同的实例上。 结论 Springboot实现...
PHP 实现多服务器共享 SESSION 数据 一、问题起源 稍大一些的网站,通常都会有好几个服务器,每个服务器运行着不同功能的模块,使用不同的二级域名,而一个整体性强的网站,用户系统是统一的,即一套用户名、密码...
【PHP 实现多服务器共享 SESSION 数据】 在大型网站的架构中,往往会有多个服务器负责不同的功能模块,每个服务器都有自己的二级域名。为了提供统一的用户体验,用户在一个服务器上登录后,应该能够在其他服务器上...
在构建大型分布式Web应用时,实现多服务器共享SESSION数据是一个重要的需求,因为它能确保用户在登录后可以在所有服务器间自由切换而无需重新登录。本文将以Zend Framework为例,深入讲解如何在多服务器环境中实现...
"PHP实现多服务器session共享之memcache共享"的主题着重于如何在多台服务器之间有效地存储和同步用户的session数据,以确保用户在不同服务器间的会话状态能够保持一致。本文将深入探讨这一主题,并围绕相关知识点...
"PHP_实现多服务器共享_SESSION_数据"的主题聚焦于如何在多台PHP服务器之间有效地共享SESSION数据,以便用户在不同服务器间切换时仍能保持登录状态和其他个性化设置。这涉及到网络架构、会话管理以及数据存储等多个...
但这仅解决了部分问题,如果所有服务器需要共享Session数据,还需要更复杂的解决方案。 描述中提到的“jar包”,很可能是指实现Session共享的中间件,如Redis或Memcached。这些缓存服务可以作为一个集中式的Session...
具体的实现细节和技术选型需要结合项目实际情况来确定,例如《多台服务器共享SESSION - 学在囧途的日志 - 网易博客》和《多服务器共享session的方法》这两篇文章可能提供了更深入的实践案例和技术解析,值得进一步...
现在,PHP会将session数据存储在memcached服务器上,而不是本地文件系统,从而实现了跨服务器的session共享。 然而,值得注意的是,memcached不保证数据持久性,如果服务器崩溃,可能会丢失session数据。因此,对于...
本文将深入探讨如何通过memcache在多服务器之间共享session。 首先,我们需要理解memcache的基本原理。Memcache是一个高性能的分布式内存对象缓存系统,它能存储键值对数据,常用于减轻数据库负载,提高网站的响应...
"nginx+tomcat shiro实现多tomcat下session共享"这一主题,就是探讨在这样的架构中,如何有效管理和共享session。 1. **Nginx的作用**: Nginx是一个高性能的HTTP和反向代理服务器,常用于负载均衡,可以将用户的...
在分布式环境中,每个服务器节点都可能独立处理用户的请求,传统的Session存储方式(例如在单个服务器的内存中)无法满足需求,因为服务器之间无法共享Session信息。这就引入了Redis,它能够作为一个中央Session仓库...
在传统的Web应用中,Session信息通常存储在单个服务器的内存中,当应用部署在集群或者分布式环境时,不同服务器之间无法共享Session数据,导致用户在切换服务器时会丢失Session信息。Spring Session的出现,就是为了...
综上所述,跨域共享session涉及到多个技术层面,包括浏览器限制、服务器配置、前端处理和安全措施。实现HTTP到HTTPS的session共享需要综合考虑这些因素,并确保在提供便利的同时,保证用户数据的安全。
3. **共享数据库或缓存**:将Session数据存储在一个中央数据库或者如Redis、Memcached这样的分布式缓存系统中。每个域都可以访问这个共享存储来读写Session数据。这种方式灵活且可扩展性好,但需要处理数据同步和...