文章摘自:https://www.jb51.net/article/170410.htm
1.0 为什么需要session共享
当我们的网站用户越来越多,为满足并发访问,就会对网站服务器进行集群(负载均衡、分布式),那么问题随之而来,网站用户的登录权限都是存放在当时所访问的服务器上,其他服务器没有保存或保存的数据不一样。 当一个用户第一次 访问的是A应用服,而第二次访问分发到了B应用服,那么B应用服的session数据与A应用服没有同步。所以需要进行session同步处理。
1.1 PHP的session原理
客户端访问php页面,执行session_start,生成session_id,一般我们是把session_id存储到cookie上,session内容保存在服务端,客户端访问访问不同的页面都会把session_id传到服务端,通过session_id来获取session内容。
流程是这样,可是不同的服务器会对同一个客户端产生不同的session_id,这样的话不同服务器就不能得到相同的session内容。而且PHP 默认的 SESSION 数据都是分别保存在本服务器的文件系统中。
1.2 session共享需要解决两个问题:
1.2.1 多台服务器用同一个session_id
这个比较容易解决,只要在php中设置存session_id的cookie域名为网站主域就可以打开PHP.ini, 设置session.cookie_domain = .feiniu.com,当然也可以在php代码当中设置ini_set("session.cookie_domain","feiniu.com");
1.2.2 多台服务器用同一个session_id访问到相同的session内容
要实现这点,就必须把session内容存储到让所有服务器都能访问到的地方,php的session内容是默认存储到本服务器的文件中的,一般的解决方案是存入数据库,memcache或者redis这种缓存服务器,当然用默认的文件存储方式也可以,用NFS统一存储。
1.3 选择session数据存储方式
redis存储:与memcache相比,redis访问稍稍慢一点点,好处是:
redis支持的数据结构较多,可以存储数组或对象,而memcache只能存储字符串。
在session机器重启的情况下,memcache所有用户都必须重新获得 session,而redis不会。3.在突然涌来大量用户产生了很多数据把
存储 session 的机器内存占满了的情况下,memcache会罢工,所有key都没过期的话就不停的覆盖最后写入的数据,而redis只是会变
慢,不会影响程序的逻辑