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

那誰的技術博客

感興趣領域:高性能服務器編程,存儲,算法,Linux內核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數據加載中……

服務器定時器處理要注意的問題

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

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處,調用free函數, 然后進入與之相關的libc函數調用中.但是, 在這個調用還沒有完結之前被定時器管理模塊中斷, 進入了定時器處理的部分, 在在這個處理中同樣調用了free函數, 于是出現了死鎖的情況--因為malloc/free函數族不是可重入的, 在這里有一篇相關的文章.

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

于是, 解決這個問題的思路就改變為:盡量的簡單化定時器處理操作.目前我想到的一個策略時, 一個定時器被觸發的時候, 置一個標志位, 而不是在在觸發的時候調用相應的處理函數, 然后在服務器的主循環中判斷是否被置位, 如果是的話再去調用相關的處理函數.

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

while(1)
{
   服務器主循環;
}

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

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

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


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


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

評論

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

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

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

內存池
2008-10-17 12:46 | kevin

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

我覺得定時器只負責產生消息即可。
2008-10-17 13:23 | lihui

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

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

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

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

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

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

效率高一些,卻不優雅。 擴展比較難。

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

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

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

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

建議看看libevent的定時器實現。
很優美的實現。將IO,信號和定時器都作為事件來統一進行分發。
2009-12-26 05:35 | 浩毛

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

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

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

