Nginx反向代理实现会话(session)保持的两种方式 (转)

Posted crazyYong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nginx反向代理实现会话(session)保持的两种方式 (转)相关的知识,希望对你有一定的参考价值。

http://blog.csdn.net/gaoqiao1988/article/details/53390352

 

一、ip_hash:

ip_hash使用源地址哈希算法,将同一客户端的请求总是发往同一个后端服务器,除非该服务器不可用。

ip_hash语法:

upstream backend {    ip_hash;
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com down;
    server backend4.example.com;
}

ip_hash简单易用,但有如下问题:

  • 当后端服务器宕机后,session会丢失;

  • 来自同一局域网的客户端会被转发到同一个后端服务器,可能导致负载失衡;

  • 不适用于CDN网络,不适用于前段还有代理的情况。

二、sticky_cookie_insert:

使 用sticky_cookie_insert启用会话亲缘关系,这会导致来自同一客户端的请求被传递到一组服务器在同一台服务器。与ip_hash不同之 处在于,它不是基于IP来判断客户端的,而是基于cookie来判断。因此可以避免上述ip_hash中来自同一局域网的客户端和前段代理导致负载失衡的 情况。

语法:

upstream backend {
    server backend1.example.com;
    server backend2.example.com;    sticky_cookie_insert srv_id expires=1h domain=xxxx.com path=/;}

说明:

  • expires:设置浏览器中保持cookie的时间

  • domain:定义cookie的域

  • path:为cookie定义路径

另外还可以使用后端服务器自身通过相关机制保持session同步,后面会详细介绍!

 

以上是关于Nginx反向代理实现会话(session)保持的两种方式 (转)的主要内容,如果未能解决你的问题,请参考以下文章

Nginx反向代理+Tomcat+memcached实现session server

Udp的反向代理:nginx

实现tomcat基于session会话保持

分布式环境下,如何实现session共享

Nginx+Redis实现反向代理和Session共享

Nginx+Tomcat+Memcached实现会话保持