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

那誰的技術(shù)博客

感興趣領(lǐng)域:高性能服務(wù)器編程,存儲,算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數(shù)據(jù)加載中……

服務(wù)器定時器處理要注意的問題

今天早上,例行巡查服務(wù)器,我用strace命令跟蹤服務(wù)器進程的時候, 發(fā)現(xiàn)有幾個服務(wù)器進程出現(xiàn)了死鎖情況, gdb繼續(xù)跟進,顯示如下:

gdb) bt
#
0  0x00ff9410 in __kernel_vsyscall ()
#
1  0x004d593e in __lll_mutex_lock_wait () from /lib/libc.so.6
#
2  0x00465b38 in _L_lock_14080 () from /lib/libc.so.6
#
3  0x00464df4 in free () from /lib/libc.so.6
#
4  0x006c7691 in operator delete () from /usr/lib/libstdc++.so.6
#
5  0x08059cfb in __gnu_cxx::new_allocator<std::_List_node<TTimeEvent> >::deallocate (this=0x98e0064, __p=0x98e1218)
    at 
/usr/lib/gcc/i386-redhat-linux/4.1.1/../../../../include/c++/4.1.1/ext/new_allocator.h:94
#
6  0x08059d20 in std::_List_base<TTimeEvent, std::allocator<TTimeEvent> >::_M_put_node (this=0x98e0064, __p=0x98e1218)
    at 
/usr/lib/gcc/i386-redhat-linux/4.1.1/../../../../include/c++/4.1.1/bits/stl_list.h:320
#
7  0x08059d81 in std::list<TTimeEvent, std::allocator<TTimeEvent> >::_M_erase (this=0x98e0064, __position=
      {_M_node 
= 0x98e1218}) at /usr/lib/gcc/i386-redhat-linux/4.1.1/../../../../include/c++/4.1.1/bits/stl_list.h:1150
#
8  0x08059db3 in std::list<TTimeEvent, std::allocator<TTimeEvent> >::pop_front (this=0x98e0064)
    at 
/usr/lib/gcc/i386-redhat-linux/4.1.1/../../../../include/c++/4.1.1/bits/stl_list.h:747
#
9  0x08059334 in CTimerManager::Process (this=0x98e0058) at src/timermanager.cpp:168
#
10 0x080597dd in Process (nSigNo=14) at src/timermanager.cpp:199
#
11 <signal handler called>
#
12 0x004612ba in _int_free () from /lib/libc.so.6
#
13 0x00464e00 in free () from /lib/libc.so.6
#
14 0x006c7691 in operator delete () from /usr/lib/libstdc++.so.6
#
15 0x006a424d in std::string::_Rep::_M_destroy () from /usr/lib/libstdc++.so.6
#
16 0x0069e40f in std::basic_stringbuf<char, std::char_traits<char>, std::allocator<char> >::~basic_stringbuf ()
   from 
/usr/lib/libstdc++.so.6
#
17 0x0069fd7f in std::basic_stringstream<char, std::char_traits<char>, std::allocator<char> >::~basic_stringstream ()
   from 
/usr/lib/libstdc++.so.6
#
18 0x080524ea in CDBMoudle::Insert (this=0x98e6e80, tFixkey=@0xbfe1c6ec) at src/dbmoudle.cpp:59
#
19 0x08051718 in CConnectionTask::ProcFixContent (this=0x98e6510) at src/connectiontask.cpp:218
#
20 0x0805196e in CConnectionTask::HandleRead (this=0x98e6510) at src/connectiontask.cpp:86
#
21 0x08051a0f in CConnectionTask::Handle (this=0x98e6510, nEvent=1) at src/connectiontask.cpp:52
#
22 0x080585af in IServer::Run (this=0xbfe1c7e0) at src/server.cpp:133
#
23 0x08055328 in main (argc=2, argv=0xbfe1c8b4) at src/main.cpp:19
在#13處,調(diào)用free函數(shù), 然后進入與之相關(guān)的libc函數(shù)調(diào)用中.但是, 在這個調(diào)用還沒有完結(jié)之前被定時器管理模塊中斷, 進入了定時器處理的部分, 在在這個處理中同樣調(diào)用了free函數(shù), 于是出現(xiàn)了死鎖的情況--因為malloc/free函數(shù)族不是可重入的, 在這里有一篇相關(guān)的文章.

我曾經(jīng)想在我的服務(wù)器代碼中盡量減少對象的構(gòu)造/析構(gòu), 但是想了一下, 這個策略不是治本的辦法, 這意味著我必須在寫代碼的時候處處小心, 今天可能在A處出現(xiàn)死鎖, 明天可能會在B處出現(xiàn).而且, 由于使用的是C++, 一些局部對象的構(gòu)造和析構(gòu)是不可避免的.

