0

0

如何监控进程子进程 fork和exec调用追踪方法

P粉602998670

P粉602998670

发布时间:2025-07-01 11:22:01

|

577人浏览过

|

来源于php中文网

原创

最直接的方式是使用 strace、auditd 或 systemtap 工具;1. strace 可追踪指定进程的 fork 和 execve 系统调用,加 -f 参数可监控子进程;2. auditd 适合系统级长期监控,通过配置规则记录 execve 调用及相关上下文;3. systemtap 支持编写自定义脚本实现灵活监控,适合高级用户和自动化平台集成。

如何监控进程子进程 fork和exec调用追踪方法

Linux环境下,想监控一个进程及其子进程的 fork 和 exec 调用,最直接的方式是利用系统自带的调试和追踪工具。这类操作通常用于排查程序行为、调试服务启动流程,或者分析恶意行为。下面介绍几种实用的方法。

如何监控进程子进程 fork和exec调用追踪方法

使用 strace 追踪 fork 和 exec

strace 是 Linux 下非常强大的系统调用追踪工具。它可以让你看到某个进程在运行时都调用了哪些系统调用,包括 fork、execve 等。

如何监控进程子进程 fork和exec调用追踪方法

使用方法:

  • 监控某个进程的所有系统调用:

    如何监控进程子进程 fork和exec调用追踪方法
    strace -p 
  • 只关注 fork 和 exec(更高效):

    strace -p  -e trace=fork,execve
  • 如果你想同时监控子进程(比如服务启动脚本),加上 -f 参数:

    strace -f -p  -e trace=fork,execve

这样就能看到目标进程以及它 fork 出来的所有子进程的 exec 行为,适合快速定位问题。


auditd 实现系统级监控

如果你需要对整个系统进行监控,而不是只针对单个进程,可以使用 auditd。它是 Linux 审计系统的守护进程,适合做长期或安全相关的监控。

配置步骤:

  1. 安装 auditd(以 Ubuntu 为例):

    Batch GPT
    Batch GPT

    使用AI批量处理数据、自动执行任务

    下载
    sudo apt install auditd
  2. 添加审计规则,监控 execve 调用(包含 fork 后执行新程序的行为):

    sudo auditctl -w /usr/bin/ -p war -k my_exec_events

    或者更细粒度地设置系统调用过滤:

    sudo auditctl -a exit,always -F arch=b64 -S execve -k exec_monitor
  3. 查看日志:

    ausearch -k exec_monitor

auditd 的优势在于它能记录更完整的上下文信息,比如用户、进程名、参数等,适合做合规审计或入侵检测。


利用 systemtap 编写自定义脚本

对于有定制化需求的场景,比如你想在特定条件下才触发记录,或者要聚合数据统计,可以考虑使用 systemtap

简单示例脚本:

probe syscall.fork {
    printf("PID %d called fork()\n", pid())
}

probe syscall.execve {
    printf("PID %d is executing %s\n", pid(), filename)
}

保存为 trace_exec_fork.stp,然后运行:

sudo stap trace_exec_fork.stp

systemtap 提供了更大的灵活性,但需要一定的学习成本,适合高级用户或自动化监控平台集成。


小贴士与注意事项

  • 如果你发现子进程没有被追踪到,可能是没加 -f 参数。
  • execve 是实际执行新程序的系统调用,而 fork 只是创建了一个副本。
  • 不同发行版默认安装情况不同,记得先检查是否已安装相关工具。
  • 在生产环境使用 auditd 时要注意性能影响,建议只监控必要内容。

基本上就这些方法了。根据你的具体场景选择合适的工具,效果会更好。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1345

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

698

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

293

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

773

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

544

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

296

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

374

2023.07.25

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号