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

ACG狂人

其實我更愛姐汁...

ASIO攻破!??!

花了足足3天時間,外加1天心情休整,終于在第5天編寫出了一個能運行的基于asio和thread_group的框架,差點沒氣暈過去,把源碼都看懂了才感覺會用了。
測試了一下,debug下一萬次回應耗時800+毫秒,release下是200+毫秒,機器配置雙核2.5G英特爾,4個線程并行工作,無錯的感覺真好,再也不用擔心iocp出一些奇怪的問題啦,因為是巨人們寫的實現,呵呵。

進入正題,簡要說一下asio的實現原理吧。在win32平臺上,asio是基于IOCP技術實現的,我以前也用過IOCP,卻沒想到居然能擴展成這樣,真是神奇!在其他平臺下還會有別的方法去實現,具體見io_service類下面這部分的源碼:
  // The type of the platform-specific implementation.
#if defined(BOOST_ASIO_HAS_IOCP)
  typedef detail::win_iocp_io_service impl_type;
  friend 
class detail::win_iocp_overlapped_ptr;
#elif defined(BOOST_ASIO_HAS_EPOLL)
  typedef detail::task_io_service
<detail::epoll_reactor<false> > impl_type;
#elif defined(BOOST_ASIO_HAS_KQUEUE)
  typedef detail::task_io_service
<detail::kqueue_reactor<false> > impl_type;
#elif defined(BOOST_ASIO_HAS_DEV_POLL)
  typedef detail::task_io_service
<detail::dev_poll_reactor<false> > impl_type;
#else
  typedef detail::task_io_service
<detail::select_reactor<false> > impl_type;
#endif
這部分代碼其實就在boost::asio::io_service類聲明中的最前面幾行,可以看見在不同平臺下,io_service類的實現將會不同。很顯然,windows平臺下當然是win_iocp_io_service類為實現了(不過我一開始還以為win_iocp_io_service是直接拿出來用的呢,還在疑惑這樣怎么有移植性呢?官方文檔也對該類只字不提,其實我卡殼就是卡在這里了,差點就直接用這個類了^_^!)。

那么就分析一下win_iocp_io_service的代碼吧,這里完全是用IOCP來路由各種任務,大家使用post來委托任務,內部調用的其實是IOCP的PostQueuedCompletionStatus函數,然后線程們用run來接受任務,內部其實是阻塞在IOCP的GetQueuedCompletionStatus函數上,一旦有了任務就立即返回,執行完后再一個循環,繼續阻塞在這里等待下一個任務的到來,這種設計思想堪稱神奇,對線程、服務以及任務完全解耦,靈活度達到了如此高度,不愧為boost庫的東西!我只能有拜的份了...

說一下總體的設計思想,其實io_service就像是勞工中介所,而一個線程就是一個勞工,而調用post的模塊相當于富人們,他們去中介所委托任務,而勞工們就聽候中介所的調遣去執行這些任務,任務的內容就寫在富人們給你的handler上,也就是函數指針,指針指向具體實現就是任務的實質內容。其實在整個過程中,富人們都不知道是哪個勞工幫他們做的工作,只知道是中介所負責完成這些就可以了。這使得邏輯上的耦合降到了最低。不過這樣的比喻也有個不恰當的地方,如果硬要這樣比喻的話,我只能說:其實勞工里面也有很多富人的^o^! 。很多勞工在完成任務的過程中自己也托給中介所一些任務,然后這些任務很可能還是自己去完成。這也難怪,運行代碼的總是這些線程,那么調用post的肯定也會有這些線程了,不過不管怎么說,如此循環往復可以解決問題就行,比喻不見得就得恰當,任何事物之間都不可能完全相同,只要能闡述思想就行。

最后還要說明的一點就是:委托的任務其實可以設定執行的時間的,很不錯的設定,內部實現則是通過定時器原理,GetQueuedCompletionStatus有一個等待時間的參數似乎被用在這方面,還有源碼中的定時器線程我并沒有過多的去理解,總之大體原理已基本掌握,剩下的就是使勁的用它了?。?!

另外為了方便人交流,在這里插入一些代碼可能更容易讓人理解吧,
下面這個是啟動服務時的代碼:
void ServerFramework::run()
{
    boost::thread_group workers;
    
for (uint32 i = 0; i < mWorkerCount; ++i)
        workers.create_thread(
            boost::bind(
&boost::asio::io_service::run, &mIoService));
    workers.join_all();
}

