作为软件开发人员,如何才能提升我们的开发效率?如何才能快速地解决开发过程中遇到的何种问题?根据我多年来的开发经历及取得的经验,我们需要掌握一些常用的软件分析工具,借助这些工具,可以快速高效地分析和解决问题。

1 进程分析工具

1.1 ProcessHacker

功能:ProcessHacker 是一款不错的进程分析工具,可查看所有进程信息,包括进程加载的 dll、进程打开的文件、进程读写的注册表……,也可以将特定进程的内存空间 Dump 到本地,此外还可以查看网络连接。

工具截图如下:

注:查看具体进程的详细信息,双击 Processes 列表中的进程名字即可。

1.2 ProcessExplorer

功能:ProcessExplorer 是一款不错的进程分析工具,微软官方推荐工具,稳定性和兼容性相对不错。可查看所有进程的信息,包括其加载的 dll、创建的线程、网络连接……,同样可以 Dump 出进程的内存空间到本地。

1.3 ProcessMonitor

功能:ProcessMonitor 是一款实时刷新的进程信息监控工具,微软官方推荐工具,稳定性和兼容性也是相对出色。展示的信息很全面,且每一个打开的句柄、注册表、网络连接…… 都与具体的进程关联起来。

1.4 XueTr

功能:XueTr(官网 www.xuetr.com)是一个 Windows 系统信息查看软件,可协助排查木马、后门等病毒,可以做为手工杀毒的辅助工具,XueTr(简称XT)是一个强大的系统信息查看软件,也是一个强大的手工杀毒软件,用它可以方便揪出电脑中的病毒木马,在逆向与安全领域很有名。它主要功能包含:

进程、线程、进程模块、进程窗口、进程内存、定时器、热键信息查看,杀进程、杀线程、卸载模块等功能。注册表编辑,端口信息查看,消息钩子查看,内核驱动模块查看,支持内核驱动模块的内存拷贝。

3.SSDT、Shadow SSDT、FSD、Keyboard、TCPIP、Classpnp、Atapi、Acpi、SCSI、Mouse、IDT、GDT 信息查看,并能检测和恢复 ssdt hook 和 inline hook。

4.CreateProcess、CreateThread、LoadImage、CmpCallback、BugCheckCallback、Shutdown、Lego 等 Notify Routine 信息查看,并支持对这些 Notify Routine 的删除。

磁盘、卷、键盘、网络层等过滤驱动检测,并支持删除。

进程 iat、eat、inline hook、patches 检测和恢复。

文件系统查看,支持基本的文件操作。

查看(编辑)IE 插件、SPI、启动项、服务、Host 文件、映像劫持、文件关联、系统防火墙规则、IME。

13.ObjectType Hook 检测和恢复。

14.DPC 定时器检测和删除。

15.MBR Rootkit 检测和修复。

内核对象劫持检测。

其它一些手工杀毒时需要用到的功能,如修复 LSP、修复安全模式等。

1.5 PCHunter

功能:XueTr 的增强版,功能和 XueTr 差不多,可参考上图。推荐更多使用 PCHunter,减少出故障的概率。

1.6 ProcessDump

功能:可对指定的进程,将其进程空间内的所有模块单独 Dump 出来,甚至可 Dump 出隐藏的模块(即进程加载的 dll,这里通常是被注入)。

注:这是个命令行工具。

1.7 PsTools

功能:PsTools 是命令行工具集,微软官方推荐,功能多而全,其涵盖的子功能(命令)如下:

2 流量分析工具

2.1 Wireshark

功能:Wireshark 是一款常用的网络抓包工具,同时也可以用于流量分析。

2.2 科来网络分析

功能:科来公司的一款流量分析工具,对比 Wireshark 要相对易用些(特别是流量分析入门人员),此外,该工具会自动将流量进行归类和统计。在某种意味上,还是比较方便的。

2.3 TCPView

功能:查看系统的网络连接详情,每一条连接对应的进程、协议、进程、源目地址、源目端口、连接状态…… 总之,可展示当前活跃连接的所有详细信息。

3 启动项分析工具

3.1 AutoRuns

