解决nginx负载均衡的session共享问题
PHP服务器有多台,用nginx做负载均衡,这样同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说登录
1、不使用session,换用cookie
session是存放在服务器端的,cookie是存放在客户端的,可以把用户访问页面产生的session放到cookie里面,就是以cookie为中转站。
访问web服务器A,产生了session然后把它放到cookie里面,当你的请求被分配到B服务器时,服务器B先判断服务器有没有这个session,如果没有,再去看看客户端的cookie里面有没有这个session,如果也没有,说明session真的不存,如果cookie里面有,就把cookie里面的sessoin同步到服务器B,这样就可以实现session的同步了。
说明:
这种方法实现起来简单,方便,也不会加大数据库的负担,但是如果客户端把cookie禁掉了的话,那么session就无从同步了,这样会给网站带来损失;cookie的安全性不高,虽然它已经加了密,但是还是可以伪造的。
在集群系统中不能用session,否则惹出祸端来就不好办。如果系统不复杂,就优先考虑能否将session去掉
2、session存在数据库(MySQL等)中
可以配置将session保存在数据库中,这种方法是把存放session的表和其他数据库表放在一起,如果mysql也做了集群了话,每个mysql节点都要有这张表,并且这张session表的数据表要实时同步。
说明:
用数据库来同步session,会加大数据库的IO,增加数据库的负担。而且数据库读写速度较慢,不利于session的适时同步。
适用于较为严格但请求量不高的场合
3、session存在memcache或者redis中
memcache可以做分布式,php配置文件中设置存储方式为memcache,这样php自己会建立一个session集群,将session数据存储在memcache中。
说明:
以这种方式来同步session,不会加大数据库的负担,并且安全性比用cookie大大的提高,把session放到内存里面,比从文件中读取要快很多。
但是memcache把内存分成很多种规格的存储块,有块就有大小,这种方式也就决定了,memcache不能完全利用内存,会产生内存碎片,如果存储块不足,还会产生内存溢出。
4、nginx中的ip_hash技术
该技术能够将某个ip的请求定向到同一台后端,这样一来这个ip下的某个客户端和某个后端就能建立起稳固的session
ip_hash是在upstream配置中定义
upstream nginx.example.com { server 192.168.74.235:80; server 192.168.74.236:80; ip_hash; } server { listen 80; location / { proxy_pass http://nginx.example.com; } }
因为仅能用ip这个因子来分配后端,因此ip_hash不能在下列情况下使用:
(1)nginx不是最前端的服务器。
ip_hash要求nginx一定是最前端的服务器,否则nginx得不到正确ip,就不能根据ip作hash
譬如使用的是squid为最前端,那么nginx取ip时只能得到squid的服务器ip地址,用这个地址来作分流是肯定错乱的。
(2)nginx的后端还有其它方式的负载均衡
如果nginx后端又有其它负载均衡,将请求又通过另外的方式分流了,那么某个客户端的请求肯定不能定位到同一台session应用服务器上。
nginx后端只能直接指向应用服务器,或者再搭一个squid,然后指向应用服务器。
最好的办法是用 location作一次分流,将需要session的部分请求通过ip_hash分流,剩下的走其它后端去。
5、upstream_hash
使用upstream_hash这个第三方模块,这个模块多数情况下是用作url_hash的,可以它用来做session共享
相关文章
- Nginx的负载均衡的几种方式
- 查询系统负载信息 Linux 命令详解
- Koordinator v1.1发布:负载感知与干扰检测采集
- 借助LVS+Keepalived实现负载均衡(转)
- lvs、haproxy、nginx 负载均衡的比较分析(转)
- 淘宝网采用什么技术架构来实现网站高负载的(转)
- nginx集群:nginx配置负载均衡集群(nginx1.18.0)
- EasyDarwin开源流媒体云平台设计与实现(分布式+负载均衡)
- java:tomcat(负载均衡)nginx的应用配置
- 简单讲解一下负载均衡、反向代理模式的优点、缺点
- nginx负载均衡配置
- SpringCloud 网关和应用的负载均衡
- Atitit 稳定性提升的艺术 之技术解决之道 目录 1. 2. 为什么会发生稳定性问题11 2. 大原则1 2.1. 尽快释放资源类似php最好的稳定性1 2.2. Nginx 负载均衡
- 【Nginx】负载均衡——ip_hash
- 云图说 | 3分钟创建一个游戏类工作负载
- 【Nginx】面试官:给我讲讲Nginx如何实现四层负载均衡?
- 【Nginx】如何使用Nginx实现MySQL数据库的负载均衡?看完我懂了!!
- IIS负载均衡-Application Request Route详解第一篇: ARR介绍
- 网站架构(页面静态化,图片服务器分离,负载均衡)方案全解析
- Nginx---负载均衡和缓存
- 【Nginx笔记01】Nginx配置文件介绍、反向代理、负载均衡
- 【微服务】SpringCloud中使用Ribbon实现负载均衡的原理
- 【Nginx】负载均衡——ip_hash
- 【Nginx】入门看这一篇就够啦,nginx 简介、安装、工作原理、工作方式、详解配置文件
- 一文聊透负载均衡神器 LVS、Nginx、HAProxy的工作原理
- Nginx的反向代理与负载均衡