從nginx返回404來看http1.0和http1.1的區別

序言

? ??什么樣的人可以稱之為有智慧的人呢?如果下一個定義,你會如何來定義?

????所謂智慧,就是能區分自己能改變的部分,自己無法改變的部分,努力去做自己能改變的,而不要天天想著那些無法改變的東西,不然的話,就只能越來越消極了,消極的原因大部分也在于總是關注于自己無法改變的現實。

nginx返回404問題排查

? ??背景

????大部分的人在看到nginx返回404的時候,要么就是請求了一個不存在的資源或者接口,要么就是location寫的有問題,基本不會想到是協議導致的。

????架構

????現在的應用程序都講究前后端分離,分離不完整的時候,就會進行修改架構,在修改之前的架構如下:

cb71359aaf709d06a8d1b283d8f6220f.png

????為了從統一入口進來,從而將架構修改為如下:

841c781d38c44087daf3475b56b6ff44.png

????修改之后的好處主要是能減少客戶端能接觸的東西,從而減少暴露面,當有攻擊的時候,排查或者封殺的面不會很多。

????1 前端nginx進行重新配置

????在前端nginx上面,其實只要增加一段location的配置即可,從而使用了極簡的配置:

upstream backend {server???192.168.1.1;server???192.168.1.2;
}
location??/api/{proxy_pass?http://backend;proxy_set_header?X-Real_IP?$remote_addr;proxy_set_header?X-Forwarded-For?$proxy_add_x_forwarded_for;
}

????在添加完成配置之后,將nginx進行reaload,讓配置生效,再次進行驗證請求之后,發現后端請求的接口全部變成了404.

????此時的你,該如何去解決這個問題?

????對,應該第一時刻進行回滾備份的配置,先讓生產跑起來,再來解決問題。

????2 查看前端和后端的日志

????變更導致的問題,要么看配置是不是有問題,要么看日志查查問題出現的點在哪里。

????在查看nginx的accesslog的時候,重要的看請求發到了哪個后端,404是不是后端返回的,如果404是nginx直接返回的,說明還沒到達后端,如果是后端的返回的,那么就要看后端nginx的日志了。

????在此處的問題中,查看前端nginx日志的時候,發現是后端nginx返回的404,因為upsteam_status 為404,而且能找到對應的upsteam server的ip,從而到對應的后端nginx上去查看日志。

????但是,非常奇怪的是,在后端nginx上面未看到任何請求日志,在后端nginx上面,使用的是vhost的配置,也就是虛擬主機。

????那么現在可以得到一個初步結論:

1?404?的確是后端nginx返回的
2 后端nginx上面沒找到對應的訪問日志

????3 可能出現問題的地方

????根據如上的結論,那么哪些地方可能出現問題呢?

????首先再看了一眼加了location配置的地方,比平時的配置少一些東西:

proxy_set_header Host $host;
proxy_set_header?Connection?"";
proxy_http_version 1.1;

????在后端的nginx對應的server段的配置的日志路徑上面,沒找到對應的日志信息,但是前端的nginx返回中說明是后端nginx返回的,從而找到對應的默認主機,也就是default server中,發現默認配置沒有,那么就找到在vhost中第一個主機段,查看它的日志,發現了請求。

????從而問題已經找到,因為在nginx的默認配置中,如果不指定http協議版本的話,那么默認是1.0版本,而對于http 1.0版本來說,默認是不會加上host頭部的,從而當請求到后端nginx的時候,找不到對應server name進行處理,從而走了默認的server段進行處理,從而導致了對應的虛擬主機沒有日志,而在默認的虛擬主機中找到了對應的訪問日志。

????從而再將host頭部進行設置,然后切換,發現訪問正常。

????那么再嘗試一下第二種方案,不加host后端,而指定http協議為1.1,因為http1.1協議默認會傳輸host頭部,從而無需顯示指定,發現也是ok的。

????最后再把這三個頭部加上,主要是為了讓兩個nginx之間保持長連接,從而減少三次握手的時間,當然upsteam之中,也要將keepalive指令打開,不然也是不能激活長連接的,因為nginx的默認值如下:

