文章目录

nginx 会话保持

nginx会话保持主要有以下几种实现方式。

1、ip\_hash

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

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

ip\_hash简单易用,但有如下问题:

  • 当后端服务器宕机后,session会话丢失;
  • 同一客户端会被转发到同一个后端服务器,可能导致负载失衡;

2、sticky\_cookie\_insert

使用sticky\_cookie\_insert启用会话亲缘关系,这会导致来自同一客户端的请求被传递到一组服务器的同一台服务器。与ip\_hash不同之处在于,它不是基于IP来判断客户端的,而是基于cookie来判断。因此可以避免上述ip\_hash中来自同一客户端导致负载失衡的情况。(需要引入第三方模块才能实现)
sticky模块语法:


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

server {
    listen 80;
    server_name 3evip.cn;
    location / {
        proxy_pass http://backend;
    }
}

说明:

expires:设置浏览器中保持cookie的时间
domain:定义cookie的域
path:为cookie定义路径

3,jvm\_route

jvm\_route的原理

1, 一开始请求过来,没有带session信息,jvm\_route就根据轮询(round robin)的方法,发到一台tomcat上面。

2, tomcat添加上session 信息,并返回给客户。

3.,用户再此请求,jvm\_route看到session中有后端服务器的名称,它就把请求转到对应的服务器上。

标签: nginx, server, 服务器, http, ip, hash, 会话, cookie

相关文章推荐

添加新评论,含*的栏目为必填