nginx-sticky怎么用 Nginx 负载均衡添加 sticky 模块完整步骤

第一步:先搞懂这是啥

nginx-sticky是个能让用户每次访问都落到同一台后端服务器的插件(比如你有好几台Tomcat/Node服务器,用它就能让用户一直连其中一台)。解压后一般是 .c文件(比如 ngx_http_sticky_module.c)和说明文档。

第二步:准备环境(必须装这些!)

  1. 装Nginx源码 :去 Nginx官网下和你现在用的Nginx版本一致的源码(别版本对不上,不然编译会炸),nginx-sticky安装包下载: pan.quark.cn/s/ed2504ebd...

  2. 装依赖工具 :编译需要 gccmakepcre-devel(正则支持)、zlib-devel(压缩支持),Linux直接敲:

    csharp 复制代码
    # CentOS/RHEL
    yum install gcc make pcre-devel zlib-devel -y
    # Ubuntu/Debian
    apt-get install gcc make libpcre3-dev zlib1g-dev -y

第三步:把插件编进Nginx里

假设你的Nginx安装在 /usr/local/nginx,源码放在 /opt/nginx-1.20.2,插件解压在 /opt/nginx-sticky

  1. 进Nginx源码目录

    bash 复制代码
    cd /opt/nginx-1.20.2
  2. 配置编译参数(关键!)

    先看看你原来的Nginx编译了啥参数(记下来!):

    bash 复制代码
    /usr/local/nginx/sbin/nginx -V  # 注意是大写V,会输出 --prefix=/usr/local/nginx ... 这些

    然后复制这些参数,加上插件的路径,执行 ./configure。比如原来参数是 --prefix=/usr/local/nginx,现在加插件的路径(假设插件 .c文件在 /opt/nginx-sticky):

    javascript 复制代码
    ./configure --prefix=/usr/local/nginx [你原来的其他参数] --add-module=/opt/nginx-sticky

    [你原来的其他参数]就是 -V输出的那些,比如 --with-http_ssl_module之类的,别漏!)

  3. 编译安装

    go 复制代码
    make  # 只编译,别make install!不然会覆盖原Nginx

    编译完,把新生成的 objs/nginx替换原来的Nginx可执行文件(记得先停Nginx!):

    bash 复制代码
    # 停Nginx(如果开着的话)
    /usr/local/nginx/sbin/nginx -s stop
    # 备份原Nginx(以防翻车)
    cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak
    # 替换成新的
    cp objs/nginx /usr/local/nginx/sbin/nginx

第四步:改Nginx配置文件

打开你的Nginx配置文件(一般在 /usr/local/nginx/conf/nginx.conf),在 upstream块里加 sticky;(就这么简单!)。

举个栗子:

ini 复制代码
http {
    upstream my_servers {  # 你的后端服务器组
        server 192.168.1.10:8080;
        server 192.168.1.11:8080;
        sticky;  # 加上这句,启用粘性会话
        # 可选参数:比如 sticky expires=1h domain=.example.com path=/;
        # expires 是cookie过期时间,domain/path 是cookie作用域
    }

    server {
        listen 80;
        location / {
            proxy_pass http://my_servers;  # 代理到上面的upstream
        }
    }
}

第五步:测试能不能用

  1. 检查配置有没有错

    bash 复制代码
    /usr/local/nginx/sbin/nginx -t

    显示 oksuccessful就没问题。

  2. 启动/重启Nginx

    bash 复制代码
    /usr/local/nginx/sbin/nginx  # 启动
    # 或者重启:/usr/local/nginx/sbin/nginx -s reload
  3. 验证效果

    开两个浏览器(或清缓存),反复刷新页面,看是不是一直访问同一台后端服务器(可以看后端服务器的日志,比如Tomcat的 localhost_access_log,IP对应的请求是不是都落一台)。

相关推荐
@22068 小时前
银河麒麟系统离线环境下用docke方式部署(Postgres、Nginx、Redis、JDK)
运维·数据库·redis·nginx
戈壁老孙11 小时前
使用Nginx实现动态后端服务切换:一套配置管理多环境
运维·nginx
天天天天学习丶13 小时前
Nginx 域名解析后默认打开其他项目问题解决方案
nginx
取谖慕12.13 小时前
keepailved+nginx+nfs高可用
运维·nginx·nfs
小Ti客栈14 小时前
Nginx进阶配置实战全攻略:SSL部署、防盗链、压缩、代理、限流、请求合并
nginx·负载均衡·ssl
岁岁种桃花儿16 小时前
深入理解 Keepalive:从协议到 Nginx 实战(全场景解析)
运维·nginx
康小庄16 小时前
通过NGINX实现将小程序HTTPS请求转为内部HTTP请求
java·spring boot·nginx·spring·http·小程序
牵牛老人16 小时前
Qt后端开发遇到跨域问题终极解决方案 与 Nginx反向代理全解析
qt·nginx·状态模式
小目标一个亿1 天前
Windows平台Nginx配置web账号密码验证
linux·前端·nginx
养乐多q.♡1 天前
docker镜像的nginx配置证书SSL,单独配置单个localtion使用证书,其他nginx配置不影响
nginx·docker·ssl