在打開前就得分配好任務,否則線程們運行起來就退出了,阻塞不住,任務的分配就交給open函數了,它是分配了監聽端口的任務,一旦有了連接就會拋出一個任務,其中一個線程就會開始行動啦。
void ServerFramework::open(const String& address, const String& port, uint32 nWorkers /*= DEFAULT_WORKER_COUNT*/)
{
    
// Open the acceptor with the option to reuse the address (i.e. SO_REUSEADDR).
    boost::asio::ip::tcp::resolver resolver(mIoService);
    boost::asio::ip::tcp::resolver::query query(address, port);
    boost::asio::ip::tcp::endpoint endpoint 
= *resolver.resolve(query);

    mAcceptor.open(endpoint.protocol());
    mAcceptor.set_option(boost::asio::ip::tcp::acceptor::reuse_address(
true));
    mAcceptor.bind(endpoint);
    mAcceptor.listen();

    mNextConnection 
= new Connection(this);
    mAcceptor.async_accept(mNextConnection
->getSocket(),
        boost::bind(
&ServerFramework::__onConnect, this,
        boost::asio::placeholders::error));

    mWorkerCount 
= nWorkers;
    
if (mWorkerCount == DEFAULT_WORKER_COUNT)
    
{
        mWorkerCount 
= 4;
    }

}

open函數中給io_service的一個任務就是在有鏈接訪問服務器端口的情況下執行ServerFramework::__onConnect函數,有一點需要格外注意的,io_service必須時刻都有任務存在,否則線程io_service::run函數將返回,于是線程都會結束并銷毀,程序將退出,所以,你必須保證無論何時都有任務存在,這樣線程們即使空閑了也還是會繼續等待,不會銷毀。所以,我在ServerFramework::__onConnect函數中又一次給了io_service相同的任務,即:繼續監聽端口,有鏈接了還是調用ServerFramework::__onConnect函數。如果你在ServerFramework::__onConnect執行完了還沒有給io_service任務的話,那么一切都晚了...... 代碼如下:
void ServerFramework::__onConnect(const BoostSysErr& e)
{
    
if (e)
    
{
        MOELOG_DETAIL_WARN(e.message().c_str());
    }


    Connection
* p = mNextConnection;
    mNextConnection 
= new Connection(this);

    
// 再次進入監聽狀態
    mAcceptor.async_accept(mNextConnection->getSocket(),
        boost::bind(
&ServerFramework::__onConnect, this,
        boost::asio::placeholders::error));

    
// 處理當前鏈接
    __addConnection(p);
    p
->start();
}

最后,展示一下這個類的所有成員變量吧:
    // 用于線程池異步處理的核心對象
    boost::asio::io_service mIoService;

    
// 網絡鏈接的接收器,用于接收請求進入的鏈接
    boost::asio::ip::tcp::acceptor mAcceptor;

    
// 指向下一個將要被使用的鏈接對象
    Connection* mNextConnection;

    
// 存儲服務器鏈接對象的容器
    ConnectionSet mConnections;

    
//// 為鏈接對象容器準備的strand,防止并行調用mConnections
    //boost::asio::io_service::strand mStrand_mConnections;

    
// 為鏈接對象容器準備的同步鎖,防止并行調用mConnections
    boost::mutex mMutex4ConnSet;

    
// 為控制臺輸出流準備的strand,防止并行調用std::cout
    AsioService::strand mStrand_ConsoleIostream;

    
// 工作線程的數量
    uint32 mWorkerCount;



但愿這篇隨筆也能對正在研究asio的朋友們有所幫助吧。

posted on 2009-06-26 22:14 釀妹汁 閱讀(9971) 評論(15)  編輯 收藏 引用 所屬分類: C++

評論

# re: ASIO攻破!!! 2009-06-27 09:40 zhaoyang0618

感謝!也在學習ASIO。
能否簡單的說一下如何在ASIO中使用thread_group呢?或者說在ASIO中使用線城池。  回復  更多評論   

# re: ASIO攻破?。?! 2009-06-30 17:15 亨德列克

高  回復  更多評論   

# re: ASIO攻破?。。? 2009-07-04 16:03

@zhaoyang0618
其實asio將線程與框架分離了開來,但是會在內部輔助你進行同步調用,完全不用你去擔心。你只要在線程的主函數中調用io_service::run方法就可以了,或者干脆將io_service::run當成線程的主函數也行,就像我所用的方法一樣:
boost::thread_group workers;
for (uint32 i = 0; i < mWorkerCount; ++i)
workers.create_thread(
boost::bind(&boost::asio::io_service::run, &mIoService));
workers.join_all();  回復  更多評論   

