ソースを参照

Fix 修复sse长连接使用nginx经常断开连接的问题

Yue 8 ヶ月 前
コミット
1579b9df08

+ 39 - 0
SERVER/VberAdminPlusV3/.script/docker/nginx/conf/default.conf

@@ -61,6 +61,8 @@ server {
         try_files $uri =404;
         try_files $uri =404;
     }
     }
 
 
+
+
     location /prod-api/ {
     location /prod-api/ {
         proxy_set_header Host $http_host;
         proxy_set_header Host $http_host;
         proxy_set_header X-Real-IP $remote_addr;
         proxy_set_header X-Real-IP $remote_addr;
@@ -70,9 +72,46 @@ server {
         proxy_http_version 1.1;
         proxy_http_version 1.1;
         proxy_set_header Upgrade $http_upgrade;
         proxy_set_header Upgrade $http_upgrade;
         proxy_set_header Connection "upgrade";
         proxy_set_header Connection "upgrade";
+
         proxy_pass http://server/;
         proxy_pass http://server/;
     }
     }
 
 
+    # 针对 SSE 的特殊配置
+    location /prod-api/resource/sse {
+        proxy_set_header Host $http_host;
+        proxy_set_header X-Real-IP $remote_addr;
+        proxy_set_header REMOTE-HOST $remote_addr;
+        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+
+        # 1. 彻底禁用所有缓冲和压缩(关键修复)
+        proxy_buffering off;           # 禁用代理缓冲(必须)
+        proxy_request_buffering off;   # 禁用请求缓冲
+        proxy_cache off;               # 禁用缓存
+        gzip off;                      # 显式禁用gzip(避免压缩分块数据)
+        proxy_set_header Accept-Encoding "";  # 告诉后端不接受压缩数据
+
+        # 2. 延长超时时间(确保长连接不被Nginx主动关闭)
+        proxy_connect_timeout 3600s;   # 连接建立超时(1小时,远超业务需求)
+        proxy_send_timeout 3600s;      # 发送数据超时
+        proxy_read_timeout 3600s;      # 读取后端响应超时(核心:SSE长连接必须足够长)
+        send_timeout 3600s;            # 向客户端发送数据超时(补充配置)
+
+        # 3. HTTP/1.1 长连接配置(修复连接被强制关闭的问题)
+        proxy_http_version 1.1;        # 强制HTTP/1.1(分块传输依赖)
+        proxy_set_header Connection "";  # 清除Connection头,避免Nginx注入"close"
+
+        # 4. SSE响应头(添加always参数,确保所有状态码都生效)
+        add_header 'Content-Type' 'text/event-stream' always;
+        add_header 'Cache-Control' 'no-cache, no-store' always;  # 彻底禁用缓存
+        add_header 'Connection' 'keep-alive' always;
+        add_header 'X-Accel-Buffering' 'no' always;  # 额外禁用Nginx的加速缓冲(关键)
+
+        tcp_nodelay on;  # 确保数据立即发送
+
+        proxy_pass http://server/resource/sse;
+    }
+
+
     # https 会拦截内链所有的 http 请求 造成功能无法使用
     # https 会拦截内链所有的 http 请求 造成功能无法使用
     # 解决方案1 将 admin 服务 也配置成 https
     # 解决方案1 将 admin 服务 也配置成 https
     # 解决方案2 将菜单配置为外链访问 走独立页面 http 访问
     # 解决方案2 将菜单配置为外链访问 走独立页面 http 访问