于是, 解決這個問題的思路就改變?yōu)?盡量的簡單化定時器處理操作.目前我想到的一個策略時, 一個定時器被觸發(fā)的時候, 置一個標志位, 而不是在在觸發(fā)的時候調(diào)用相應(yīng)的處理函數(shù), 然后在服務(wù)器的主循環(huán)中判斷是否被置位, 如果是的話再去調(diào)用相關(guān)的處理函數(shù).

于是, 原來的思路就是:
// 該函數(shù)在定時器到時的時候被觸發(fā)
void signal()
{
   
// 定時器處理函數(shù)
   dosomething();
}

while(1)
{
   服務(wù)器主循環(huán);
}

修改之后的思路是:
int violate g_alarm = 0;

// 該函數(shù)在定時器到時的時候被觸發(fā)
void signal()
{
  g_alarm 
= 1;
}

while(1)
{
   服務(wù)器主循環(huán);
   
if (g_alarm)
   {
       
// 定時器處理函數(shù)
      dosomething();
      g_alarm 
= 0;
   }
}


這是大概的模型上面的改變.這是我目前能想到的處理該問題的最好辦法, 如果哪位有更好的辦法歡迎補充.


posted on 2008-10-16 19:08 那誰 閱讀(5104) 評論(10)  編輯 收藏 引用 所屬分類: 服務(wù)器設(shè)計Linux/Unix

評論

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

認同你的做法
這種做法很常見,簡單實用
2008-10-16 21:49 | LOGOS

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

內(nèi)存池
2008-10-17 12:46 | kevin

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

我覺得定時器只負責(zé)產(chǎn)生消息即可。
2008-10-17 13:23 | lihui

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

是不是要加鎖?小弟不才,請指教.
while & signal 都修改了這個violate,所以考慮要不要加鎖?
2008-10-20 08:39 | ocean

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

明白了,不加鎖,呵呵,讀你的東西真是受用.
2008-10-20 08:42 | ocean

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

這樣的做法 很簡單,但是很難看。

效率高一些,卻不優(yōu)雅。 擴展比較難。

如果多一些事件的話,可能把主線程搞成非常亂
2009-04-24 17:26 | 妞妞

# re: 服務(wù)器定時器處理要注意的問題[未登錄]  回復(fù)  更多評論   

@妞妞
那有什么好的建議沒有呢?
2009-04-27 17:07 | 那誰

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

建議看看libevent的定時器實現(xiàn)。
很優(yōu)美的實現(xiàn)。將IO,信號和定時器都作為事件來統(tǒng)一進行分發(fā)。
2009-12-26 05:35 | 浩毛

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

假設(shè)現(xiàn)在g_alarm = 1,進入了if中正在處理do_something,恰好現(xiàn)在產(chǎn)生一個信號使 g_alarm = 1,當do_something退出時, g_alarm = 0了,所以丟失了一個信號事件。這個問題該怎么辦?
2011-01-15 10:18 | xunuj

# re: 服務(wù)器定時器處理要注意的問題  回復(fù)  更多評論   

