Him*_*mel 12 nginx load-balancing sticky-sessions
我有一个运行在两个不同 AWS 实例上的应用程序,我想启用基于 IP 的“粘性”或“持久”会话,以便我可以以特定方式利用 Web 套接字技术。
我有两种不同的设置,都涉及ip_hash用于启用这些粘性会话。
在第一个设置中,应用程序进程与 Nginx 配置在同一实例上运行。这是有效的,会话按预期持续存在。
upstream my_app {
ip_hash;
# local servers
server 127.0.0.1:3001 weight=100 max_fails=5 fail_timeout=300;
server 127.0.0.1:3002 weight=100 max_fails=5 fail_timeout=300;
keepalive 8;
}
Run Code Online (Sandbox Code Playgroud)
在第二个设置中,我指向外部实例并试图达到相同的效果。此设置不起作用。换句话说,会话仍在进行负载平衡。
upstream my_app {
ip_hash;
# external servers
server 111.11.11.11:3001 weight=100 max_fails=5 fail_timeout=300;
server 222.22.22.22:3002 weight=100 max_fails=5 fail_timeout=300;
keepalive 8;
}
Run Code Online (Sandbox Code Playgroud)
我使用ip_hash正确吗?如何为外部服务器启用“粘性”基于 ip 的会话?
我的服务器支持 AWS 负载平衡,因此我需要将正确的标头传递给上游,以便它始终反映客户端 IP。以下配置解决了我的问题(请参阅注释行):
upstream my_app {
ip_hash;
server 111.11.11.11:3001 weight=100 max_fails=5 fail_timeout=300;
server 222.22.22.22:3002 weight=100 max_fails=5 fail_timeout=300;
keepalive 8;
}
server {
server_name my-app.com;
location / {
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header X-Real_IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
# This is necessary to pass the correct IP to be hashed
real_ip_header X-Real-IP;
proxy_pass http://my_app/;
proxy_redirect off;
}
}
Run Code Online (Sandbox Code Playgroud)
根据 Nginx 文档,粘性会话支持仅适用于其昂贵的 Plus 版本。我一直在研究替代方案,而且我越接近这个旧叉子,它与 Nginx 1.5+ 不兼容https://github.com/lusis/nginx-sticky-module
我还尝试构建一个 LUA 模块,但没有用于对等选择的 API 挂钩,仅用于枚举和阻塞。
更新
我发现了另一个很棒的模块,请参阅https://bitbucket.org/nginx-goodies/nginx-sticky-module-ng/src