Syntax:  keepalive connections;
Default:  —
Context:  upstream

6770a3b39a0427eff32d850f3f354ab6.png

風言風語

? ?一個東西,使用的多了,就能遇到各種各樣的問題,而在一些資料上看到的東西,你會發現那都是基礎中的基礎,解決不了任何問題,但是卻是解決問題的根基,簡單的報錯,但是中間就充斥著各種可能得組合原因。就像做數學,基礎都是1+1,然后來個3+2,都是同樣的道理。

????知道并不代表能靈活運行,能猜到可能的原因和解法,對比法也是一個比較好的方法。

????努力的方向也是自己能改變的東西,也是自己能掌控的東西,如果努力的方向都是不能改變的,不可控的,那么這種努力也將是一種徒勞。

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

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

相關文章

解析Java中的反射機制及其應用場景

解析Java中的反射機制及其應用場景 大家好,我是微賺淘客系統3.0的小編,也是冬天不穿秋褲,天冷也要風度的程序猿! Java的反射機制是指在運行時可以動態地獲取類的信息(如類名、方法、字段等),并…

麒麟桌面操作系統上網絡設置界面消失的解決方法

原文鏈接:麒麟桌面操作系統上網絡設置界面消失的解決方法 Hello,大家好啊!今天給大家帶來一篇關于麒麟桌面操作系統上網絡設置界面消失解決方法的文章。在使用麒麟桌面操作系統時,可能會遇到網絡設置界面突然消失的情況&#xff…

斯坦福CS224n深度學習培訓營課程

自然語言處理領域的經典課程涵蓋了從基礎知識到最新研究的全面內容。本培訓營將精選課程內容,結合實際案例和項目實踐,帶領學員深入探索自然語言處理的前沿,學習最先進的深度學習技術。 課程大小:2.6G 課程下載:http…

Softmax函數的意義

來自GPT,后期會再整理。。。 Softmax函數在深度學習中,特別是在多分類任務中,被廣泛用作輸出層的激活函數。它將模型的原始輸出(logits)轉化為概率分布,使得每個類別的概率總和為1。相比于簡單地使用“單個…

四自由度SCARA機器人的運動學和動力學matlab建模與仿真

目錄 1.課題概述 2.系統仿真結果 3.核心程序與模型 4.系統原理簡介 5.完整工程文件 1.課題概述 針對SCARA 機器人系統進行了深入研究與探討,提出SCARA機器人的動力學模型和運動學模型,并以MATLAB軟件為仿真平臺,通過MATLAB Robotics Too…

java核心-泛型

目錄 概述什么是泛型分類泛型類泛型接口泛型方法 泛型通配符分類 泛型類型擦除分類無限制類型擦除有限制類型擦除 問題需求第一種第二種 概述 了解泛型有利于學習 jdk 、中間件的源碼,提升代碼抽象能力,封裝通用性更強的組件。 什么是泛型 在定義類、接…

二手閑置平臺小程序的設計

管理員賬戶功能包括:系統首頁,個人中心,用戶管理,賣家管理,商品分類管理,商品信息管理,商品購買管理,商品配送管理 微信端賬號功能包括:系統首頁,商品信息&a…

qt中connect函數的使用方法

bool QObject::connect(const QObject *sender, const char *signal,const QObject *receiver, const char *method,Qt::ConnectionType type Qt::AutoConnection);1.sender: 一個指向信號發送者的QObject指針。這是發出信號的對象,可以是任何繼承自QObject的類的實…

【linux服務器】大語言模型實戰教程:LLMS大模型部署到個人服務器或嵌入式開發板(保姆級教學)

🎬 鴿芷咕:個人主頁 🔥 個人專欄: 《C干貨基地》《粉絲福利》 ??生活的理想,就是為了理想的生活! 引言 說到大語言模型相信大家都不會陌生,大型語言模型(LLMs)是人工智能文本處理的主要類型,也現在最流行的人工智能…

基于Java+SpringMvc+Vue技術智慧校園系統設計與實現--60頁及以上論文參考