功能:一款不错的启动项分析工具,微软官方推荐。只要涉及到启动项相关的信息,事无巨细,通通都可以查询得到,非常方便找到病毒的启动项。

4 信息收集工具

4.1 FastIR

功能:收集操作系统的关键日志、关键信息,方便后续取证和排查分析。

4.2 BrowsingHistoryView

功能:收集浏览器的历史记录,方便追溯域名、URL 的访问来源是否源自于用户行为。

5 辅助工具

5.1 Hash

功能:文件 hash 计算工具,可计算文件 MD5、SHA1、CRC 值,可用于辅助判断文件是否被篡改,或者使用哈希值到威胁情报网站查看是否为恶意文件。

5.2 ntfsdir

功能:病毒也有可能是以创建服务启动项的方式保持长久运行,点击 Autoruns 的 Services 功能,如下图,检查是否有异常的服务启动项。

5.3 Unlocker

功能:可对难以删除的文件进行强制删除(包括锁定的文件),需安装,安装后右键菜单”Unlocker“即可弹出如下界面:

6 Webshell 查杀工具

6.1 wscan

功能:深信服自研的一款 Webshell 查杀工具。

6.2 D 盾

功能:D 盾是迪元素科技的一款 Webshell 查杀工具。

7 专杀工具

7.1 飞客蠕虫专杀

功能:专门针对飞客蠕虫病毒进行查杀的工具。

飞客蠕虫专杀工具有 kidokiller(卡巴斯基出品)、TMCleanTool(趋势科技出品)。

Kidokiller 运行截图如下,红色方框的所有 0 值表明没有中飞客蠕虫,如果有非 0 值,即说明中了飞客蠕虫。

TMCleanTool 的运行截图如下,有威胁项即表明中了飞客蠕虫。

7.2 Ramnit 专杀

功能:专门针对 Ramnit 类家族病毒进行查杀的工具。

FxRamnit 是赛门铁克出品的 Ramnit 专杀工具,其运行界面如下,点击”Start“按钮即可:

注:由于 Ramnit 是全盘感染性病毒,故此专杀工具运行时间比较长,需耐心等待(FxRamnit 常常给人一种” 假死 “的感觉)。

8.性能测试工具——gperftools

gperftools google推出的一个性能分析工具,主要由四个组件组成:

1、Tcmalloc内存分析器

2、Heap-profiler

Heap-profiler是内存监控器,可以随时知道内存的使用情况[2]。

3、Heap-checker

Heap-checker是专门检测内存泄漏的工具

4、Cpu-profiler

Cpu-profiler主要是通过采样的的方式,给出一段时间内程序实际占用cpu时间偏进行统计和分析。

相关介绍可见:
Home · gperftools/gperftools Wiki · GitHub

9.内存检测工具Sanitizers

GitHub :https://github.com/google/Sanitizers

使用文档: https://github.com/google/sanitizers/wiki

C++程序很容易出现越界、内存泄漏、内存重复释放、悬垂指针等问题,这些问题是新手的噩梦,但是一般的C++教程从来不教如何解决这些问题,导致很多人自学者都是人肉解决,从此给心理蒙上了阴影。其实针对C++有很多的工具可以用来定位这些问题,其中最垂手可得的是sanitizers,因为它已经被集成在编译器(gcc/clang/msvc)中,直接加上相关的编译选项就可以用,对于传说中恐怖的内存问题大都能手到擒来。

Sanitizers 是谷歌发起的开源工具集,包括了 AddressSanitizer, MemorySanitizer, ThreadSanitizer, LeakSanitizer,Sanitizers项目本是LLVM项目的一部分,但GNU也将该系列工具加入到了自家的 GCC 编译器中。GCC 从 4.8 版本开始支持 Address 和 Thread Sanitizer,4.9 版本开始支持 Leak Sanitizer 和 UB Sanitizer,这些都是查找隐藏 Bug 的利器。

gcc/g++ 使用 sanitizer:

gcc/g++ 编译只需要将 sanitizer 的标志作为 flag 设置即可,如下:

