我们使用python的线程特性来分析dump日志,高效环保,哈哈
这里我们使用cdb.exe工具来分析你dmp日志
定义两个模块,AnalyzeDump和AnalyzeDumpThread,以及一个公共的变量模块,存储一下配置变量
AnalyzeDump模块
1.在配置模块中定好分析线程的个数n,生成n个dump path,并在每个path下面,新建一个空的CRASH.DMP文件,以供后续分析线程使用
2.获取出在未经处理的dump日志,将其存入一个filelist中
3.分配filelist中的dump文件到n个线程中, a little tricks here
filelistLen = filelist.__len__()
numPerGroup = int(filelistLen / threadNum) #取下整
reminder = filelistLen - numPerGroup * threadNum #余数
fileGroup = []
for i in range(threadNum):
subfilelist = filelist[i*numPerGroup:(i+1)*numPerGroup]
fileGroup.append(subfilelist)
curPlace = numPerGroup * gl.threadNum
nLeft = range(reminder)
for j in nLeft:
fileGroup[j].append(filelist[curPlace])
curPlace = curPlace
4.将上述的dump path, dump file, fileGroup等放到线程中去执行,执行后join同步,即可从dump日志中抽取出我们所需要的信息。
5.线程同步之后,可以将相应处理过的dump文件标记done
AnalyzeDumpTread模块
Thread模块中的run会调用处理dump的函数,获取dump信息,并存入数据库