開場java
朋友約的是十點半的面試,提早了十分鐘到,而後安靜地坐在沙發等待,順便回憶下以前看的資料。快到十點半時,一個高瘦,穿着格子衫的男子推開門而進,說了句「你好,咱們來開始面試吧!」,朋友不失禮貌地笑着回了句「行」面試
若是你們在學習Java過程當中遇到什麼問題,或者缺少相關的Java學習資料,可查看右側公告欄獲取,有問題隨問隨答,還有我這段時間整理的一些Java學習手冊,面試題,開發工具,PDF文檔書籍教程,須要的話均可以避免費分享給你們。算法
朋友(怎麼一上來就問TCP,不按套路出牌啊,不應問問java基礎嗎?不過常規題,我還行)跨域
朋友:網絡模型通常分七層:應用層、表示層、會話層、傳輸層、網絡層、數據鏈路層、物理層。應用層的協議包括HTTP、FTP、SMTP,而TCP屬於傳輸層,IP協議則屬於網絡層安全
朋友:TCP/IP網絡模型層次由上到下,層層包裝,每一層都對應不一樣的協議解析,我來畫個圖服務器
朋友(什麼鬼!當我百度詞典,這怎麼記得住?等等,昨天晚上好像看過,有印象)cookie
朋友:繼續畫個圖,直觀點網絡
朋友:TCP首部結構先是16位的源端口號和目標端口號、接着是32位的序列號和確認號。再下面就是4bit的頭部長度和6個bit的保留位及6bit的標誌位session
朋友:16位的屬性則有窗口大小(控制發送窗口),檢驗和(校驗數據段是否未被修改)及緊急指針。最後是選項,其長度由頭部長度決定socket
朋友:詳細說下序列號,它是TCP報文段的一數字編號,爲保證TCP可靠鏈接,每個發送的數據段都要加上序列號。創建鏈接時,兩端都會隨機生成一個初始序列號。而確認號而是和序列號配合使用的,應答某次請求時,則返回一個確認號,它的值等於對方請求序列號加1
朋友:而6個標誌位分別是,URG:這是條緊急信息,ACK:應答消息,PSH:緩衝區還沒有填滿,RST:重置鏈接,SYN:創建鏈接消息標誌,FIN:鏈接關閉通知信息
朋友:窗口大小是接收端用來控制發送端的滑動窗口大小
朋友(鬆了一口氣)
朋友:1)鏈接方面:TCP面向鏈接。UDP是無鏈接的,發送數據以前不須要創建鏈接
朋友:2)安全方面:TCP提供可靠的服務,保證傳送的數據,無差錯,不丟失,不重複,且按序到達。UDP則是盡最大努力交付,不保證可靠交付
朋友:3)傳輸效率:TCP傳輸效率相對較低,UDP傳輸效率高
朋友:TCP的鏈接是基於三次握手,而斷開則是四次揮手
朋友:爲了保障數據不丟失及錯誤(可靠性),它有報文校驗、ACK應答、超時重傳(發送方)、失序數據重傳(接收方)、丟棄重複數據、流量控制(滑動窗口)和擁塞控制等機制
朋友(又是常規題,曬曬水啦)
朋友:TCP是可靠的雙向通道,因此須要三次握手和四次揮手,我來畫個圖
三次握手
四次揮手
朋友:提早搶答下,關閉鏈接時須要四次揮手,比創建時多一次,是由於被動關閉端或許還有數據沒被送出去,不能像握手時同樣,第二次握手既是發起握手也是響應握手
朋友:若是隻有兩次握手,client發鏈接請求後不會再ACK服務端的SYN
朋友:此時若客戶端由於自身緣由判斷創建鏈接失敗,可能會重複創建TCP鏈接,而服務端卻會認爲那些被client丟棄的TCP仍是有效,會白白浪費資源
朋友:CLOSE_WAIT是被動關閉造成的;當對方close socket而發送FIN報文過來時,迴應ACK以後進入CLOSE_WAIT狀態。隨後檢查是否存在未傳輸數據,若是沒有則發起第三次揮手,發送FIN報文給對方,進入LAST_ACK狀態並等待對方ACK報文到來
朋友:TIME_WAIT是主動關閉鏈接方式造成的;處於FIN_WAIT_2狀態時,收到對方FIN報文後進入TIME_WAIT狀態;以後再等待兩個MSL(Maximum Segment Lifetime:報文最大生存時間)
朋友(這問得太深了吧,老哥。還好昨天偷偷補課了)
朋友:1)TIME_WAIT的做用是爲了保證最後一次揮手的ACK報文能送達給對方,若是ACK丟失,對方會超時重傳FIN,主動關閉端會再次響應ACK過去;若是沒有TIME_WAIT狀態,直接關閉,對方重傳的FIN報文則被響應一個RST報文,此RST會被動關閉端被解析成錯誤
朋友:2)存在兩個鏈接,第一個鏈接正常關閉,第二相同的鏈接緊接着創建;若是第一個鏈接的迷路報文到來,則會干擾第二鏈接,等待兩個MSL則可讓上次鏈接的報文數據消逝在網絡後
朋友:第一方式是慢啓動和擁塞避免
朋友:1)慢啓動,TCP發送端會維護一個擁塞窗口(congestionwindow),簡稱爲cwnd。擁塞窗口初始爲1個報文段,每通過一次RTT(數據徹底發送完到確認的時間),窗口大小翻倍(指數增加,只是前期慢)
朋友:2)擁塞避免,它思路是讓擁塞窗口cwnd緩慢增大,發送方的cwnd達到閥值ssthresh(初始值由系統決定的)以後,每通過一個RTT就把擁塞窗口加一,而不是加倍(收到兩個或四個確認,都是cwnd+1),cwnd呈線性增長(加法增大)
朋友:(畫個圖好解析)
朋友:若是遇到網絡擁塞,擁塞窗口閥值ssthresh減半,cwnd設置爲1,從新進入慢啓動階段
朋友:快重傳和快恢復
朋友:1)快重傳是當接收方收到了一個失序的報文,則立馬報告給發送方,趕忙重傳
朋友:假如接收方M1收到了,M2沒有收到,以後的M三、M四、M5又發送了,此時接收方一共連續給發送方反饋了3個M1確認報文。那麼快重傳規定,發送方只要連續收到3個重複確認,當即重傳對方發來的M2(重複確認報文的後一個報文)
朋友:2)快恢復
朋友:當發送方連續收到三個重複確認,ssthresh減半;因爲發送方可能認爲網絡如今沒有擁塞,所以與慢啓動不一樣,把cwnd值設置爲ssthresh減半以後的值,而後執行擁塞避免算法,cwnd線性增大
朋友:(再來一圖)
朋友:接收端將本身能夠接收的緩衝區大小放入TCP首部中的「窗口大小」字段,經過ACK報文來通知發送端,滑動窗口是接收端用來控制發送端發送數據的大小,從而達到流量控制
朋友:其實發送方的窗口上限,是取值擁塞窗口和滑動窗口二者的最小值
朋友:相同點都是控制丟包現象,實現機制都是讓發送方發得慢一點
朋友:不一樣點在於控制的對象不一樣
朋友:1)流量控制的對象是接收方,怕發送方發的太快,使得接收方來不及處理
朋友:2)擁塞控制的對象是網絡,怕發送方發的太快,形成網絡擁塞,使得網絡來不及處理
朋友:程序須要發送的數據大小和TCP報文段能發送MSS(Maximum Segment Size,最大報文長度)是不同的
朋友:大於MSS時,而須要把程序數據拆分爲多個TCP報文段,稱之爲拆包;小於時,則會考慮合併多個程序數據爲一個TCP報文段,則是粘包;其中MSS = TCP報文段長度-TCP首部長度
朋友:在IP協議層或者鏈路層、物理層,都存在拆包、粘包現象
朋友:1)在數據尾部增長特殊字符進行分割
朋友:2)將數據定爲固定大小
朋友:3)將數據分爲兩部分,一部分是頭部,一部分是內容體;其中頭部結構大小固定,且有一個字段聲明內容體的大小
朋友:SYN Flood 僞造 SYN 報文向服務器發起鏈接,服務器在收到報文後用 SYN_ACK 應答,此應答發出去後,不會收到 ACK 報文,形成一個半鏈接
朋友:若攻擊者發送大量這樣的報文,會在被攻擊主機上出現大量的半鏈接,耗盡其資源,使正常的用戶沒法訪問,直到半鏈接超時
朋友:1)解析域名 -> 2)發起TCP三次握手,創建鏈接 -> 3)基於TCP發起HTTP請求 -> 4)服務器響應HTTP請求,並返回數據 -> 5)客戶端解析返回數據
朋友:大概有如下幾種
200:表示成功正常請求
400:語義有誤,通常是請求格式不對
401:需求用戶驗證權限,通常是證書token沒經過認證
403:拒絕提供服務
404:資源不存在
500:服務器錯誤
503:服務器臨時維護,過載;可恢復
朋友:1)存儲位置不一樣,cookie是保存在客戶端的數據;session的數據存放在服務器上
朋友:2)存儲容量不一樣,單個cookie保存的數據小,一個站點最多保存20個Cookie;對於session來講並無上限
朋友:3)存儲方式不一樣,cookie中只能保管ASCII字符串;session中可以存儲任何類型的數據
朋友:4)隱私策略不一樣,cookie對客戶端是可見的;session存儲在服務器上,對客戶端是透明對
朋友:5)有效期上不一樣,cookie能夠長期有效存在;session依賴於名爲JSESSIONID的cookie,過時時間默認爲-1,只需關閉窗口該session就會失效
朋友:6)跨域支持上不一樣,cookie支持跨域名訪問;session不支持跨域名訪問
朋友:分塊傳送是HTTP的一種傳輸機制,容許服務端發送給客戶端的數據分紅多個部分,該協議在HTTP/1.1提供
朋友:HTTP分塊傳輸編碼容許服務器爲動態生成的內容維持HTTP持久鏈接
朋友:分塊傳輸編碼容許服務器在最後發送消息頭字段。對於那些頭字段值在內容被生成以前沒法知道的情形很是重要,例如消息的內容要使用散列進行簽名
朋友:HTTP服務器有時使用壓縮 (gzip或deflate)以縮短傳輸花費的時間。分塊傳輸編碼能夠用來分隔壓縮對象的多個部分。在這種狀況下,塊不是分別壓縮的,而是整個負載進行壓縮。分塊編碼有利於一邊進行壓縮一邊發送數據
朋友:長鏈接是指客戶端和服務創建TCP鏈接後,它們之間的鏈接會持續存在,不會由於一次HTTP請求後關閉,後續的請求也是用這個鏈接
朋友:長鏈接能夠省去TCP的創建和關閉操做,對於頻繁請求的客戶端適合使用長鏈接,可是注意惡意的長鏈接致使服務受損(建議內部服務之間使用)
朋友:並不是安全,HTTP傳輸的數據都是明文的,容易被第三方截取;要作安全傳輸數據,可使用HTTP的升級版HTTPS協議
朋友:1)http協議的鏈接是無狀態的,明文傳輸
朋友:2)HTTPS則是由SSL/TLS+HTTP協議構建的有加密傳輸、身份認證的網絡協議
朋友:SSL(Secure Socket Layer 安全套接層)是基於HTTPS下的一個協議加密層,保障數據私密性。TLS(Transport Layer Security)則是升級版的SSL
朋友:https在http基礎加了一層安全認證及加密層TLS或者SSL,它首先會經過安全層進行ca證書認證,正確獲取服務端的公鑰
朋友:接着客戶端會經過公鑰和服務端確認一種加密算法,後面的數據則可使用該加密算法對數據進行加密
原文做者:cscw連接:https://juejin.cn/post/6900439208641921038來源:掘金