一个跟踪 CPU 时间和内存使用情况的 Linux shell
我正在尝试做的事情的简短概要:
模拟一个 shell 程序,当用户在自己的进程中输入命令时执行命令,并且在每个进程完成后,输出所有子进程和 shell 在该进程上花费的总时间CPU,以及单个进程已使用的最大内存量。
创建 shell 并执行命令不是问题,但跟踪进程的统计信息却让我陷入困境。
为了跟踪 CPU 时间,我将使用 time 系统调用并将用户的命令通过 shell 传递到 time 中,以便进程可以完成运行,并且在执行结束时我将获得可用的 time 信息。但是,当涉及到获取 shell(当前程序)在 CPU 上花费的时间时,我不完全确定该怎么做,因为我见过或遇到的每个时间实现都使用上述传递时间的方法命令和参数进入时间,但我无法使用 shell 做到这一点。我目前唯一的想法是让 shell 也成为一个子进程,运行一段时间,当 shell 完成运行子进程时,重新启动 shell,从 time 中提取信息,然后重新启动 shell。这看起来很绕,但我找不到任何系统调用来执行我想要的操作。
至于内存使用情况,本来想用top,然后把信息拉出来,但是iirc top只监控当前内存使用情况,而不是总量。我唯一能想到的另一件事就是进入 /proc// 并尝试从那里的某个地方提取信息。这又显得非常迂回。
任何朝着正确方向的推动都会很棒。所有这些都是用 C 语言完成的,如果这有什么不同的话。
A short synopsis of what I'm trying to do:
Emulate a shell program that executes commands as the user enters them in its own process, and after each process finished, output the total time that all child processes and the shell have spent on the CPU, and the max amount of memory that a single process has used.
Creating the shell and executing the commands isn't a problem, but when it comes to keeping track of the statistics about the processes is what has me stuck.
For keeping track of the CPU time, I was going to use the time system call and pass the user's command through the shell and into time so the process could finish running and at the end of execution I would have the information from time available to me. But when it comes to getting the time that the shell (current program) has spent on the CPU, I'm not entirely sure what to do because every implementation of time that I've seen or come across uses the above method of passing the commands and arguments into time, and I can't do that with the shell. The only idea I ahve at the moment is to make the shell a child process as well, run that through time, and when the shell finishes running a child process, reboot the shell, pull the information from time, and reboot the shell. Which seems very round about, but I can't find any system calls to do what I want.
As for the memory usage, I was thinking about using top and then pulling the information out, but iirc top only monitors current memory usage, not total. The only other thing I could think of would be going into /proc// and trying to pull the information out from somewhere in there. Which again, seems very roundabout.
Any nudge in the right direction would be awesome. All of this is done in C, if that makes a difference.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
一种可能的方法是将每个用户命令作为单独的进程运行,并在进程完成时获取资源使用信息。好的,将命令作为进程运行非常简单(请参阅 fork() 和 exec* 系列)。资源使用情况(时间、内存等)怎么样?我建议看一下 getrusage() 系统调用。
男人说:
让我们看看这个系统调用提供了哪些信息:
我认为这足以解决您的问题。
One possible way is to run every user command as a separate process and when process finishes grab the resources usage information. Ok, running command as process is easy enough (see fork() and exec* family). What about resource usage (time, memory, etc)? I suggest take a look at getrusage() syscall.
man says:
Lets see what information this syscall provides:
I think this would be enough to solve your problem.