Https流式輸出一次輸出一大段,一卡一卡的-解決方案

【背景】

最近遇到一個奇怪的現象,前端vue,后端python,服務部署在服務器上面后,本來一切正常,但公司說要使用https訪問,想著也沒什么問題,切過去發現在沒有更改任何代碼的情況下,https的這個地址,流式輸出時,總是一卡一卡的,一次輸出一大段,而http這邊的地址,一切正常,輸出都是好著的,一個字一個字的崩,起初懷疑是證書的問題,更換證書后依舊卡頓。 經過curl命令排查, https請求時,后端響應明顯變慢,但是http正常, 排除代碼本身的原因。懷疑到nginx上后,經過一頓搜索,問題解決。

linux系統生成ssl證書后nginx配置可參考博主的另外一篇文章:

linux系統生成ssl證書后nginx配置_linux生成ssl pem-CSDN博客

先上解決辦法

server {listen 443 ssl;server_name example.com;ssl_certificate /path/to/cert.pem;ssl_certificate_key /path/to/key.pem;location /agent {proxy_pass http://backend;proxy_buffering off; # 關閉代理緩沖,確保流式傳輸}
}

核心配置:proxy_buffering off; # 關閉代理緩沖,確保流式傳輸

配置完后,nginx重新加載一下配置

nginx -s reload

深究原理:

我有個疑問: 相同的nginx配置,為什么 http訪問正常, https訪問好像被nginx 截流了呢? 為什么 http請求 沒有proxy_buffering off; 設置也正常響應呢?

這個問題的核心在于 HTTP 和 HTTPS 在 Nginx 代理中的處理方式不同。以下幾點解釋了為什么 HTTP 請求可以正常響應,而 HTTPS 請求在沒有關閉?proxy_buffering?時表現出卡頓的現象。

這是因為 httpshttp 協議在傳輸數據時使用的是不同的傳輸方式。http 協議使用的是明文傳輸,數據是一行一行地傳輸的,每行數據以回車符和換行符結尾。這種傳輸方式比較簡單,但是不夠安全,容易被竊聽和篡改。https 協議使用的是加密傳輸,數據是一大段一大段地傳輸的,每段數據的長度是不固定的。這種傳輸方式比較安全,可以保護數據的機密性和完整性,但是相對于 http 協議來說,傳輸效率會稍微低一些。因此,如果你需要傳輸機密性較高的數據,建議使用 https 協議進行傳輸。如果你需要傳輸的數據不太機密,可以使用
http 協議進行傳輸。

1. Nginx 代理行為差異

  • HTTP:在 HTTP 請求中,Nginx 默認會使用緩沖機制,但由于 HTTP 請求本身并不涉及加密和解密,數據的傳輸和處理通常比較快,即使啟用了 proxy_buffering,只要后端響應速度快,客戶端也不會明顯感受到延遲。Nginx 能夠較快速地將緩沖的數據傳遞給客戶端,因此你感受不到 HTTP 請求的卡頓。
  • HTTPS:HTTPS 請求涉及加密、解密過程,Nginx 需要處理 SSL/TLS 協議,導致響應的數據經過更多處理環節。在這種情況下,proxy_buffering 緩沖機制可能會導致 Nginx 等待完整的響應數據塊,再將其推送到客戶端,增加了數據傳輸的延遲感,尤其在流式數據的場景中更明顯。

2. 緩沖的作用

  • proxy_buffering 的默認行為:Nginx 默認會緩沖來自后端服務器的響應數據,緩沖滿了之后再一次性發送到客戶端。對于 HTTP 請求,數據包小而且無需解密,Nginx 處理較為快速,通常不會影響用戶體驗。
  • HTTPS 的復雜性:在 HTTPS 情況下,由于涉及加密和較大的數據包,Nginx 可能需要更長的時間來處理響應。而當啟用緩沖時,Nginx 會先緩沖較大的數據塊,再推送到客戶端,這使得 HTTPS 的流式響應延遲更為明顯。關閉 proxy_buffering 后,Nginx 可以直接將流式數據傳遞給客戶端,無需等待緩沖區填滿。

3. 流式傳輸的需求

  • 流式響應要求數據能夠即時從后端傳遞給前端,而不是經過代理服務器的緩沖。對于流式傳輸來說,proxy_buffering 可能會阻礙這種即時時性。HTTP 由于傳輸開銷小,能承受一定的緩沖延遲,而 HTTPS 的加密過程放大了這個問題。

4. 數據包大小和網絡開銷

  • HTTPS 請求的每個數據包相對更大,因為它包含了加密后的數據。Nginx 可能需要緩沖這些較大的數據包,而一旦 Nginx 使用 proxy_buffering 進行緩沖處理,這種額外的等待時間會被放大。而 HTTP 請求沒有這種加密開銷,響應更快。

總結:

簡單來說,HTTPS 請求的流式響應之所以卡頓,主要是因為:

  • 數據包更大:HTTPS 請求的數據包經過加密后確實比 HTTP 大一些,加密增加了開銷。
  • 緩沖機制的影響:在 HTTPS 請求中,Nginx 的緩沖機制需要更多時間來處理這些加密的數據包,導致延遲。相比之下,HTTP 沒有加密開銷,即使啟用緩沖,數據傳輸也相對流暢。

因此,同樣的請求,HTTPS 因為加密、數據包較大,加上 Nginx 的緩沖,導致流式響應出現卡頓。關閉 proxy_buffering 后,Nginx 不再等待緩沖區填滿,而是直接傳輸數據,HTTPS 響應也就變得流暢了。

性能影響及優化建議

  1. ?性能影響?:https的加密和解密過程增加了處理時間,尤其是在流式數據的場景中,Nginx需要等待完整的響應數據塊才能推送給客戶端,這可能導致延遲感增加?。
  2. ?優化建議?:可以通過調整Nginx配置來減少緩沖,使用分塊傳輸編碼等方式來優化性能。此外,對于大數據處理,可以考慮使用更高效的算法和硬件資源來減輕CPU負擔?

https://juejin.cn/post/7417521775586770995

https://mp.weixin.qq.com/s?__biz=MzAxMjY5NDU2Ng==&mid=2651867175&idx=1&sn=8fe3429c9943c981480f7e51ed9a4133

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/84201.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/84201.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/84201.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Vue常用自定義指令-積累的魅力【VUE】

前言 在【自定義指令—v2與v3之間的區別【VUE基礎】一文中,整理了自定義指令部分vue2和vue3 兩個版本的區別,有興趣的伙伴或者針對自定義部分比較迷茫的伙伴可以跳轉看一下。此次主要介紹一些自己積累的一些自定義指令的代碼,與大家一起分享。…

【mysql】mysql的高級函數、高級用法

mysql是最常用的數據庫之一,常見的函數用法大家應該都很熟悉,本文主要例舉一些相對出現頻率比較少的高級用法 (注:需注意mysql版本,大部分高級特性都是mysql8才有的) 多值索引與虛擬列 主要是解決字符串索引問題,光說…

C#日期和時間:DateTime轉字符串全面指南

C#日期和時間:DateTime轉字符串全面指南 在 C# 開發中,DateTime類型的時間格式化是高頻操作場景。無論是日志記錄、數據持久化,還是接口數據交互,合理的時間字符串格式都能顯著提升系統的可讀性和兼容性。本文將通過 20 實戰示例…

Canvas設計圖片編輯器全講解(一)Canvas基礎(萬字圖文講解)

一、前序 近兩年AI發展太過迅速,各類AI產品層出不窮,AI繪圖/AI工作流/AI視頻等平臺的蓬勃發展,促使圖片/視頻等復雜內容的創作更加簡單,讓更多普通人有了圖片和視頻創作的機會。另一方面用戶內容消費也逐漸向圖片和視頻傾斜。在“…

Javase易混點專項復習02_static關鍵字

1. static關鍵字1.1概述1.2修飾一個成員變量例:1.2.1靜態屬性與非靜態屬性示例及內存圖對比 1.3修飾一個方法(靜態方法)1.4.static修飾成員的訪問特點總結1.5動態代碼塊和靜態代碼塊1.5.1動態代碼塊1.5.2 靜態代碼塊 1.6帶有繼承的對象創建過…

C++滑動門問題(附兩種方法)

題目如下&#xff1a; 滑動窗口 - 題目 - Liusers OJ ——引用自OJ網站 方法如下&#xff1a; 1.常規思想 #include<bits/stdc.h> using namespace std; int main() {int n,k;int a[110];cin>>n>>k;for(int i0;i<n;i){cin>>a[i];}for(int i0;i…

mysql連接池druid監控配置

文章目錄 前置依賴啟用配置訪問監控一些問題 前置 連接池有很多類型&#xff0c;比如 c3p0&#xff0c;比如 hikariCP&#xff0c;比如 druid。c3p0 一些歷史項目可能用的比較多&#xff0c;hikariCP 需要高性能的項目比較多&#xff0c;druid 性能也很好&#xff0c;而且還提…

Jetson系統燒錄與環境配置全流程詳解(含驅動、GCC、.Net設置)

Jetson系統燒錄與環境配置全流程詳解&#xff08;含驅動、GCC、.Net設置&#xff09; 目錄1. 準備工作與工具安裝1.1 主機系統要求1.2 安裝 SDK Manager 2. JetPack 系統燒錄流程2.1 Jetson 進入恢復模式2.2 使用 SDK Manager 燒錄 JetPack 3. Jetson 系統基礎設置4. 配置 .Net…

分布式緩存:緩存的三種讀寫模式及分類

文章目錄 緩存全景圖Pre緩存讀寫模式概述1. Cache Aside&#xff08;旁路緩存&#xff09;工作流程優缺點 2. Read/Write Through&#xff08;讀寫穿透&#xff09;工作流程優缺點典型場景 3. Write Behind Caching&#xff08;異步寫回&#xff09;工作流程優缺點典型場景 緩存…

Ntfs!FindFirstIndexEntry函數中ReadIndexBuffer函數的作用是新建一個Ntfs!_INDEX_LOOKUP_STACK結構

第一部分&#xff1a; 0: kd> kc # 00 Ntfs!FindFirstIndexEntry 01 Ntfs!NtfsRestartIndexEnumeration 02 Ntfs!NtfsQueryDirectory 03 Ntfs!NtfsCommonDirectoryControl 04 Ntfs!NtfsFsdDirectoryControl 05 nt!IofCallDriver 06 nt!IopSynchronousServiceTail 07 nt!Nt…

5.24 note

笛卡爾積(?選擇條件 select a.student_name as member_A, b.student_name as member_B, c.student_name as member_C from schoola as a join schoolb as b join schoolc as c where a.student_name ! b.student_name and a.student_name !…

為什么需要在循環里fetch?

假設有多個設備連接在后端,數量不定,需要按個讀回狀態,那么就要在循環里fetch了. 此函數非常好用,來自于國內一個作者,時間久了,忘記了來源,抱歉. export default async function fetchWithTimeout(resource, options {}) {const { timeout 1000 } options;const controll…

不同凈化技術(靜電 / UV / 濕式)的性能對比研究

在餐飲油煙和工業廢氣治理領域&#xff0c;油煙凈化技術的選擇至關重要。目前&#xff0c;靜電、UV 光解、濕式洗滌是市場上應用較為廣泛的三種凈化技術。它們憑借不同的工作原理和技術特性&#xff0c;在凈化效率、能耗、適用場景等方面展現出各自的優勢與局限。本文將從多個維…

Ubuntu 22.04上升級npm版本

如果使用NVM安裝Node.js npm會自動包含&#xff0c;但版本可能不是最新的。你可以選擇升級&#xff1a; # 檢查當前版本 npm --version# 升級到最新版本 npm install -g npmlatest# 或者升級到特定版本 npm install -g npm9.8.1如果使用其他方法安裝Node.js 通常Node.js安裝…

項目管理進階:111頁 詳解華為業務變革框架及戰略級項目管理【附全文閱讀】

BTMS 是一套集成管理系統框架&#xff0c;涵蓋變革規劃、項目執行、實施及生命周期管理等多個關鍵環節。在規劃階段&#xff0c;通過全面收集需求、深入分析現狀&#xff0c;制定出符合業務戰略的年度規劃&#xff0c;明確變革舉措和項目清單。 解決方案開發的 PMOP 流程&#…

java基礎知識回顧1(可用于Java基礎速通)考前,面試前均可用!

目錄 一、初識java 二、基礎語法 1.字面量 2.變量 3.關鍵字 4.標識符 聲明&#xff1a;本文章根據黑馬程序員b站教學視頻做的筆記&#xff0c;可對應課程聽&#xff0c;課程鏈接如下: 02、Java入門&#xff1a;初識Java_嗶哩嗶哩_bilibili 一、初識java Java是美國 sun 公…

Linux下MySQL的安裝與使用

1 安裝前說明 1.1 Linux系統及工具的準備 安裝并啟動好兩臺虛擬機&#xff1a;CentOS 7 掌握克隆虛擬機的操作 mac地址主機名ip地址UUID 安裝有 Xshell 和 Xftp 等訪問 CentOS 系統的工具 CentOS6 和 CentOS7 在 MySQL 的使用中的區別 防火墻&#xff1a;6是iptables&am…

在react項目中使用andt日期組件,選擇周和季度,直接獲取所對應的日期區間

在react項目中使用andt日期組件&#xff0c;選擇周和季度&#xff0c;直接獲取所對應的日期區間 import { DatePicker, Space } from antd; import React from react; const onChange (date, dateString) > {console.log(date,dateString) }; const onChangeweek (date, …

數字信號處理大實驗2 利用FFT估計信號的頻率

目錄 3.1 實驗目的 3.2 實驗內容與要求 3.3 實驗原理 3.3.1 基于時域求導-頻域乘法的n階導數積分法 3.3.2 基于頻域卷積的雙/多譜線插值法 3.3.3 基于譜峰和滑動平均的多譜線綜合插值方法 3.3.4 基于相鄰顯著譜線的滑動平均綜合插值方法 3.3.5 基于&#xff08;2&#…

【Java】Java元注解

Target(ElementType.METHOD) Retention(value RetentionPolicy.RUNTIME) public interface OperatorLog {String source() default "WEB"; //日志操作來源 默認是web&#xff0c;還有socket的String model() default ""; //操作模塊 }這個代碼中的 Target…