青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

昨天優化了一下服務器的網絡部分,測試了一下,在不考慮吞吐率的情況下,并發5W

昨天優化了一下服務器的網絡部分,測試了一下,在不考慮吞吐率的情況下,并發5W

下面是俺的一些經驗

1.基本結構

服務器結構如下圖
33.JPG

使用2個不同的線程池來分別來處理 網絡數據包的發送接收 以及 消息的處理.
這樣可以避免繁重的業務處理導致網絡數據包接收的阻塞.

根據服務器CPU情況創建線程. 服務器是2*4核心. 即雙CPU, 每CPU上有4個核心.
在邏輯上就有8個處理單元.

在第1個CPU上的每個核心上創建x個線程用于發送和接收.
即: 發送接收線程池有線程數 x*4個,位于第1個CPU上.

在第2個CPU上的每個核心上創建y個線程,用于業務處理
即: 業務處理線程池有線程數 y*4個,位于第2個CPU上

具體的x,y應該按照實際的系統設置.設置的原則是:
1. 盡量小的線程上下文切換開銷
2. 盡量高的CPU利用率(注意,是利用率,不是占用率)
一般來說,y>x

BOOL?WINAPI?SetProcessAffinityMask(
??__in??????????HANDLE?hProcess,
??__in??????????DWORD_PTR?dwProcessAffinityMask
);
// ?此API用于設置進程的CPU親緣屬性,第2個參數是"位或"表示.?對于2*4核系統,則設置位0xFF

DWORD_PTR?WINAPI?SetThreadAffinityMask(
??__in??????????HANDLE?hThread,
??__in??????????DWORD_PTR?dwThreadAffinityMask
);
// ?此API用于設置線程的CPU親緣屬性,第2個參數是"位或"表示.?需要注意的是,dwThreadAffinityMask必須是dwProcessAffinityMask的子集

DWORD?WINAPI?SetThreadIdealProcessor(
??__in??????????HANDLE?hThread,
??__in??????????DWORD?dwIdealProcessor
);
// ?此API用于設置線程的首選CPU,操作系統在調度線程時優先考慮首選核心,?第2個參數是以0為基數的處理器ID

上述3個API都可以用來設置線程的執行單元是哪個. 一般來說,線程調度是由操作系統負責.人為的控制有時候反而會降低效率.但針對高負荷的線程處理,完全可以指定獨立的CPU來優化.
比如,設定dwThreadAffinityMask=0xF,表示此線程在1-4核上執行,具體是哪個核還是由操作系統調度.這樣可以將不同用途的線程分配到不同的CPU上,因為每個CPU有自己獨立的L2 Cache,這樣做可以避免不同類型線程在不同CPU之間切換帶來的損失.
參考: 面向共享高速緩存多核系統的軟件技術

上面所說的這些都只是理論,到實際的系統中,必須經過反復的性能對比試驗來確定最佳方案

2. 登陸數據的接收
在IOCP中,經常使用AcceptEx來投遞前置式的accept請求. 這里有一個問題: 登陸數據如何接收?
一般來說,登陸數據包是連接后的第1個或者第2個數據包.必須先保證一個TCP連接是信任的才能進行業務處理.有下列方法

方法1:
如果登陸數據包是第一個客戶端發送的數據包,那么AcceptEx的dwReceiveDataLength 可以設置成登陸數據包大小,AcceptEx只有在收到此數據包后才投遞到完成隊列進行驗證

方法2:
AcceptEx的dwReceiveDataLength 設置成0,表示在接收到連接后立即投遞到完成隊列.在完成隊列中,投遞WSARecv獲得登陸數據包

方法3:
AcceptEx的dwReceiveDataLength 設置成0,表示在接收到連接后立即投遞到完成隊列.在Accept時,使用阻塞的recv來接收登陸數據包,如果recv超時,則踢掉連接

這3種方式沒有哪種能夠徹底的解決D.O.S的問題,只能在一定程度上緩解.
方法1:客戶端只連接不發送數據,大量的這種連接會導致拒絕服務(一般采用附加線程定時檢測超時)
方法2:客戶端只連接不發送數據,大量的這種連接會導致拒絕服務(一般采用附加線程定時檢測超時)
方法3:recv的超時時間設置很敏感,過大的超時時間同樣會因為大量連接而拒絕服務(recv超時時間設定得如果合適是能夠在一定程度上緩解)

3. 設置LINGER縮短連接關閉時間

// ?éè??SO_DONTLINGER
BOOL?bDontLinger? = ?FALSE;
::setsockopt(?lpWsaOverlappedPlus
-> hSocket
????,?SOL_SOCKET
????,?SO_DONTLINGER
????,?(
const ? char * ) & bDontLinger
????,?sizeof(BOOL)
????);