gcc/g++ -fsanitize=address -g -fno-omit-frame-pointer test.cpp

CMakeLists 使用 sanitizer :

使用 CMAKE_CXX_FLAGS 或 add_compile_options 的配置即可使用,如下:

set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address -fno-omit-frame-pointer")

或者使用如下:

add_compile_options(-fsanitize=address -fno-omit-frame-pointer)
link_libraries(-fsanitize=address)

10.性能剖析工具perf

Wiki:https://perf.wiki.kernel.org/index.php/Main_Page

Perf 是内置于Linux 内核源码树中的性能剖析(profiling)工具。其基于事件采样原理,以性能事件为基础,常用于性能瓶颈的查找与热点代码的定位。

性能调优工具如 perf,Oprofile 等的基本原理都是对被监测对象进行采样,最简单的情形是根据 tick 中断进行采样,即在 tick 中断内触发采样点,在采样点里判断程序当时的上下文。假如一个程序 90% 的时间都花费在函数 foo() 上,那么 90% 的采样点都应该落在函数 foo的上下文中。只要采样频率足够高,采样时间足够长,那么以上推论就比较可靠。因此,通过 tick 触发采样,我们便可以了解程序中哪些地方最耗时间,从而重点分析。

11.调试器工具Windbg

Windbg是windows系统强大的调试器,在解决软件异常崩溃时非常有用,是我们用的最多的一款工具。

我们可以静态分析一异常发生时捕获到的dump文件,也可以将Windbg动态地挂载到目标进程中进行调试。比如遇到死循环时,可以采用动调试的方法,在Windbg中设置代码断点,可以确定到底死循环发生在哪个函数中。

Windbg排查异常问题时,其效率比我们直接去排查代码要高很多。Windbg的入门也相对简单,只需要掌握常用的命令,了解函数调用的栈分布图,知晓函数调用的栈回溯原理,但如果要深入分析,就需要有较深的软件开发经验和汇编语言基础了。

12.API Monitor

该工具可以来窥探其他软件在实现一些功能时都调用了哪些系统API:

13.库依赖查看工具Dependency Walker

Depenency Walker是库依赖查看工具,可以查看dll库的导出接口信息,也可以查看exe和dll的依赖库信息。该工具是早期Visual Studio自带的工具,现在的Visual Studio不再打包该工具了,需要到Depenency Walker官网上去下载。

该工具主要用于排查程序启动时缺少库报错、找不到接口报错等问题。

引用

网信杯writeup-web部分 - _nul1 - 博客园

C++ performance 性能分析工具(sanitizers valgrind gprof gperftools perf)的使用_超级大洋葱806的博客-CSDN博客_c++ 性能分析工具

性能测试工具gperftools使用 - 走看看

gperftools性能测试工具介绍 - 简书

C++性能分析工具gperftools - 简书

编译器自带的调试神器sanitizers - 知乎

【内存】内存检测工具sanitizer[内存泄漏、内存越界] VS valgrind_bandaoyu的博客-CSDN博客

_nul1 - 博客园

Windows开发值得推荐的十大软件分析工具,值得收藏_dvlinker的博客-CSDN博客_软件分析工具

