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

隨筆 - 119  文章 - 290  trackbacks - 0

博客搬家了哦,請移步
叫我abc

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306720
  • 排名 - 84

最新評論

閱讀排行榜

引子

最近用機器人做NPC的壓力測試,突然發現一臺機器能支持的機器人數量劇減,而且運行一段時間后整臺機器直接內存耗光死機.經過觀察,發現1個機器人在運行一段時間之后內存能占用到120M之多,而且還在不斷增加,同時內存無法手動回收.
以前1個機器人大概消耗10M-20M的內存,這次的消耗明顯異常了,所以初步判斷邏輯上存在lua對象泄漏:在某些沒有注意到的地方長期引用著不再使用的lua對象,導致這些對象無法被gc.
為了解決這個問題,google到一篇相似問題的文章,lua內存泄漏查證.文章的大概思路就是:

  1. 資源跟蹤,定位哪些資源泄漏
  2. 引用檢索,查找泄漏的資源被哪個模塊引用

資源跟蹤

定義:將應用中分配的lua對象添加到一個弱表中.執行完整的gc后,還能從弱表中索引到的對象表示它還在別的地方被引用著,可能是正常的引用,也可能是一處內存泄漏.
我使用了一個弱鍵表,該表以要跟蹤的lua對象為鍵,該對象的描述信息為值.其中的描述信息包含了對象描述和對象創建時間兩項.對象描述用于區別不同的跟蹤對象;創建時間則用來在打印弱表的時候判斷對象的存活時間是否合理.
我定義的接口是:function TraceMem(obj, description);

雖然機器人可以動態的加載無盡的模塊,但是幾乎所有的資源都是由幾個基礎模塊開始分配的,所以添加對象跟蹤相對比較簡單.經過修改,運行,測試,從弱表中打印出來的數據發現,機器人中有大量的移動包和移動相關的計時器對象沒有被gc掉,這些對象多數都已經存活了100秒以上.場景中NPC都是僵尸,每個移動的時間應該在5秒以下,所以可判定這些移動對象是泄漏.
問題的范圍縮小了,但還是看不出哪段代碼造成了泄漏?泄漏的對象在哪一個模塊中被引用?

引用檢索

定義:從某個節點開始搜索所有該節點引用的對象以及遞歸搜索子節點,找到要搜索的對象,打印出引用路徑.
最常見的可以從_G開始搜索.搜索到的每個table,取其key和value遞歸搜索;搜索到的每個函數,取其upvalue遞歸搜索.至于是否需要搜索對象的環境表和metatable,以及全局registry表,則取決于具體需求.我因為用不上,就沒有搜索這一部分.
搜索的時候注意標記已經搜索過的節點,避免重復搜索.最好能縮小搜索范圍,而不是從_G開始搜索,另外應該能每次只搜索指定的部分引用而非全部,可以極大的縮短等待時間.搜索所有的引用其實相當耗時.
我定義的搜索接口是:function Search_r(obj, node, mark, result);

經過引用檢索處理后,我看到了計時器模塊引用了那些泄漏的移動包和移動計時器對象,這些對象的創建時間和引用他們的激活時間居然是相同的,這導致了這些計時器對象不會再激活,同時也失去了激活后釋放的機會,造成了內存泄漏.而根本原因,則是移動處理模塊在使用計時器的時候傳入了0超時參數,因為僵尸走得太慢了.
到此,問題就算全部解決了.

PS:發現用html編輯blog非常不錯啊,比cppblog自帶的所見即所得編輯器好用多了,還可以用CSS和插入一些有趣的js.

posted on 2010-08-14 15:41 LOGOS 閱讀(7032) 評論(2)  編輯 收藏 引用

FeedBack:
# re: 檢測lua內存泄漏 2010-08-15 22:55 tp
有沒有直接定位監測的啊?  回復  更多評論
  