# re: ASIO攻破!??! 2009-07-04 16:26

@zhaoyang0618
博客正文已經添加了新的內容,還望能指正。  回復  更多評論   

# re: ASIO攻破?。。? 2009-07-04 17:06 99網上書店

開源軟件的領袖和先驅,從來沒有領過一天工資  回復  更多評論   

# re: ASIO攻破?。。? 2009-07-05 23:27 99書城

能否簡單的說一下如何在ASIO中使用thread_group呢  回復  更多評論   

# re: ASIO攻破?。。未登錄] 2009-09-02 21:17 ace

喜歡用ace  回復  更多評論   

# re: ASIO攻破!!! 2009-10-27 16:14 dc

為什么我一直覺得asio似乎并沒有將io/work分開呢?
按照這種async模型的話,只要work卡住不去執行async_recv的話一直無法從網絡緩沖區中提取出packet,最終可能導致緩沖區飽和?  回復  更多評論   

# re: ASIO攻破!??! 2009-10-27 16:16 dc

不是數據包緩沖區..是io消息列隊..  回復  更多評論   

# re: ASIO攻破?。?! 2010-11-05 16:41 冬瓜

為了防止io_service.run退出,可以增加一個work,這樣它就可以使它一直處理boost::asio::io_service::work  回復  更多評論   

# re: ASIO攻破?。?![未登錄] 2012-08-30 13:21 jason

你好,能給我一份關于boost的IOCP,完整的代碼嗎?對我而言,特別重要,希望大蝦幫助。  回復  更多評論   

# re: ASIO攻破?。?![未登錄] 2012-08-30 13:23 jason

我的郵件是zxl200406@163.com
謝謝您的幫助。  回復  更多評論   

# re: ASIO攻破?。?! 2012-09-18 23:05 shanoa

@jason
boost源碼里有的呀,你上www.boost.org下載boost源碼吧  回復  更多評論   

# re: ASIO攻破!??![未登錄] 2013-07-10 16:34 stonexin

mAcceptor.bind(endpoint);

這一行代碼最好做個判斷,加上error_code.不然ip地址或者端口不正確,會導致意外的崩潰。
boost::system::error_code ec;
mAcceptor.bind(endpoint,ec);
if(ec)
{
std::cout<<"error: "<<ec.message()<<std::endl;
}  回復  更多評論   

# re: ASIO攻破?。?! 2013-08-16 17:24 feelworld