剛從博主《libevent 事件處理框架分析》中看到
“信號事件:所有的信號都注冊回調函數為evsignal_handler(在signal.c中),這個函數的功能就是在某信號被觸發的時候將該信號被觸發的計數器加1,同時置一個標志位表示有信號被觸發.“
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>
            91久久久一线二线三线品牌| 亚洲男女毛片无遮挡| 欧美国产日本高清在线| 久久影视三级福利片| 久久福利毛片| 裸体素人女欧美日韩| 另类专区欧美制服同性| 欧美h视频在线| 欧美日韩另类字幕中文| 国产精品成人久久久久| 国产精自产拍久久久久久| 狠狠色伊人亚洲综合成人| 激情欧美一区二区三区在线观看| 亚洲电影免费观看高清完整版| 亚洲精品国产精品国自产在线 | 国内一区二区三区| 亚洲国内自拍| 午夜精品一区二区三区在线| 欧美在线中文字幕| 欧美大香线蕉线伊人久久国产精品| 亚洲精品老司机| 午夜视频在线观看一区二区| 久久久久亚洲综合| 欧美日韩不卡视频| 国产一区二区高清视频| 一本色道久久| 老司机亚洲精品| 在线亚洲伦理| 免费久久99精品国产自在现线| 欧美色图一区二区三区| 一区在线播放视频| 亚洲欧美国产高清va在线播| 男女精品视频| 亚洲永久免费视频| 欧美激情一区二区三区在线视频| 国产日韩欧美一区二区| 在线一区二区三区做爰视频网站 | 久久黄色级2电影| 亚洲二区视频| 久久精品99无色码中文字幕| 欧美三级日本三级少妇99| 在线国产精品播放| 久久成人18免费网站| 日韩视频永久免费观看| 久久综合亚州| 精品盗摄一区二区三区| 欧美在线啊v一区| 99国产欧美久久久精品| 欧美电影在线观看完整版| 激情久久中文字幕| 久久久国产一区二区| 亚洲综合不卡| 国产精品入口尤物| 亚洲欧美日韩成人| 正在播放亚洲一区| 国产精品麻豆欧美日韩ww| 亚洲网站在线| 亚洲网站在线| 国产精品羞羞答答xxdd| 欧美一区二区精品| 欧美一级欧美一级在线播放| 国产午夜亚洲精品不卡| 久久久久一区| 狼人社综合社区| 亚洲精品中文字| 亚洲欧洲精品一区二区三区不卡 | 久久久www免费人成黑人精品| 亚洲视频一起| 国产精品亚洲网站| 欧美在线播放一区| 欧美一区二区三区在线| 国产综合色产| 欧美sm重口味系列视频在线观看| 久久伊伊香蕉| 最近中文字幕日韩精品| 欧美激情视频给我| 欧美日本在线一区| 亚洲午夜羞羞片| 亚洲制服av| 狠狠做深爱婷婷久久综合一区| 免费不卡亚洲欧美| 欧美日本中文字幕| 欧美在线视频全部完| 久久国产主播精品| 亚洲精品国精品久久99热一| 99ri日韩精品视频| 国产在线观看一区| 狠狠色丁香婷婷综合久久片| 欧美一区=区| 一本色道**综合亚洲精品蜜桃冫| 国产精品久久久久免费a∨| 久久不射2019中文字幕| 蜜桃av噜噜一区二区三区| 正在播放日韩| 久久爱另类一区二区小说| 亚洲日韩欧美视频一区| 亚洲图中文字幕| 伊人久久综合| 99re66热这里只有精品4| 国内精品久久久久久影视8| 欧美激情中文字幕一区二区| 国产精品久久久久久亚洲毛片| 狂野欧美性猛交xxxx巴西| 欧美精品激情blacked18| 久久精品99国产精品酒店日本| 美女视频黄 久久| 欧美一区成人| 欧美日韩在线影院| 欧美成人一区二免费视频软件| 国产精品每日更新| 亚洲国产小视频在线观看| 国产精品一区二区在线观看不卡| 欧美黑人国产人伦爽爽爽| 国产亚洲欧美一区在线观看| 日韩视频一区二区三区在线播放| 1204国产成人精品视频| 亚洲一区二区三区在线看 | 香蕉成人伊视频在线观看| 日韩一级不卡| 玖玖精品视频| 久久久久一区| 国产精品美女999| 亚洲美女性视频| 亚洲精选视频在线| 狂野欧美一区| 美腿丝袜亚洲色图| 国产综合网站| 欧美一区日韩一区| 欧美在线地址| 国产日本欧洲亚洲| 午夜精品国产更新| 久久精品国产v日韩v亚洲 | 一区二区三区中文在线观看| 亚洲一区二区在| 亚洲欧美日韩精品久久| 欧美精品乱码久久久久久按摩| 欧美国产日韩一区二区| 亚洲国产日韩欧美在线99| 麻豆视频一区二区| 欧美福利一区| 日韩系列欧美系列| 欧美精品不卡| 日韩一区二区精品| 亚洲在线观看| 国产精品视频自拍| 亚洲欧美在线一区二区| 久久成人羞羞网站| 韩国三级电影一区二区| 99av国产精品欲麻豆| 麻豆国产精品va在线观看不卡| 欧美亚洲综合网| 国产日韩精品视频一区| 亚洲欧美激情在线视频| 欧美亚洲网站| 狠狠操狠狠色综合网| 久久久天天操| 亚洲国产欧美一区二区三区久久| 亚洲人www| 欧美日韩在线播放一区| 一区二区三区四区蜜桃| 午夜精品久久久久久久白皮肤 | 国产精品久久久久av免费| 中文在线一区| 久久精品免费电影| 91久久国产综合久久91精品网站| 欧美电影免费观看高清| 一本一道久久综合狠狠老精东影业| 午夜一区二区三视频在线观看| 国内久久婷婷综合| 欧美大片免费观看| 亚洲欧美日韩国产成人精品影院 | 中文日韩在线| 国产欧美69| 女人天堂亚洲aⅴ在线观看| 一区二区高清视频在线观看| 久久久久免费视频| 一区二区免费在线播放| 国模精品娜娜一二三区| 欧美精品一区二区在线播放| 亚洲欧美久久| 亚洲精品国产精品久久清纯直播| 欧美一区二区三区四区在线观看地址 | 国产女人aaa级久久久级| 久久亚洲精品视频| 日韩一区二区电影网| 免费成人毛片| 欧美在线国产| 制服丝袜激情欧洲亚洲| 亚洲高清不卡在线观看| 国产精品亚洲精品| 欧美日韩国产成人在线91| 久久久久久亚洲精品中文字幕| 宅男噜噜噜66一区二区| 亚洲片在线资源| 欧美wwwwww| 久久综合给合久久狠狠色| 午夜亚洲激情| 亚洲免费一区二区| 亚洲无限乱码一二三四麻| 日韩视频亚洲视频|