# re: 檢測lua內存泄漏 2010-08-16 12:00 LOGOS
@tp
也有辦法
你可以通過遍歷_G的方式記錄各個資源的生存狀況和引用路徑  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              久久av最新网址| 一区二区91| 麻豆91精品91久久久的内涵| 国产一区二区福利| 久久久久久香蕉网| 久久精品国产亚洲aⅴ| 国产片一区二区| 正在播放日韩| 亚洲视频在线观看视频| 欧美高清在线视频观看不卡| 亚洲精品视频在线观看免费| 亚洲第一页自拍| 欧美理论大片| 亚洲午夜91| 久久国产精品99久久久久久老狼| 国产精品久久久一本精品| 亚洲男女自偷自拍图片另类| 欧美韩国一区| 国产精品久久久久av| 性欧美xxxx大乳国产app| 欧美亚洲免费电影| 亚洲激情一区二区| 夜夜嗨av一区二区三区四季av| 国产精品网曝门| 亚洲大胆人体在线| 国产精品女人网站| 欧美华人在线视频| 国产精品婷婷| 亚洲第一二三四五区| 久久久久青草大香线综合精品| 另类酷文…触手系列精品集v1小说| 国产精品美女久久久久av超清| 久久精品综合网| 欧美a级片网| 欧美a级一区| 国产日韩视频| 一区二区三区产品免费精品久久75| 国产欧美精品日韩区二区麻豆天美 | 日韩视频在线一区| 在线免费精品视频| 久久国产日本精品| 亚洲精品欧美日韩| 久久婷婷久久| 亚洲风情亚aⅴ在线发布| 精品二区久久| 老司机一区二区| 久久香蕉精品| 亚洲国产精品成人va在线观看| 亚洲欧美在线一区二区| 午夜精品久久久久久久久久久久久 | 欧美日韩久久精品| 亚洲精选视频在线| 亚洲在线视频免费观看| 国产精品video| 欧美影院成年免费版| 久久视频国产精品免费视频在线| 国内偷自视频区视频综合| 久久国产色av| 亚洲人成在线观看| 午夜视频一区二区| 国产专区欧美精品| 欧美激情一区二区三区全黄| 91久久极品少妇xxxxⅹ软件| 一区二区三区高清在线观看| 国产区亚洲区欧美区| 久久av一区二区三区漫画| 欧美韩国在线| 欧美一区二区精品在线| 99re6热在线精品视频播放速度| 国产精品激情偷乱一区二区∴| 久久精品国产77777蜜臀| 亚洲精品影院在线观看| 久久在线91| 亚洲制服少妇| 日韩亚洲精品在线| 亚洲国产美女久久久久| 国产一区亚洲一区| 欧美紧缚bdsm在线视频| 久久免费视频在线观看| 久久aⅴ国产紧身牛仔裤| 亚洲一区二区三区免费观看| 亚洲精品视频免费观看| 欧美激情综合色| 亚洲国产欧美在线| 免费亚洲视频| 欧美专区日韩专区| 欧美三级视频| 亚洲欧美日韩电影| 亚洲一区二区三区视频| 一区二区激情| 午夜激情久久久| 亚洲欧美国产毛片在线| 亚洲欧美日韩国产中文在线| 亚洲区欧美区| 日韩视频免费| 午夜久久久久久| 欧美一级淫片aaaaaaa视频| 性久久久久久久| 久久久久国产成人精品亚洲午夜| 久久国产欧美| 欧美久久久久久久久久| 国产欧美精品一区| 亚洲欧洲精品一区二区三区波多野1战4| 亚洲国产免费看| 亚洲字幕一区二区| 狼狼综合久久久久综合网| 欧美激情一区二区三区全黄| 一本大道久久a久久综合婷婷| 亚洲尤物视频网| 欧美日韩国产成人精品| 在线观看欧美成人| 亚洲区一区二| 蜜臀av性久久久久蜜臀aⅴ| 日韩视频精品| 欧美成人精品三级在线观看| 国内精品国语自产拍在线观看| 亚洲视频久久| 亚洲大片一区二区三区| 鲁大师影院一区二区三区| 国产一区二区av| 久久精品国产99国产精品澳门| 亚洲大胆av| 噜噜噜躁狠狠躁狠狠精品视频| 在线成人h网| 99国产麻豆精品| 国内在线观看一区二区三区| 母乳一区在线观看| 国产精品h在线观看| 久久精品视频在线免费观看| 久久久噜噜噜久久中文字免| 亚洲精品一线二线三线无人区| 一本色道久久| 影音先锋日韩有码| 亚洲一二三四区| 亚洲人成在线观看| 午夜日韩福利| 亚洲一区在线直播| 蜜桃伊人久久| 久久夜色精品一区| 国产精品一区2区| 99riav久久精品riav| 亚洲高清成人| 久久久午夜电影| 久久久久高清| 国产一区二区高清不卡| 亚洲永久精品大片| 羞羞色国产精品| 国产精品久久97| 一本久久综合| 欧美一区二区高清| 国产精品久久久久久一区二区三区| 最新日韩欧美| 亚洲视频axxx| 国产欧美精品在线播放| 性18欧美另类| 免费一级欧美片在线观看| 亚洲电影在线播放| 久久久久久久97| 亚洲国产一区二区a毛片| 最新精品在线| 欧美日韩在线高清| 亚洲一区二区三区视频| 麻豆成人综合网| 一本一本久久a久久精品综合麻豆| 亚洲视频精品在线| 国产日韩欧美精品在线| 免费在线观看日韩欧美| 亚洲精品综合久久中文字幕| 午夜精品影院在线观看| 1024成人网色www| 国产精品超碰97尤物18| 久久久久久久97| 亚洲一区二区三区视频| 欧美高清视频在线| 午夜精品国产精品大乳美女| 亚洲电影自拍| 国产主播精品| 国产伦精品一区二区三区免费迷| 玖玖玖国产精品| 欧美一区激情| 亚洲午夜一区二区三区| 亚洲精品日韩在线观看| 亚洲成人在线视频播放| 久久久999精品视频| 欧美一站二站| 欧美主播一区二区三区美女 久久精品人| 亚洲国产欧美一区二区三区同亚洲| 欧美系列电影免费观看| 欧美精品乱人伦久久久久久| 久久久91精品国产一区二区精品| 亚欧成人在线| 久久精品系列| 欧美激情网友自拍| 欧美日韩黄视频| 欧美亚洲不卡| 国产精品视频一二| 国内精品亚洲| 一本色道久久综合狠狠躁的推荐| 99精品欧美| 欧美在线免费看|