解决nginx负载均衡的session共享问题

2025-07-26 00:31:45

1、nginx中的ip_hash技术能够将某个ip的请求定向到同一台后端,这样一来这个ip下的某个客户端和某个后端就能建立起稳固的session,ip_hash是在upstream配置中定义的

解决nginx负载均衡的session共享问题

2、ip_hash是容易理解的,但是因为仅仅能用ip这个因子来分配后端,因此ip_hash是有缺陷的,不能在一些情况下使用:1.nginx不是最前端的服务器。ip_hash要求n爿讥旌护ginx一定是最前端的服务器,否则nginx得不到正确ip,就不能根据ip作hash。譬如使用的是squid为最前端,那么nginx取ip时只能得到squid的服务器ip地址,用这个地址来作分流是肯定错乱的。2.nginx的后端还有其它方式的负载均衡。假如nginx后端又有其它负载均衡,将请求又通过另外的方式分流了,那么某个客户端的请求肯定不能定位到同一台session应用服务器上。这么算起来,nginx后端只能直接指向应用服务器,或者再搭一个squid,然后指向应用服务器。最好的办法是用 location作一次分流,将需要session的部分请求通过ip_hash分流,剩下的走其它后端去。5、upstream_hash为了解决ip_hash的一些问题,可以使用upstream_hash这个第三方模块,这个模块多数情况下是用作url_hash的,但是并不妨碍将它用来做session共享。没试过真心的不明白补充:memcached简单的介绍一、概念Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升性能。二、适用场合1. 分布式应用。由于memcached本身基于分布式的系统,所以尤其适合大型的分布式系统。2. 数据库前段缓存。数据库常常是网站系统的瓶颈。数据库的大并发量访问,常常造成网站内存溢出。当然我们也可以使用hibernate的缓存机制。但memcached是基于分布式的,并可独立于网站应用本身,所以更适合大型网站进行应用的拆分。3. 服务器间数据共享。举例来讲,我们将网站的登录系统、查询系统拆分为两个应用,放在不同的服务器上,并进行集群,那这个时候用户登录后,登录信息如何从登录系统服务器同步到查询系统服务器呢?这时候,我们便可以使用memcached,登录系统将登录信息缓存起来,查询系统便可以获得登录信息,就像获取本地信息一样。三、不适用场合那些不需要“分布”的,不需要共享的,或者干脆规模小到只有一台服务器的应用,memcached不会带来任何好处,相反还会拖慢系统效率,因为网络连接同样需要资源解决方案,使用memcached做为session的存储,memcached服务器设置在和nginx同一台Linux主机上。解决过程,两台apache的主机IP分别是 192.168.74.235192.168.74.236Nginx主机IP是192.168.74.131Memcached主机的IP是192.168.74.131在192.168.74.131 安装memcached,并且启动以一台为例192.168.74.236,安装php及php对memcached的依赖库yuminstall memcached-devel.i686 libmemcached-devel.i686 php-pecl-memcache.i686配置php.inisession.save_handler= memcachesession.save_path= "tcp://192.168.74.131:11211"或者(以下两个没有尝试)1.某个目录下的 .htaccess :php_value session.save_handler "memcache"php_value session.save_path "tcp://IP:11211"2.在某个一个应用中:ini_set("session.save_handler", "memcache");ini_set("session.save_path", "tcp://IP:11211");同时一定要把下面的;session.save_path= "/var/lib/php/session" 注释掉同时把extension=memcache.so 打开重启一下 apache,查看 phpinfo 中的 "Registered save handlers" 会有 "files usermemcache" 这3个可用,如果有就证明装好了Memcached服务器执行及结果[root@Git~]# memcached-tool127.0.0.1:11211# Item_Size Max_agePages Count Full?Evicted Evict_Time OOM在236机器上添加下面的php文件<?phpsession_start();if (!isset($_SESSION['TEST'])) {$_SESSION['TEST'] = time();}$_SESSION['TEST3'] = time();print $_SESSION['TEST'];print "<br><br>";print $_SESSION['TEST3'];print "<br><br>";print session_id();?>然后去memcached服务器上执行[root@Git ~]# memcached-tool127.0.0.1:11211# Item_Size Max_agePages Count Full?Evicted Evict_Time OOM1 80B 0s 10 no 00 0这样应该就算可以把session写到memcached服务器上了。总结下:1.防火墙问题,很多连接局域网服务器失败都是防火墙引起的2.依赖没有安装完毕,一开始使用memcached总失败,因为我没有安装php-memcached这样的扩展库

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
相关推荐
  • 阅读量:24
  • 阅读量:93
  • 阅读量:59
  • 阅读量:55
  • 阅读量:21
  • 猜你喜欢