davitenio Asked: 2009-05-23 23:56:58 +0800 CST2009-05-23 23:56:58 +0800 CST 2009-05-23 23:56:58 +0800 CST 进程的内存使用峰值 772 像top和ps这样的工具可以给我当前分配给进程的内存量,但我有兴趣测量自创建以来或在给定时间间隔内分配给进程的最大内存量。关于如何找出的任何建议? linux memory 3 个回答 Voted Best Answer Tom Feiner 2009-05-24T01:33:49+08:002009-05-24T01:33:49+08:00 您可以在以下位置获取某个进程的峰值内存使用量: grep VmPeak /proc/$PID/status (将 $PID 更改为您要查找的实际进程 ID)。 VmPeak 是进程自启动以来使用的最大内存量。 为了随时间跟踪进程的内存使用情况,您可以使用名为munin的工具进行跟踪,并显示随时间变化的内存使用情况的漂亮图表。 Munin 带有许多用于跟踪系统资源的默认插件,但是它没有用于跟踪峰值内存使用的插件 - 幸运的是,为它编写插件非常容易。 这是一个 munin 插件示例,用于跟踪 apache 进程的 VmPeak、VmRSS 和 VmSize 内存使用情况。您可以根据需要进行更改(只需指向正确的 PID 文件并根据需要更改组件名称)。 它输出的图形如下所示(在此示例中 VmPeak 和 VmSize 相同,因此您只能看到其中一个): 注意:这只监控主 apache 进程,不显示它的子进程的内存使用情况。 #!/bin/bash # # Parameters: # # config (required) # autoconf (optional - used by munin-config) # COMPONENT_NAME="Apache" COMPONENT_PID_FILE="/var/run/apache2.pid" if [ "$1" = "autoconf" ]; then if [ -r /proc/stat ]; then echo yes exit 0 else echo "no (/proc/stat not readable)" exit 1 fi fi if [ "$1" = "config" ]; then echo "graph_title $COMPONENT_NAME memory usage" echo 'graph_vlabel' echo "graph_category Processes" echo "graph_info This graph shows the amount of memory used by the $COMPONENT_NAME processes" echo "${COMPONENT_NAME}_vmpeak.label $COMPONENT_NAME VmPeak" echo "${COMPONENT_NAME}_vmsize.label $COMPONENT_NAME VmSize" echo "${COMPONENT_NAME}_vmrss.label $COMPONENT_NAME VmRSS" echo 'graph_args --base 1024' exit 0 fi check_memory () # $1 - PID location # $2 - process_label { pid_location=$1 process_label=$2 read pid < $pid_location procpath="/proc/$pid/status" if [ ! -e $procpath ] || [ -z $pid ] then echo "${process_label}_vmpeak.value 0" echo "${process_label}_vmsize.value 0" echo "${process_label}_vmrss.value 0" exit 0 fi VmPeak=`grep VmPeak /proc/$pid/status|awk '{print $2}'` VmSize=`grep VmSize /proc/$pid/status|awk '{print $2}'` VmRSS=`grep VmRSS /proc/$pid/status|awk '{print $2}'` echo "${process_label}_vmpeak.value $(( $VmPeak * 1024 ))" echo "${process_label}_vmsize.value $(( $VmSize * 1024 ))" echo "${process_label}_vmrss.value $(( $VmRSS * 1024 ))" } check_memory $COMPONENT_PID_FILE $COMPONENT_NAME davitenio 2009-06-11T02:28:45+08:002009-06-11T02:28:45+08:00 您可以在启动进程时使用一些工具,这些工具会在进程完成后为您提供内存使用情况的摘要: 记忆时间 时间 当使用 -v 选项执行时, GNU 时间也会给出内存使用峰值。请注意,bash 也有一个名为 time 的内置命令,因此您可能需要在调用它时指定 GNU time 的完整路径,例如/usr/bin/time -v command。此外,请注意旧版本的 GNU 时间有一个错误,即结果被错误地乘以 4,例如,检查以下链接:https ://bugzilla.redhat.com/show_bug.cgi?id=702826 Anon 2019-05-31T04:49:58+08:002019-05-31T04:49:58+08:00 如果您可以应对减速,您可能会找到用于此目的valgrind的 massif 工具--pages-as-heap=yes,因为它可以随着时间的推移分析堆(以及使用时的一般内存)分配。
您可以在以下位置获取某个进程的峰值内存使用量:
(将 $PID 更改为您要查找的实际进程 ID)。
VmPeak 是进程自启动以来使用的最大内存量。
为了随时间跟踪进程的内存使用情况,您可以使用名为munin的工具进行跟踪,并显示随时间变化的内存使用情况的漂亮图表。
Munin 带有许多用于跟踪系统资源的默认插件,但是它没有用于跟踪峰值内存使用的插件 - 幸运的是,为它编写插件非常容易。
这是一个 munin 插件示例,用于跟踪 apache 进程的 VmPeak、VmRSS 和 VmSize 内存使用情况。您可以根据需要进行更改(只需指向正确的 PID 文件并根据需要更改组件名称)。
它输出的图形如下所示(在此示例中 VmPeak 和 VmSize 相同,因此您只能看到其中一个):
注意:这只监控主 apache 进程,不显示它的子进程的内存使用情况。
您可以在启动进程时使用一些工具,这些工具会在进程完成后为您提供内存使用情况的摘要:
当使用 -v 选项执行时, GNU 时间也会给出内存使用峰值。请注意,bash 也有一个名为 time 的内置命令,因此您可能需要在调用它时指定 GNU time 的完整路径,例如/usr/bin/time -v command。此外,请注意旧版本的 GNU 时间有一个错误,即结果被错误地乘以 4,例如,检查以下链接:https ://bugzilla.redhat.com/show_bug.cgi?id=702826
如果您可以应对减速,您可能会找到用于此目的
valgrind
的 massif 工具--pages-as-heap=yes
,因为它可以随着时间的推移分析堆(以及使用时的一般内存)分配。