常用问题排查工具和分析神器,值得收藏相关推荐

  1. MongoDB 常用故障排查工具

    MongoDB 常用故障排查工具 1.profile profiling levels: 0,关闭profile:1,只抓取slow查询:2,抓取所有数据. 启动profile并且设置Profile级 ...

  2. GitHub上这款网络排查工具,堪称神器!

    点击上方"Github爱好者社区",选择星标 回复"资料",获取小编整理的一份资料 作者:苏欣 链接:https://cloud.tencent.com/dev ...

  3. 这款网络排查工具,堪称神器!

    作者:苏欣 链接:https://cloud.tencent.com/developer/article/1491610 常用的 ping,tracert,nslookup 一般用来判断主机的网络连通 ...

  4. 常用 Java Profiling 工具的分析与比较

    相对于静态代码分析,Profiling 是通过收集程序运行时的信息来研究程序行为的动态分析方法.其目的在于定位程序需要被优化的部分,从而提高程序的运行速度或是内存使用效率.收集程序运行时信息的方法主要 ...

  5. 下面哪个不是python常用的开发工具_有哪些值得推荐的 Python 开发工具?

    数据转化成更直观的图片,对于理解数据背后的真相很有帮助.如果你有这方面的需求,而且还在使用Python,那么强烈推荐你试一试Altair. Altair是一个专为Python编写的可视化软件包,它能让 ...

  6. c++工具库大全(值得收藏)

    转自:http://blog.csdn.net/xiaoxiaoyeyaya/article/details/42541419 值得学习的C语言开源项目 - 1. Webbench Webbench是 ...

  7. 热门领域、常用短视频工具分享,新手抓紧收藏,每天多200收益

    新手做短视频自媒体,想要有每月数万.数十万的收益肯定需要花点时间和精力. 但新手想要每天有个2.3百的收益还是很简单的,不是网上说的随便做做就有收入,但也不是那么难. 只要你选对领域,用好匹配的辅助工 ...

  8. mysql命令巧记_MYSQL常用命令大全(三)【值得收藏】

    [友情提示]你必须首先登录到MySQL中,以下操作都是在MySQL的提示符下进行的且每个命令以分号结束. 7.下面的语句在mysql环境在执行 显示用户拥有权限的数据库 show databases; ...

  9. mysql explain字段含义_史上最全的explain常见结果含义分析,值得收藏

    概述 对于MySQL执行计划的获取,我们可以通过explain方式来查看,explain方式看似简单,实际上包含的内容很多,尤其是输出结果中的type类型列.理解这些不同的类型,对于我们SQL优化举足 ...

  10. JVM学习笔记之-堆,年轻代与老年代,对象分配过程,Minor GC、Major GC、Full GC,堆内存大小与OOM,堆空间分代,内存分配策略,对象分配内存,小结堆空间,逃逸分析,常用调优工具

    堆的核心概述 概述 一个JVM实例只存在一个堆内存,堆也是Java内存管理的核心区域.Java堆区在JVM 启动的时候即被创建,其空间大小也就确定了.是JVM管理的最大一块内存空间. 堆内存的大小是可 ...

最新文章

  1. Android进阶:七、Retrofit2.0原理解析之最简流程【上】
  2. 数据表示字面量整型字面量
  3. 基础-计算机及操作系统和应用程序的概念
  4. 在ASP.Net2.0中使用UrlRewritingNet实现链接重写
  5. S5PV210开发 -- 烧写/启动模式
  6. tomcat7查看后台管理怎么设置用户名和密码
  7. java php python 高并发_关于php如何调用Python快速发送高并发邮件的示例代码
  8. [深度学习] Normalization 模型
  9. 实例22:python
  10. 使用TryParse()来执行数值转换
  11. OpenCV学习笔记(一):读取、显示、保存图片
  12. FPGA:异步FIFO
  13. android检测cup温度工具,Android如何实现获取手机CPU的温度?
  14. 小运营征战大市场,手游运营也需”千人千面” ——DT时代手游精细化运营解析
  15. DevC++ 调试的时候闪退解决办法
  16. 电脑电池,笔记本电池校正,教您怎样校正笔记本电脑电池
  17. 最终幻想13-2时钟迷题破解工具
  18. unity-shader 水的效果WaterEffect
  19. CUDA9.1、cuDNN7在Ubuntu16.04上的安装
  20. Open Images Dataset V6 简介

热门文章

  1. [追加评论]三款SDR平台对比:HackRF,bladeRF和USRP
  2. 360服务器安全加固系统,360政企安全
  3. Flutter封装加载状态视图,加载中、加载成功、加载失败、加载无数据
  4. MATLAB图像处理之图像去模糊处理
  5. CMMI认证的周期是多久?费用是多少?
  6. c语言中32位整数用谁标识,int占几个字节
  7. 【场效应管】之【场效应管型号技术参数】
  8. 【深入浅出通信原理-学习笔记】信源编码
  9. 武汉ISO27001认证的完整步骤
  10. [商业_法务] 2、注册公司起名很费劲,用C++怒写个随机名字生成器