


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、精編word文檔 下載可編輯網(wǎng)絡(luò)計劃技術(shù)是利用圖論和網(wǎng)絡(luò)分析的方法編制和優(yōu)化實施計劃的一種科學(xué)手段。今天給大家?guī)砹藢τ诰W(wǎng)絡(luò)問題的總結(jié),希望對大家有所幫助。對于網(wǎng)絡(luò)問題的總結(jié)篇一我的主要科研方向為下一代網(wǎng)絡(luò)sdn以及云計算中網(wǎng)絡(luò)研究,但是傳統(tǒng)網(wǎng)絡(luò)發(fā)展到如此成熟的一個地步,雖然存在一些問題,不過我們不應(yīng)該用完美來要求所有東西,傳統(tǒng)網(wǎng)絡(luò)的很多思想和技術(shù)都將長遠(yuǎn)地影響以后的網(wǎng)絡(luò)發(fā)展,這篇文章欲總結(jié)一些傳統(tǒng)網(wǎng)絡(luò)中經(jīng)常會碰到的問題。正文為什么不單獨的用mac地址和ip地址來進行數(shù)據(jù)轉(zhuǎn)發(fā)如果只用mac地址,也就是說整個網(wǎng)絡(luò)都處于一個大二層中,都處于同一個廣播域中,當(dāng)世界上成百上千萬的機器處于同一個廣播域的
2、時候,結(jié)果可想而知。如果只是用ip地址,這個問題我只想了下面這種可能性,但是覺得解釋上仍然有些不足,希望大神可以不吝賜教。ip地址是由管理者統(tǒng)一分配的,所以在某個機器申請了ip地址之后,不是說這個機器的ip地址確定了,而是這個機器現(xiàn)在所連的這根網(wǎng)線的ip地址確定了,所以只有ip地址的話,如果頻繁的更換或者移動機器,每次都需要重新配置機器的ip地址。icmp和igmp以及arp和rarp屬于ip/tcp協(xié)議分層中的哪一層首先icmp和igmp都是ip的附屬協(xié)議,所以他們有理由都屬于網(wǎng)絡(luò)層,但是在數(shù)據(jù)包的具體傳輸過程中,icmp和igmp報文都被封裝在了ip數(shù)據(jù)報中。對于arp和rarp協(xié)議來說,
3、也是眾說紛紜,有的教材將其劃作網(wǎng)絡(luò)層,有的認(rèn)為是數(shù)據(jù)鏈路層,從邏輯上來說,數(shù)據(jù)在從上到下進行封裝的過程中會加上自己的信息,當(dāng)網(wǎng)絡(luò)層的ip包進入鏈路層時,鏈路層通過arp協(xié)議添加鏈路信息,而這不是網(wǎng)絡(luò)層的功能,所以可以認(rèn)為是數(shù)據(jù)鏈路層,但是從整個網(wǎng)絡(luò)解析層面來說,arp和rarp和ip數(shù)據(jù)報一樣,都擁有自己的以太網(wǎng)數(shù)據(jù)幀類型,所以也可以認(rèn)為是網(wǎng)絡(luò)層,所以他們在哪一層并不重要,明白原理最重要,這同時也說明了網(wǎng)絡(luò)層的劃分并不是十分完美的。為什么常見的網(wǎng)絡(luò)應(yīng)用端口號都是奇數(shù)端口號是用來區(qū)分不用應(yīng)用的,比如我們看著視頻聊著qq,我們都需要使用網(wǎng)絡(luò)傳輸數(shù)據(jù),所以需要客戶端端口號,同樣的,對于服務(wù)器而言,他
4、要提供多種服務(wù),如何區(qū)分這些服務(wù),同樣需要的是服務(wù)器端口號。如果有注意的話發(fā)現(xiàn)常用的、時間比較久遠(yuǎn)的應(yīng)用的端口號都是奇數(shù),比如ftp的端口號為21,snmp為161,telnet為23。這是為什么呢因為這些端口號都是從網(wǎng)絡(luò)控制協(xié)議(即tcp前身,arpanet的傳輸層協(xié)議)派生出來的,原來網(wǎng)絡(luò)控制協(xié)議是單工的,不是全雙工的,因此每個應(yīng)用程序需要兩個連接,一個用于接收,一個用于發(fā)送,需要預(yù)留一對奇數(shù)和偶數(shù)端口號,當(dāng)tcp和udp稱為了標(biāo)準(zhǔn)的傳輸層協(xié)議時,每個應(yīng)用程序只需要一個端口號,所以就使用了原來的網(wǎng)絡(luò)控制協(xié)議中的奇數(shù)??偨Y(jié)很多技術(shù)的發(fā)展都有其深刻的歷史烙印,想要精通一門技術(shù),了解其歷史是十分
5、重要的。不向靜中參妙理,縱然穎悟也虛浮 立乎其大 和而不同 古之成大事者,不惟有超世之才,亦必有堅韌不拔之志對于網(wǎng)絡(luò)問題的總結(jié)篇二對于網(wǎng)絡(luò)io,我們一般情況下都需要超時機制來避免進行操作的線程被handle住,經(jīng)典的做法就是采用select+非阻塞io進行判斷,select在超時時間內(nèi)判斷是否可以讀寫操作,然后采用非堵塞讀寫,不過一般實現(xiàn)的時候讀操作不需要設(shè)置為非堵塞,上面已經(jīng)說過讀操作只有在沒有數(shù)據(jù)的 時候才會阻塞,select的判斷成功說明存在數(shù)據(jù),所以即使是阻塞讀在這種情況下也是可以做到非阻塞的效果,就沒有必要設(shè)置成非阻塞的情況了.這部分的代碼可以參考ullib中ul_sreado_ms
6、_ex和ul_swriteo_ms_ex. % g j d: g% c4采用ul_sreado_ms_ex讀數(shù)據(jù)也是不能保證返回大于就一定讀到指定的數(shù)據(jù)長度, 對于讀寫操作, 都是需要判斷返回的讀長度或者寫長度是否是需要的長度, 不能簡單的判斷一下返回值是否小于. 對于ul_sreado_ms_ex的情況如果出現(xiàn)了發(fā)送端數(shù)據(jù)發(fā)送一半就被close掉的情況就有可能導(dǎo)致接收端讀不到完整的數(shù)據(jù)包. errno 只有在函數(shù)返回值為負(fù)的時候才有效,如果返回或者大于的數(shù), errno 的結(jié)果是無意義的. 有些時候 會出現(xiàn)read到, 但是我們認(rèn)為是錯誤的情況然后輸出errno造成誤解,一般建議在這種情況要
7、同時輸出返回值和errno的結(jié)果,有些情況由于只有errno造成了對于問 題的判斷失誤。 ; j; w& h* d6 _長連接和短連接的各種可能的問題及相應(yīng)的處理 n9 c; f! % r& 這里主要是發(fā)起連接的客戶端的問題,這里列出的問題主要是在采用同步模型的情況下才會存在的問題.短連接: j/ e. u5 v: l采用短連接的情況一般是考慮到下面的一些問題:后端服務(wù)的問題, 考慮最簡單的情況下一個線程一個連接, 如果這個連接采用了長連接那么就需要我們處理連接的線程和后端保持一一對應(yīng),然后按照某些原則進行處理(n對n的關(guān)系), 但由于一方面服務(wù)器可能增加,這樣導(dǎo)致需要前后端保持一致,帶來了更
8、多的麻煩,另一方面線程數(shù)上不去對應(yīng)處理能力也會產(chǎn)生影響,而短連接每次連接的時候只 需要關(guān)注當(dāng)前的機器,問題相對會少一些. 其實這個問題可以采用連接池的方式來解決,后面會提到. 不需要考慮由于異常帶來的臟數(shù)據(jù)。負(fù)載均衡方面可以簡單考慮, 無論線程數(shù)是多少還是后端服務(wù)器的數(shù)量是多少都沒有關(guān)系, 每次考慮單個連接就可以了. 當(dāng)然如果負(fù)載邏輯簡單,并且機器相對固定,一個線程一個長連接問題也不大. 規(guī)避一些問題, 在過去有些情況下出現(xiàn)長連接大延時,數(shù)據(jù)沒響應(yīng)等問題, 測試的時候發(fā)現(xiàn)換短連接問題就解決了,由于時間關(guān)系就沒有再繼續(xù)追查, 事實上這些問題現(xiàn)在基本上都已經(jīng)定位并且有相關(guān)的解決方案了.不足:效率不
9、足, 由于連接操作一般會有5ns2ns的時間消耗,導(dǎo)致短連接需要消耗更多的時間會產(chǎn)生time_wait問題,需要做更多的守護長連接:長連接相比短連接減少了連接的時間消耗, 可以承受更高的負(fù)載. 但在使用的時候需要考慮一些問題臟數(shù)據(jù), 在一些特殊情況(特別是邏輯錯誤的情況下) 會存在一些我們并不需要的數(shù)據(jù). 這個時候的處理比較安全的方式是一旦檢測到就關(guān)閉連接, 檢測的方式在在發(fā)起請求前用前面為什么socket寫錯誤,但用recv檢查依然成功 介紹的方式進行檢查. 不過有些程序會采用繼續(xù)讀把所有不需要的數(shù)據(jù)讀完畢(讀到 eaegin), 不過這種方式過分依賴邏輯了,存在了一定的風(fēng)險. 不如直接斷開
10、來的簡單 后端連接, 前面也提到了 在這種情況我們一般會采用連接池的方式來解決問題比如(public/connectpool中就可以維護不同的連接,使每個線程都可以均勻的獲取到句 柄) 服務(wù)端的處理這個時候需要考慮連接的數(shù)量,簡單的方式就是一個長連接一個線程, 但是線程也不能無限增加( 增加了,可能造成大量的上下文切換使的性能下降). 我們一般在長連接的情況采用pendingpool的模型, 通過一個異步隊列來緩沖, 這樣不需要考慮客戶端和服務(wù)端的線程數(shù)問題,可以任意配置(可以通過線下測試選擇合適的線程數(shù))一些特殊的問題, 主要是長連接的延時 在后面的faq中會有詳細(xì)的說明. 2 a( ! 5
11、 1 o9 b+ v) /一般來說,對于我們多數(shù)的內(nèi)部業(yè)務(wù)邏輯都是可以采用長連接模式,不會產(chǎn)生太多的問題.對于網(wǎng)絡(luò)問題的總結(jié)篇三在網(wǎng)絡(luò)編程中對于一個網(wǎng)絡(luò)句柄會遇到阻塞io和非阻塞io的概念, 這里對于這兩種socket先做一下說明 5 /% b8 u! i; /) 基本概念socket的阻塞模式意味著必須要做完io操作(包括錯誤)才會返回。 非阻塞模式下無論操作是否完成都會立刻返回,需要通過其他方式來判斷具體操作是否成功。設(shè)置一般對于一個socket是阻塞模式還是非阻塞模式有兩種方式 fcntl設(shè)置和recv,send系列的參數(shù). j% f& o: ; s$ w2 v) pfcntl函數(shù)可以將
12、一個socket句柄設(shè)置成非阻塞模式:flags=fcntl(sockfd, f_getfl, ); fcntl(sockfd, f_setfl, flags | o_nonblock);設(shè)置之后每次的對于sockfd的操作都是非阻塞的 6 b$ b8 i _ k: u5 w$ brecv, send函數(shù)的最后有一個flag參數(shù)可以設(shè)置成msg_dontwait臨時將sockfd設(shè)置為非阻塞模式,而無論原有是阻塞還是非阻塞。 recv(sockfd, buff, buff_size, msg_dontwait); send(scokfd, buff, buff_size, msg_dontwa
13、it); * l( v- | g1 u區(qū)別:讀:讀本質(zhì)來說其實不能是讀,在實際中, 具體的接收數(shù)據(jù)不是由這些調(diào)用來進行,是由于系統(tǒng)底層自動完成的,read也好,recv也好只負(fù)責(zé)把數(shù)據(jù)從底層緩沖copy到我們指定的位置. 對于讀來說(read, 或者 recv) ,在阻塞條件下如果沒有發(fā)現(xiàn)數(shù)據(jù)在網(wǎng)絡(luò)緩沖中會一直等待,當(dāng)發(fā)現(xiàn)有數(shù)據(jù)的時候會把數(shù)據(jù)讀到用戶指定的緩沖區(qū),但是如果這個時候讀到的數(shù)據(jù)量比較少,比參數(shù)中指定的長度要小,read并不會一直等待下去,而是立刻返回。read的原則是數(shù)據(jù)在不超過指定的長度的時候有多少讀多少,沒有數(shù)據(jù)就會一直等待。所以一般情況下我們讀取數(shù)據(jù)都需要采用循環(huán)讀的方式讀取
14、數(shù)據(jù),一次read完畢不能保證讀到我們需要長度的數(shù)據(jù),read完一次需要判斷讀到的數(shù)據(jù)長度再決定是否還需要再次讀取。在非阻塞的情況下,read的行為是如果發(fā)現(xiàn)沒有數(shù)據(jù)就直接返回,如果發(fā)現(xiàn)有數(shù)據(jù)那么也是采用有多少讀多少的進行處理.對于讀而言, 阻塞和非阻塞的區(qū)別在于沒有數(shù)據(jù)到達的時候是否立刻返回.recv中有一個 msg_waitall的參數(shù)recv(sockfd, buff, buff_size, msg_waitall), 在正常情況下recv是會等待直到讀取到buff_size長度的數(shù)據(jù),但是這里的waitall也只是盡量讀全,在有中斷的情況下recv還是可能會 被打斷,造成沒有讀完指定的
15、buff_size的長度。所以即使是采用recv + waitall參數(shù)還是要考慮是否需要循環(huán)讀取的問題,在實驗中對于多數(shù)情況下recv還是可以讀完buff_size,所以相應(yīng)的性能會比直接read 進行循環(huán)讀要好一些。不過要注意的是這個時候的sockfd必須是處于阻塞模式下,否則waitall不能起作用。寫: / e/ m& a+ b+ r寫的本質(zhì)也不是進行發(fā)送操作,而是把用戶態(tài)的數(shù)據(jù)copy到系統(tǒng)底層去,然后再由系統(tǒng)進行發(fā)送操作,返回成功只表示數(shù)據(jù)已經(jīng)copy到底層緩沖,而不表示數(shù)據(jù)以及發(fā)出,更不能表示對端已經(jīng)接收到數(shù)據(jù). 對于write(或 者send)而言,在阻塞的情況是會一直等待直到write完全部的數(shù)據(jù)再返回.這點行為上與讀操作有所不同,究其原因主要是讀數(shù)據(jù)的時候我們并不知道對端到底有沒有數(shù)據(jù),數(shù)據(jù)是在什么時候結(jié)束發(fā)送的,如果一直等待就可能會造成死循環(huán),所以并沒有去進行這方面的處理;而對于write, 由于需要寫的長度是已知的,所以可以一直再寫,直到寫完.不過問題是write是可能被打斷造成write一次只write一部分?jǐn)?shù)據(jù), 所以write的過程還是
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 多層砌體結(jié)構(gòu)施工方案
- 室外污水施工方案
- 水泥砼道路施工方案
- 援助學(xué)習(xí)資料
- 2025年歷史社區(qū)面試試題及答案
- 2025年張店二模歷史試題及答案
- 6年級下冊文言文學(xué)弈
- 5一6年級讀書卡
- 低溫法蘭標(biāo)識
- cdga數(shù)據(jù)治理工程師教材
- LY/T 2499-2015野生動物飼養(yǎng)場總體設(shè)計規(guī)范
- 愛德華閥門檢修工藝(2)2
- GB/T 13701-1992單標(biāo)準(zhǔn)氣體質(zhì)譜法鈾同位素分析
- AMOLED技術(shù)寶典(十年OLED技術(shù)經(jīng)驗總結(jié))
- 7S稽核查檢表-倉庫
- 小學(xué)科學(xué)《噪音的危害與防治》優(yōu)質(zhì)課件
- 病理學(xué)-第3章 局部血液循環(huán)障礙
- 湖北省黃石市基層診所醫(yī)療機構(gòu)衛(wèi)生院社區(qū)衛(wèi)生服務(wù)中心村衛(wèi)生室信息
- 打印版醫(yī)師執(zhí)業(yè)注冊健康體檢表(新版)
- 時代與變革-為人生而藝術(shù)
- 人教八年級下冊英語U5Do-you-remember-what-you-were-doing?課件
評論
0/150
提交評論