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对应的请求是不是都落一台)。

相关推荐
Debug 熊猫2 小时前
Nginx代理快速入门(结合vue3简单项目讲解)
运维·nginx
兔子零10243 小时前
nginx 配置长跑(下):全局变量、调试思路与可观测性
后端·nginx
小小哭包13 小时前
Nginx配置文件nginx.conf中文详解
运维·nginx
weixin_4316972013 小时前
onlyoffice预览nginx代理的静态文件
运维·nginx
6***A66313 小时前
Nginx 反向代理配置
运维·nginx
pcc_is_world20 小时前
Nginx HTTPS服务器搭建与认证配置
服务器·nginx·https
wadesir1 天前
Nginx反向代理错误处理(从零开始配置自定义错误页面与故障应对)
运维·nginx
半路_出家ren1 天前
LNMP环境与应用配置
linux·数据库·mysql·nginx·网络安全·php·lnmp
摸鱼的后端1 天前
nginx systemctl 命令 开机自启
运维·nginx