剛從博主《libevent 事件處理框架分析》中看到
“信號事件:所有的信號都注冊回調(diào)函數(shù)為evsignal_handler(在signal.c中),這個函數(shù)的功能就是在某信號被觸發(fā)的時候?qū)⒃撔盘柋挥|發(fā)的計數(shù)器加1,同時置一個標志位表示有信號被觸發(fā).“
2011-01-15 10:34 | xunuj
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品成人| 久久精品一区二区三区不卡| 一卡二卡3卡四卡高清精品视频 | 欧美国产日韩xxxxx| 麻豆精品网站| 欧美韩日高清| 欧美三级免费| 国产精品久久久久久久午夜 | 欧美日本在线看| 欧美精品成人一区二区在线观看| 欧美精品一区二区三区在线播放| 欧美午夜精品久久久| 国产欧美二区| 在线观看视频日韩| 99国产精品久久久| 欧美亚洲网站| 久久久亚洲国产美女国产盗摄| 免费视频一区二区三区在线观看| 欧美国产日韩视频| 中国成人在线视频| 久久久久综合一区二区三区| 欧美日韩八区| 在线观看欧美黄色| 一本久久a久久免费精品不卡| 亚洲综合精品四区| 免费不卡欧美自拍视频| 亚洲精品老司机| 亚洲视频在线观看免费| 午夜在线a亚洲v天堂网2018| 免费欧美网站| 国产精品人成在线观看免费 | 一本久久a久久精品亚洲| 欧美一区二区三区在线看| 欧美国产精品久久| 国内精品久久久久伊人av| 亚洲一卡久久| 亚洲国产一区二区三区a毛片| 亚洲欧美精品伊人久久| 欧美日韩精品欧美日韩精品| 在线看视频不卡| 欧美制服丝袜第一页| 亚洲精品国产精品乱码不99按摩| 久久激情五月婷婷| 欧美国产一区视频在线观看| 一本一本大道香蕉久在线精品| 久久久久久久91| 国产精品视频xxxx| 一区二区高清视频| 欧美激情a∨在线视频播放| 久久国产综合精品| 国产模特精品视频久久久久| 亚洲午夜精品福利| 亚洲国产高清高潮精品美女| 久久激情综合| 国内久久精品视频| 久久久精彩视频| 午夜精品国产| 国产欧美综合一区二区三区| 亚洲综合色丁香婷婷六月图片| 欧美黄色aa电影| 免费观看亚洲视频大全| 亚洲国语精品自产拍在线观看| 麻豆精品视频在线观看| 久久黄色影院| 亚洲电影免费在线观看| 免费高清在线一区| 狂野欧美激情性xxxx欧美| 亚洲成色www久久网站| 欧美mv日韩mv国产网站| 麻豆av一区二区三区| 91久久久国产精品| 亚洲人线精品午夜| 欧美三区不卡| 久久成人精品| 久久久久久久波多野高潮日日| 一区免费观看视频| 狼人天天伊人久久| 欧美1区免费| 在线午夜精品| 亚洲在线日韩| 国产一区二区三区免费观看| 久久成人免费电影| 久久资源在线| 亚洲色图在线视频| 午夜亚洲视频| 亚洲国产色一区| 亚洲人在线视频| 国产精品影片在线观看| 老司机免费视频久久| 欧美88av| 久久精品免费电影| 欧美v亚洲v综合ⅴ国产v| 夜夜嗨av一区二区三区网站四季av| 99视频在线观看一区三区| 国产精品一区三区| 亚洲福利视频一区二区| 欧美亚洲成人免费| 老司机午夜精品视频| 欧美国产日本| 久久亚洲欧美国产精品乐播| 欧美日韩国产亚洲一区| 久久国产精品一区二区三区四区 | 久久久久成人精品| 久久嫩草精品久久久精品一| 国产精品99久久不卡二区| 久久精品视频99| 日韩午夜在线观看视频| 欧美一级在线播放| 一区二区免费在线观看| 欧美诱惑福利视频| 亚洲性线免费观看视频成熟| 久久久久在线观看| 欧美在线一区二区| 欧美精品一区二区三区一线天视频| 久久www成人_看片免费不卡| 欧美视频第二页| 欧美激情91| 亚洲第一天堂无码专区| 亚洲一区二区三区高清| 一区二区日韩| 欧美夫妇交换俱乐部在线观看| 欧美一区二区三区视频| 欧美日韩午夜| 亚洲大胆人体视频| 国产一区二区三区成人欧美日韩在线观看 | 亚洲一区国产视频| 久久在线免费视频| 久久一区二区三区国产精品| 国产农村妇女毛片精品久久莱园子 | 欧美精品国产一区| 美女露胸一区二区三区| 国产香蕉97碰碰久久人人| 99在线热播精品免费| 亚洲精品一区二区网址| 欧美成人蜜桃| 最新高清无码专区| 亚洲伦理网站| 欧美日韩国产影院| 日韩亚洲欧美成人一区| 在线亚洲欧美专区二区| 欧美日韩午夜在线视频| 亚洲国产日韩欧美在线99| 亚洲激情一区二区三区| 久久亚洲欧美国产精品乐播| 久久亚洲二区| 91久久精品国产91性色| 欧美激情欧美激情在线五月| 亚洲欧洲一区二区在线播放| 一本色道**综合亚洲精品蜜桃冫| 欧美精品福利视频| 一个人看的www久久| 亚洲欧美久久久| 国产亚洲成av人在线观看导航 | 亚洲精品视频免费在线观看| 亚洲全部视频| 欧美手机在线| 亚洲欧美中文日韩在线| 亚洲伊人网站| 国产亚洲精品资源在线26u| 久久久久久有精品国产| 亚洲福利精品| 欧美特黄a级高清免费大片a级| 亚洲主播在线播放| 久久久亚洲欧洲日产国码αv | 亚洲国产小视频| 亚洲综合第一| 亚洲福利国产精品| 欧美网站在线观看| 久久国产成人| 亚洲人线精品午夜| 久久免费视频一区| 夜夜嗨av色综合久久久综合网| 国产精品婷婷午夜在线观看| 久久综合色一综合色88| 一区二区三区四区五区精品视频| 久久不射中文字幕| 99re热这里只有精品视频| 国产视频一区欧美| 欧美人妖另类| 久久综合99re88久久爱| 中文一区在线| 亚洲国产精品一区二区三区| 久久精品国产99国产精品澳门| 亚洲美女视频网| 狠狠色狠狠色综合人人| 国产精品xxx在线观看www| 免费成人小视频| 亚欧成人在线| 99天天综合性| 亚洲激情视频| 久久亚洲私人国产精品va| 一本大道久久a久久精品综合 | 亚洲在线观看免费| 亚洲黄网站黄| 国产欧美精品xxxx另类| 欧美日本一区| 久久综合色88| 久久青青草综合| 欧美在线观看视频在线| 亚洲美女视频在线观看|