session共享

4 篇文章 0 订阅
2 篇文章 0 订阅

文章摘自: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只是会变

慢,不会影响程序的逻辑

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值