Nginx 分布式session共享问题

在集群的时候每次访问,都会被代理转到不同的服务器,那么在这些服务器之间如何共享session?

  解决方式1:session复制

    只能在window下好使,web服务器解决(广播机制,将一台机器上的session数据广播复制到集群中其余机器上),但是网络开销大,性能低

1 修改tomcat的server.xml 支持共享
将引擎标签下的<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>注释打开
2 修改项目的配置文件web.xml中添加一个节点
  <distributable/>

  解决方式2:缓存集中式管理

    将session的id放入redis,用户访问时先从缓存中拿session信息

  解决方式3:粘性session

    保证一个ip地址永远只访问一台服务器,就不存在session共享的问题,但是在网络中有机器宕掉后,用户的session就会丢失,容易造成单点故障

在nginx.conf中:
upstream group{
server yy.com:8082;
  server yy.com:8083;
  ip_hash;
}
上一篇:codeforces983A(数学题)


下一篇:C51 玄学问题,magic