负载均衡时,为了保证同一用户session会被分配到同一台服务器上,可以使用以下方法:
1.使用cookie
将用户的session存入cookie里,当用户分配到不同的服务器时,先判断服务器是否存在该用户的session,如果没有就先把cookie里面的sessoin存入该服务器,实现session会话保持。缺点是存入cookie有安全隐患。
https://blog.csdn.net/IT_ZRS/article/details/108552363
2.使用缓存
利用memcache,Redis等缓存分布式的特点,可以将所有服务器产生的session存入同一台服务器的缓存中,实现session共享。这样安全性比较高,而且从内存中读取session比从文件中读取速度快。
3.使用ip_hash
如果是nginx服务器的负载均衡,可以在upstream里设置ip_hash,每个请求按访问ip的hash结果分配,映射到固定某一台的服务器。缺点是可能导致负载不均衡。
upstream test {
ip_hash;
server 10.20.151.112:80;
server 10.20.151.113:80;
}
本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Nginx负载均衡session会话保持方法 - Python技术站