博主介紹:碩士研究生,專注于信息化技術領域開發與管理,會使用java、標準c/c等開發語言,以及畢業項目實戰? 從事基于java BS架構、CS架構、c/c 編程工作近16年,擁有近12年的管理工作經驗,擁有較豐富的技術架…

網絡基礎:園區網絡架構

園區網絡 園區網絡(Campus Network)是指在一個相對較大的區域內,如大學校園、企業園區或政府機關等,建立的計算機網絡系統。園區網絡根據規模的不同,可以分為以下幾種類型: ①小型園區網絡:通常…

WebKit中Websockets的全面支持:實現高效實時通信

WebKit中Websockets的全面支持:實現高效實時通信 Websockets是一種網絡通信協議,它允許在單個TCP連接上進行全雙工通信,從而實現服務器與客戶端之間的實時數據交換。WebKit作為許多流行瀏覽器的底層引擎,對Websockets提供了全面的…

Java 多線程工具類 Semaphore

引言 在多線程編程中,控制對共享資源的訪問是一個關鍵問題。Java 提供了多種同步機制來解決這個問題,其中 Semaphore 是一種常用的工具類,用于限制可以同時訪問某個資源的線程數。本文將詳細介紹 Semaphore 的概念、使用方法和實際應用場景。…

ARM GEC6818 LCD繪圖 實心圓 三角形 五角星 任意區域矩形以及旗幟

要在ARM上實現LCD繪圖,可以按照以下步驟進行: 硬件初始化:初始化LCD控制器和相關引腳,配置時鐘、分辨率和顏色深度等。 內存映射:將LCD顯示區域映射到ARM的內存地址空間中,可以通過ARM的內存映射機制來實現。 繪圖函數:實現繪制基本圖形的函數,如點、線、矩形、圓等。可…

【系統架構設計師】八、系統工程基礎知識(系統工程|系統性能)

目錄 一、系統工程 1.1 系統工程的方法 1.1.1 霍爾的三維結構 1.1.2 切克蘭德方法 1.1.3 并行工程方法 1.1.4 綜合集成法 1.1.5.WSR 系統方法。 二、系統工程生命周期 2.1 系統工程生命周期7階段 2.2 生命周期方法 三、基于模型的系統工程(MBSE) 四、系統性能 4.1…

vb.netcad二開自學筆記6:第一個繪制線段命令

.net編寫繪制直線已完全不同于ActiveX的(VBA)的方式,過程更類似于arx程序,需要通過操作AutoCAD 數據庫添加對象!下面的代碼是在以前代碼基礎上添加了一個新myline命令。 AutoCAD 數據庫結構 myline命令代碼 Imports A…

YoloV9改進策略:Block改進|輕量實時的重參數結構|最新改進|即插即用(全網首發)

摘要 本文使用重參數的Block替換YoloV9中的RepNBottleneck,GFLOPs從239降到了227;同時,map50從0.989漲到了0.99(重參數后的結果)。 改進方法簡單,只做簡單的替換就行,即插即用,非常…

使用ndoe實現自動化完成增刪改查接口

使用ndoe實現自動化完成增刪改查接口 最近工作內容比較繁瑣,手里需要開發的項目需求比較多,常常在多個項目之間來回切換,有時候某些分支都不知道自己開發了什么、做了哪些需求, 使用手寫筆記的方式去記錄分支到頭來也是眼花繚亂&a…

vscode調試教程

VSCode調試 VSCode Debuggers VSCode使用launch.json進行細粒度的控制,可以啟動程序或將其附加到復雜的調試場景中 打開Run and Debug視圖Ctrl Shift D 點擊create a launch.json file,選擇C(GDB/LLDB) 會在工作目錄自動創建.vscode/launch.json文…

【MyBatis】MyBatis 理論 40 問(二)

《MyBatis 理論 40 問》包含以下 2 篇文章: MyBatis 理論 40 問(一)MyBatis 理論 40 問(二) MyBatis 理論 40 問(二) 21.如何獲取生成的主鍵?22.當實體類中的屬性名和表中的字段名不…