你好 能給一份實現這個框架的代碼嗎 不勝感激 276090345@qq.com  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产成人精品女人久久久 | 欧美激情亚洲自拍| 夜久久久久久| 午夜老司机精品| 欧美一级大片在线观看| 99成人在线| 一本色道婷婷久久欧美| 亚洲免费观看视频| 亚洲免费成人| 亚洲激情电影在线| 一本色道久久综合亚洲精品婷婷| 欧美激情第3页| 久久精品观看| 欧美福利视频网站| 美女黄毛**国产精品啪啪| 欧美在线一二三| 男女精品网站| 欧美激情第1页| 亚洲视频综合在线| 亚洲女女做受ⅹxx高潮| 欧美一区成人| 欧美激情第9页| 欧美人与性禽动交情品| 亚洲少妇诱惑| 亚洲最新中文字幕| 亚洲嫩草精品久久| 欧美激情综合亚洲一二区| 宅男噜噜噜66一区二区66| 久久久久久久久久久久久女国产乱 | 欧美国产激情二区三区| 欧美成人资源网| 欧美一级久久| 亚洲风情在线资源站| 亚洲人成网在线播放| 另类尿喷潮videofree| 亚洲日本中文字幕免费在线不卡| 艳妇臀荡乳欲伦亚洲一区| 91久久久亚洲精品| 欧美亚洲日本网站| 嫩草成人www欧美| 国产亚洲精品激情久久| 91久久久在线| 午夜亚洲影视| 久久久蜜桃精品| 亚洲精品久久久久中文字幕欢迎你 | 国产精品日韩一区| 亚洲第一网站| 亚洲深夜福利在线| 亚洲素人一区二区| 亚洲国产免费看| 午夜一区二区三视频在线观看| 欧美激情五月| 激情成人在线视频| 99视频在线精品国自产拍免费观看| 久久婷婷国产综合精品青草| 亚洲韩国一区二区三区| 99精品国产在热久久| 欧美在线首页| 国产精品久久久久天堂| 在线观看的日韩av| 亚洲国产精品一区| 久久精品夜色噜噜亚洲aⅴ| 欧美岛国激情| 久久色在线播放| 国产伦精品一区二区三区在线观看 | 日韩视频中文字幕| 久久琪琪电影院| 亚洲一二三区视频在线观看| 国产精品国产a级| 99这里只有久久精品视频| 亚洲欧美在线免费观看| 亚洲伊人网站| 欧美午夜精品久久久久久人妖| 国产精品视频不卡| 亚洲尤物在线视频观看| 亚洲欧洲日本国产| 欧美日本亚洲| 一区二区三区欧美在线| 亚洲国产精品一区制服丝袜| 欧美高清视频在线播放| 亚洲高清不卡av| 亚洲区国产区| 欧美日韩国语| 一片黄亚洲嫩模| 在线一区亚洲| 国产精品任我爽爆在线播放| 亚洲一区中文| 亚洲手机成人高清视频| 国产精品日韩一区| 久久精品视频在线看| 欧美综合国产| 亚洲第一区在线观看| 91久久久久久久久| 欧美系列亚洲系列| 欧美久久九九| 一区二区欧美国产| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 午夜久久电影网| 欧美永久精品| 极品av少妇一区二区| 欧美国产日韩二区| 欧美亚一区二区| 欧美一区二区国产| 久久www成人_看片免费不卡| 亚洲精品国产视频| 一区二区三区.www| 欧美福利小视频| 欧美日韩一区二区在线视频| 亚洲欧美日韩人成在线播放| 欧美a级一区| 午夜精品视频在线观看| 性欧美长视频| 亚洲第一页在线| 亚洲自拍偷拍福利| 国外精品视频| 一区二区三区**美女毛片| 国产亚洲一区在线| 久久国产精品亚洲va麻豆| 欧美女同视频| 久久婷婷av| 国产精品视频免费| 亚洲国产高清在线| 国产欧美综合一区二区三区| 亚洲三级视频在线观看| 国产亚洲日本欧美韩国| 中文一区在线| 亚洲欧洲日夜超级视频| 在线视频亚洲一区| 亚洲人成小说网站色在线| 亚洲一区二区三区精品在线观看| 国内在线观看一区二区三区| 亚洲久久在线| 樱桃成人精品视频在线播放| 亚洲欧美日韩成人高清在线一区| 91久久精品一区二区三区| 亚洲一品av免费观看| 在线免费观看视频一区| 午夜激情一区| 久久精品国产第一区二区三区最新章节| 麻豆国产va免费精品高清在线| 亚洲一区久久久| 欧美人与性动交cc0o| 欧美福利小视频| 亚洲人成网在线播放| 久久福利精品| 欧美亚洲一区二区三区| 国产伦精品一区二区三区在线观看 | 免费成人在线观看视频| 黄色小说综合网站| 亚洲一区在线视频| 一区二区亚洲欧洲国产日韩| 午夜国产精品影院在线观看| 亚洲淫性视频| 国产无遮挡一区二区三区毛片日本| 亚洲日本中文字幕区| 欧美日韩视频在线观看一区二区三区| 亚洲国产成人在线播放| 亚洲国产你懂的| 亚洲图色在线| 久久成人免费视频| 国产精品一区二区三区乱码| 亚洲欧美在线aaa| 亚洲欧美日韩精品久久| 国产精品v亚洲精品v日韩精品 | 欧美激情麻豆| 欧美激情一区二区三区蜜桃视频| 老司机凹凸av亚洲导航| 一区二区三区在线免费播放| 久久久久女教师免费一区| 欧美刺激午夜性久久久久久久| 欧美激情精品久久久久久变态| 亚洲第一天堂av| 欧美三区不卡| 午夜亚洲一区| 亚洲欧美影音先锋| 国内精品久久久久影院优| 久久精品九九| 亚洲靠逼com| 亚洲欧美久久久| 欧美国产一区二区| 亚洲欧美日韩一区二区在线| 久久深夜福利免费观看| 日韩午夜免费视频| 国产精品久久久久国产a级| 午夜一区在线| 亚洲另类一区二区| 久久av一区| 亚洲国产乱码最新视频| 欧美日韩亚洲一区二区三区四区| 亚洲影院色无极综合| 另类专区欧美制服同性| 91久久中文字幕| 国产精品久久久久久久久久久久久久| 亚洲永久在线观看| 欧美福利视频| 亚洲性视频网站| 亚洲三级视频| 久久夜色精品国产欧美乱极品| 国产视频观看一区| 欧美三级电影大全|