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

nginx的中的ip_hash技术能够将某个IP的请求定向到同一台后端,这样一来这个IP下的某个客户端和某个后端就能建立起稳固的会话,ip_hash是在上游配置中定义的:

  1. nginx.example.com
  2. {
  3. 服务器192.168.74.235:80;
  4. 服务器192.168.74.236:80;
  5. ip_hash;
  6. }
  7. 服务器
  8. {
  9. 听80;
  10. 位置 /
  11. {
  12. proxy_pass
  13. http://nginx.example.com;
  14. }
  15. }

ip_hash是容易理解的,但是因为仅仅能用ip这个因子来分配后端,因此ip_hash是有缺陷的,不能在一些情况下使用:
1.nginx不是最前端的服务器。

ip_hash要求nginx的一定是最前端的服务器,否则nginx的得不到正确的IP,就不能根据IP作哈希。譬如使用的是鱿鱼为最前端,那么nginx的取IP时只能得到鱿鱼的服务器的IP地址,用这个地址来作分流是肯定错乱的
.2.nginx的后端还有其它方式的负载均衡。

假如nginx的后端又有其它负载均衡,将请求又通过另外的方式分流了,那么某个客户端的请求肯定不能定位到同一台会议应用服务器上。这么算起来,nginx的后端只能直接指向应用服务器,或者再搭一个squid,然后指向应用服务器。最好的办法是用位置作一次分流,将需要会话的部分请求通过ip_hash分流,剩下的走其它后端去。

5,upstream_hash
为了解决ip_hash的一些问题,可以使用upstream_hash这个第三方模块,这个模块多数情况下是用作url_hash的,但是并不妨碍将它用来做会话共享。没试过真心的不明白

补充:memcached的简单的介绍

一,概念

Memcached的是danga.com(运营的LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升性能。

二,适用场合

1.分布式应用。由于memcached本身基于分布式的系统,所以尤其适合大型的分布式系统。

2.数据库前段缓存。数据库常常是网站系统的瓶颈。数据库的大并发量访问,常常造成网站内存溢出。当然我们也可以使用Hibernate的缓存机制。但memcached是基于分布式的,并可独立于网站应用本身,所以更适合大型网站进行应用的拆分。

3.服务器间数据共享。举例来讲,我们将网站的登录系统,查询系统拆分为两个应用,放在不同的服务器上,并进行集群,放这个时候用户登录后,登录信息如何从登录系统服务器同步到查询系统服务器呢?这时候,我们便可以使用memcached的,登录系统将登录信息缓存起来,查询系统便可以获得登录信息,就像获取本地信息一样。

三,不适用场合

那些不需要“分布”的,不需要共享的,或者干脆规模小到只有一台服务器的应用,memcached的不会带来任何好处,相反还会拖慢系统效率,因为网络连接同样需要资源

 

解决方案,使用memcached的做为会话的存储,memcached的服务器设置在和nginx的同一台Linux的主机上。

解决过程,

两台apache的主机IP分别是192.168.74.235192.168.74.236

Nginx的主机IP是192.168.74.131

Memcached的主机的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.ini

session.save_handler = memcache

session.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_age  Pages   Count   Full? Evicted Evict_Time OOM

在236机器上添加下面的php文件

<?php

session_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_age  Pages   Count   Full? Evicted Evict_Time OOM

 1      80B         0s       1      0      no        0       0    0

这样应该就算可以把session写到memcached服务器上了。

总结下:

1.      防火墙问题,很多连接局域网服务器失败都是防火墙引起的

2.      依赖没有安装完毕,一开始使用memcached总失败,因为我没有安装php-memcached这样的扩展库

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值