// ?éè??SO_LINGER
linger?stLinger;
stLinger.l_onoff?
= ? 1 ;
stLinger.l_linger?
= ? 0 ;
::setsockopt(?lpWsaOverlappedPlus
-> hSocket
????,?SOL_SOCKET
????,?SO_LINGER
????,?(CHAR
* ) & stLinger
????,?sizeof(linger)
????);

4. 修改注冊表,修改TCP參數,具體的含義可以查閱MSDN
Windows?Registry?Editor?Version? 5.00

[ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Performance ]
" MaxUserPort " = dword:0000fffe

[ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters ]
" TCPFinWait2Delay? " = dword:0000001e
" SynAttackProtect " = dword: 1 ?
" TcpMaxPortsExhausted " = dword: 5 ?
" TcpMaxHalfOpen " = dword: 500 ?
" TcpMaxHalfOpenRetried " = dword: 400 ?
" TcpMaxConnectResponseRetransmissions " = dword: 2 ?
" TcpMaxDataRetransmissions " = dword: 2 ?
" EnablePMTUDiscovery " = dword: 0 ?
" KeepAliveTime " = dword: 300000 ?
" NoNameReleaseOnDemand " = dword: 1 ?
" DefaultTTL " = dword: 256 ?
" EnableDeadGWDetect " = dword: 0 ?
" DisableIPSourceRouting " = dword: 1 ?
" EnableFragmentChecking " = dword: 1 ?
" EnableMulticastForwarding " = dword: 0 ?
" IPEnableRouter " = dword: 0 ?
" EnableAddrMaskReply " = dword: 0 ?
" TcpTimedWaitDelay " = dword:0000001e

[ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\AFD\Parameters ] ?
" EnableICMPRedirect " = dword: 0 ?
" EnableDynamicBacklog " = dword: 1 ?
" MinimumDynamicBacklog " = dword: 20 ?
" MaximumDynamicBacklog " = dword: 20000 ?
" DynamicBacklogGrowthDelta " = dword: 10 ?

Feedback

# re: 昨天優化了一下服務器的網絡部分,測試了一下,在不考慮吞吐率的情況下,并發5W   回復  更多評論   

2009-01-16 11:16 by true
一個很關鍵的問題:
對于一個客戶端的收包及發包順序是怎么判斷的呢,舉例:客戶端給服務器傳輸文件,肯定是多次發包,同時服務器給客戶端多次確認,這種情況,請問是怎么實現的同步的呢?或者是怎么解決的文件傳輸的呢

# re: 昨天優化了一下服務器的網絡部分,測試了一下,在不考慮吞吐率的情況下,并發5W   回復  更多評論   

