【部署】Nginx长连接配置
nginx upstream keepalive connections
Nginx從 1.1.4 開始,實現了對后端機器的長連接支持,這是一個激動人心的改進,這意味著 Nginx 與后端機器的通信效率更高,后端機器的負擔更低。
例如,對一個沒有長連接支持的后端機器,會出現大量TIME_WAIT 狀態的連接,使用以下命令驗證之:
netstat -n | grep TIME_WAIT
經過查閱官方文檔,其目前已經實現了http, fastcgi, memcache 協議的長連接支持。而之前的版本中僅支持 memcache 協議。
1. 啟用到 memcache 服務器的長連接
在upstream 配置段中增加 keepalive N 指令即可:
upstream memcached_backend {
server 127.0.0.1:11211;
server 10.0.0.2:11211;
keepalive 32;
}
server {
...
location /memcached/ {
set $memcached_key $uri;
memcached_pass memcached_backend;
}
}
2. 啟用fastcgi 長連接支持
除了需要在upstream 中配置 keepalive N 外,還需要在 location 中增加 fastcgi_keep_conn on;
upstream fastcgi_backend {
server 127.0.0.1:9000;
keepalive 8;
}
server {
...
location /fastcgi/ {
fastcgi_pass fastcgi_backend;
fastcgi_keep_conn on;
...
}
}
3. 啟用對后端機器HTTP 長連接支持
upstream http_backend {
server 127.0.0.1:8080;
keepalive 16;
}
server {
...
location /http/ {
proxy_pass http://http_backend;
proxy_http_version 1.1;
proxy_set_header Connection "";
...
}
}
注意:需要設置nginx 代理請求的 http 協議版本號為 1.1, 以及清除掉 Connection 請求 header, 官方文檔描述:
For HTTP, the proxy_http_version directive should be set to “ 1.1 ” and the “ Connection ” header field should be cleared .
The connections parameter should be set low enough to allow upstream servers to process additional new incoming connections as well.
即是說:keepalive N 指令中 , N 的值應該盡可能設置小一些,以便后端機器可以同時接受新的連接。
在我負責的生產環境中,前端是nginx, 靜態文件緩存使用 varnish, 使用長連接之后, varnish 機器的連接數從 8000 多下降至 200 多,負載值也有明顯降低。
但是針對fastcgi, 即后端機器是 php-fpm 服務時,在 nginx 日志中出現以下錯誤:
upstream sent unsupported FastCGI protocol version: 0 while reading upstream 。 ? ?
【補充】應用解決實際問題:
背景:某系統集成外部模塊(前后端分離頁面),系統攔截該模塊所有發起的http請求(代理),通過后端向目標請求發起(避免跨域問題),此時外部模塊頁面,系統攔截,系統后端之間的通訊需要持續,此時應用:啟用對后端機器HTTP 長連接支持,否則頁面上http請求報錯一般為: status(failed), 502, 沒有respond信息。 解決方案:nginx長連接配置
?
介紹設置內容轉載:?https://www.cnblogs.com/huanxiyun/articles/6645239.html
總結
以上是生活随笔為你收集整理的【部署】Nginx长连接配置的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【项目管理】成本管理
- 下一篇: Nginx —— 检查配置文件ngi