早期網頁比較簡單,一次http請求便可加載到全部資源。隨着網頁愈來愈複雜,每每須要屢次請求才能加載到全部資源,網頁上有css,html,圖片等各類資源,短期內須要屢次http請求。每次http請求都須要創建tcp鏈接、發送請求、接收請求、斷開鏈接等過程,很是耗系統資源.
css
能不能只創建一次http請求,同時請求css,html,圖片等資源?確定是不能的,由於http是無鏈接的,若是同一個http請求連續請求css,html,js,圖片等,返回的數據就不知道怎麼處理了,不知道返回的內容是哪次請求須要的。
html
那既然tcp鏈接是有狀態的,那能不能只創建一次tcp請求?畢竟tcp請求的握手和分手很是耗網絡資源,http請求只是對tcp報文的一個封裝,若是能複用tcp請求也能提高很多性能,答案是能夠的。
通常用戶進入一個網頁、瀏覽網頁須要一段時間,可是不會須要好久,所以http keep-alive通常不會設置太長,通常設置成1分鐘,即一分鐘以內對一個站點的訪問只會創建一個tcp鏈接,頁面上若是有多個http請求則會複用這個tcp鏈接。當沒有http請求時,一分鐘以後則斷開則會個tcp鏈接。
mysql
http keep-alive底層的tcp實際上是短連接,它是經過心跳機制着tcp鏈接不間斷
sql
http1.0默認是關閉的,經過http請求頭設置「connection: keep-alive」進行開啓;http1.1中默認開啓,經過http請求頭設置「connection: close」關閉
服務器
keep-alive機制:若開啓後,在一次http請求中,服務器進行響應後,再也不直接斷開TCP鏈接,而是將TCP鏈接維持一段時間。在這段時間內,若是同一客戶端再次向服務端發起http請求,即可以複用此TCP鏈接,向服務端發起請求,並重置timeout時間計數器,在接下來一段時間內還能夠繼續複用。這樣無疑省略了反覆建立和銷燬TCP鏈接的損耗。
markdown
http keep-alive是在服務端實現的,客戶端只是設置了一下http頭,加上keep-alive字段,服務端收到這個字段後不會立馬關閉tcp鏈接,會保持一個設置的時長,好比1分鐘,1分鐘以內若是有新的tcp請求則重置這個時間,不然關閉這個tcp鏈接。通常服務端會設置兩個參數:
網絡
通常的服務器端都會設置這兩個參數,供http keep-alive使用,客戶端只須要在http頭中開啓便可。
socket
tcp keepalive是tcp層面的長鏈接,它是真正的長鏈接,是傳輸層,這個tcp長鏈接可被上層全部協議使用,應用層協議對tcp的長鏈接無感知,並不直到tcp是長鏈接,只知道有可用的tcp鏈接而且使用便可。
tcp長鏈接默認是關閉的,須要開啓。它有三個參數:
tcp
也就是默認狀況下一條TCP鏈接在2小時(7200秒)都沒有報文交換後,會開始進行保活探測,若再通過9*75秒=11分鐘15秒的循環探測都未收到探測響應,即共計:2小時11分鐘15秒後會自動斷開TCP鏈接。
探測的結果可能有三種狀況:
微服務
tcp的keepalive默認是關閉的,在建立鏈接的時候能夠經過參數設置打開。可是tcp的keepalive通常設置太長,不太實用,通常應用程序本身經過心跳機制來維持着長鏈接。即tcp建立的時候不設置keepalive,默認它永遠鏈接,它的斷開由應用程序主動關閉,只要應用程序不關閉這個tcp鏈接就不會被斷開。在複雜的網絡環境下,經過應用程序心跳機制來確保鏈接保持着通暢,實現應用層的長鏈接。這是現代不少應用層保持長鏈接經常使用的技巧,好比mysql,微服務,服務發現等。
【1】HTTP keep-alive和TCP keepalive的區別,你瞭解嗎?
【2】詳解HTTP 與TCP中Keep-Alive機制的區別