2009-01-16 18:07 by tzhang
可以提供個代碼下載么?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久国产精品久久国产精品| 性欧美xxxx大乳国产app| 欧美成人国产va精品日本一级| 久久国产精品久久久久久电车 | 欧美亚洲一区三区| 欧美日韩精品一区二区| 日韩午夜免费| 国产精品99久久99久久久二8 | 国产一区二区在线免费观看| 香蕉久久一区二区不卡无毒影院| 西西人体一区二区| 国语自产精品视频在线看抢先版结局 | 国产一区二区三区在线免费观看 | 欧美国产日韩xxxxx| 亚洲国产视频a| 欧美日韩一级片在线观看| 亚洲天堂av在线免费| 久久国产欧美日韩精品| 在线欧美影院| 国产精品sss| 久久久久久网| 亚洲精品一区二区三区樱花| 亚洲欧美日韩一区在线| 欧美第一黄色网| 国产三级欧美三级日产三级99| 亚洲在线日韩| 欧美成人xxx| 亚洲一区二区不卡免费| 国产一区二区三区久久悠悠色av| 欧美国产日本高清在线| 欧美亚洲一级| 亚洲全黄一级网站| 欧美主播一区二区三区| 一区二区免费在线播放| 激情成人在线视频| 欧美日韩四区| 久久综合图片| 欧美一区二区三区日韩| 日韩亚洲欧美综合| 欧美午夜电影一区| 在线观看三级视频欧美| 欧美日韩一区二区三区四区在线观看 | 日韩视频免费| 欧美成人按摩| 久久婷婷综合激情| 久久爱www.| 亚洲一级在线| 夜夜嗨av色一区二区不卡| 精品51国产黑色丝袜高跟鞋| 国产精品亚洲成人| 久久se精品一区精品二区| 久久久久国产精品一区二区| 久久久久一区二区三区四区| 你懂的国产精品| 一区二区三区色| 亚洲国产美女精品久久久久∴| 国产日韩精品视频一区| 国产精品毛片大码女人| 欧美日韩国产一区| 免费看av成人| 免费不卡在线观看av| 久久精品免费看| 久久精品99国产精品| 性8sex亚洲区入口| 欧美怡红院视频一区二区三区| 亚洲日本成人网| 好吊妞这里只有精品| 亚洲社区在线观看| 老司机午夜免费精品视频 | 亚洲日本中文字幕| 亚洲国产成人久久| 尤物精品在线| 一区二区在线观看视频| 狠狠色丁香婷综合久久| 国内精品视频在线观看| 在线看国产日韩| 亚洲人成小说网站色在线| 亚洲另类视频| 亚洲欧美视频| 夜夜狂射影院欧美极品| av不卡在线看| 久久精品一二三| 久久久水蜜桃av免费网站| 玖玖玖国产精品| 欧美激情国产日韩| 欧美精品一区二区三区很污很色的 | 噜噜噜在线观看免费视频日韩| 久久久久国产免费免费| 久久影音先锋| 亚洲精品影院| 欧美在线黄色| 欧美日韩卡一卡二| 狠狠狠色丁香婷婷综合激情| 亚洲免费高清| 中文日韩在线视频| 美女视频黄 久久| 亚洲欧洲精品一区| 亚洲精品社区| 欧美一区二区在线视频| 欧美喷水视频| 在线免费观看视频一区| 小嫩嫩精品导航| 欧美大片免费久久精品三p | 在线看不卡av| 亚洲综合成人婷婷小说| 欧美成人免费在线视频| 一区二区三区精品| 另类国产ts人妖高潮视频| 国产精品毛片va一区二区三区 | 夜夜嗨av色综合久久久综合网| 亚洲天堂av在线免费| 欧美在线视频播放| 欧美成人影音| 欧美一区二区精品久久911| 欧美va亚洲va日韩∨a综合色| 国产麻豆成人精品| 在线午夜精品| 亚洲第一区色| 久久电影一区| 国产午夜亚洲精品不卡| 日韩亚洲在线观看| 欧美成人精品高清在线播放| 午夜伦欧美伦电影理论片| 欧美噜噜久久久xxx| 亚洲国产毛片完整版| 老司机aⅴ在线精品导航| 亚洲在线免费视频| 国产精品卡一卡二卡三| 国产精品99久久久久久有的能看| 亚洲第一久久影院| 欧美 日韩 国产精品免费观看| 久久综合99re88久久爱| 亚洲欧美国产三级| 国产精品国产自产拍高清av王其| 亚洲欧洲在线播放| 免费观看成人| 久久久久国产精品麻豆ai换脸| 国产一区日韩二区欧美三区| 亚洲综合色婷婷| 亚洲一区视频在线观看视频| 国产精品久久午夜夜伦鲁鲁| 亚洲欧美国产视频| 亚洲午夜激情| 国产农村妇女精品一区二区| 久久久91精品国产| 久久女同互慰一区二区三区| 在线观看视频欧美| 亚洲国产精品一区二区久| 欧美成人综合在线| 亚洲无限乱码一二三四麻| 亚洲一区二区免费视频| 国产一级久久| 免费永久网站黄欧美| 女生裸体视频一区二区三区| 日韩视频免费| 亚洲自拍都市欧美小说| 狠狠色伊人亚洲综合网站色| 欧美高清免费| 欧美日韩在线观看一区二区| 久久爱www久久做| 久久综合久久久| 一区二区毛片| 欧美一区二区三区另类| 亚洲日本成人在线观看| 国产精品99久久久久久白浆小说| 国产欧美一区二区精品秋霞影院| 久久嫩草精品久久久精品| 欧美成人久久| 午夜精品视频在线观看| 欧美在线视频a| 久久最新视频| 欧美激情视频在线播放| 性欧美精品高清| 久久综合网hezyo| 亚洲图片在区色| 六月婷婷一区| 欧美一级在线播放| 欧美人妖在线观看| 麻豆精品91| 欧美日韩八区| 久久综合色影院| 欧美日韩在线看| 欧美成年视频| 国产日韩欧美精品| 亚洲国产精品99久久久久久久久| 国产精品久久久久久久午夜片| 免费观看久久久4p| 国产欧美日韩激情| 99精品视频免费| 亚洲第一区中文99精品| 午夜精品久久久久99热蜜桃导演| 日韩视频免费观看高清在线视频| 久久国产天堂福利天堂| 亚洲欧美激情视频在线观看一区二区三区| 欧美一区二区视频97| 亚洲一区二区免费视频| 欧美暴力喷水在线| 欧美aⅴ99久久黑人专区| 国产一区免费视频| 亚洲欧美不卡|