初步认识迭代服务器和并发服务器
生活随笔
收集整理的這篇文章主要介紹了
初步认识迭代服务器和并发服务器
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
http://www.cnblogs.com/wolflion/archive/2011/07/13/2539138.html
?
迭代服務(wù)器比較原始,它的原型可以描述成:
while(1) { new_fd =?服務(wù)器accept客戶端的連接(new_fd = accept(listenfd, XX, XX)) 邏輯處理 在這個(gè)new_fd上給客戶端發(fā)送消息 關(guān)閉new_fd } 也就是說(shuō),這個(gè)進(jìn)程是一個(gè)一個(gè)處理各個(gè)客戶端發(fā)來(lái)的連接的,比如一個(gè)客戶端發(fā)來(lái)一個(gè)連接,那么只要它還沒(méi)有完成自己的任務(wù),那么它就一直會(huì)占用服務(wù)器的進(jìn)程直到處理完畢后服務(wù)器關(guān)閉掉這個(gè)socket。 并發(fā)服務(wù)器是最經(jīng)常用的: 1 while(1) 2 { 3?new_fd =?服務(wù)器accept客戶端的連接 4?if(是子進(jìn)程) 5?{ 6?首先關(guān)閉掉監(jiān)聽fd // 因?yàn)樽舆M(jìn)程并不需要監(jiān)聽,它只負(fù)責(zé)處理邏輯并發(fā)消息給客戶端 7?處理邏輯發(fā)送消息 8?關(guān)閉new_fd 9?關(guān)閉進(jìn)程 10?} 11?關(guān)閉new_fd 12 } 這樣每來(lái)一個(gè)客戶端,服務(wù)器就克隆一個(gè)自己去處理請(qǐng)求,這樣主進(jìn)程就一直處于監(jiān)聽狀態(tài)而不會(huì)被阻塞 額,我想講的重點(diǎn)不是這里,重點(diǎn)是代碼第12行! 1。千萬(wàn)不要以為fork出來(lái)一個(gè)子進(jìn)程就產(chǎn)生了2個(gè)新的socket描述符,實(shí)際上子進(jìn)程和父進(jìn)程是共享linten_fd和new_fd的,當(dāng)父進(jìn)程關(guān)閉new_fd的時(shí)候(代碼第12行)它只是把這個(gè)new_fd的訪問(wèn)計(jì)數(shù)值減了1而已,由于訪問(wèn)計(jì)數(shù)值還 > 0(因?yàn)檫€有客戶端的new_fd連著呢),所以它并沒(méi)有斷開和客戶端的連接。 2。如果我們不寫第12行會(huì)有什么后果,第一,因?yàn)榭煞峙涞膕ocket描述符是有限的,如果分配了以后不釋放,也就是不能回收再利用,也就是總有描述符耗盡的一天。第二,本來(lái)把和客戶端連接的任務(wù)交給子進(jìn)程以后父進(jìn)程就可以繼續(xù)監(jiān)聽并accept下個(gè)連接了,但如果父進(jìn)程不關(guān)閉自己跟客戶的連接,意思就是這個(gè)連接居然永遠(yuǎn)存在!相當(dāng)于每來(lái)一個(gè)客戶這個(gè)父進(jìn)程就連一個(gè)客戶并且連接不斷,你應(yīng)該知道后果了吧。轉(zhuǎn)載于:https://www.cnblogs.com/johnnyflute/p/3800978.html
總結(jié)
以上是生活随笔為你收集整理的初步认识迭代服务器和并发服务器的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 团队开发(一)
- 下一篇: 模块化开发之sea.js实现原理总结