linux跑循环脚本占内存,Linux下实现脚本监测特定进程占用内存情况

Linux系统下,我们可以利用以下命令来获取特定进程的运行情况:

cat /proc/$PID/status

其中PID是具体的进程号,这个命令打印出/proc/特定进程/status文件的内容,信息比较多,包含了物理内存/虚拟内存的使用状况,监控进程是否有内存泄露的问题,一般查看进程占用物理内存的情况:

VmRSS: xxxkB

可以采用grep命令过滤出我们需要的信息:

cat /proc/$PID/status | grep RSS >> "$LOG" #过滤包含RSS的行,并且重定向到参数LOG表示的文件

由于PID号需要通过进程名获取,同样使用grep命令过滤出我们指定进程的进程号:

ps | grep $PROCESS | grep -v 'grep' | awk '{print $1;}'#$PROCESS表示进程名字

再设置一个循环,每十秒获取一次信息并写入指定文件,完整的脚本如下:.

1 #!/bin/bash2

3 PROCESS=进程名4 LOG="/mnt/memlog.txt"

5

6 sleep 10

7

8 #删除上次的监控文件9 if [ -f "$LOG" ];then

10 rm "$LOG"

11 fi

12

13 #过滤出需要的进程ID14 PID=$(ps | grep $PROCESS | grep -v 'grep' | awk '{print $1;}')15

16 while [ "$PID" != ""]17 do

18 cat /proc/$PID/status | grep RSS >> "$LOG"#过滤出VmRSS行19 sleep 5

20 PID=$(ps | grep $PROCESS | grep -v 'grep' | awk '{print $1;}')21 done

范例2

shell脚本1.

1 #!/bin/bash2 pid=$1#获取进程pid3 echo$pid4 interval=1#设置采集间隔5 while true

6 do

7 echo $(date +"%y-%m-%d %H:%M:%S") >>proc_memlog.txt8 cat /proc/$pid/status|grep -e VmRSS >>proc_memlog.txt #获取内存占用9 cpu=`top -n 1 -p $pid|tail -2|head -1|awk '{ssd=NF-4} {print $ssd}'` #获取cpu占用10 echo "Cpu:" $cpu >>proc_memlog.txt11 echo $blank >>proc_memlog.txt12 sleep$interval13 done

调用方式

$ sh shellName.sh [pid]

#exp:

sh monitor.sh 1234

脚本1-meminfo.sh:

1 #!/bin/bash2 interval=60

3 if [ "$1" != ""]4 then

5 interval=$1

6 fi

7 echo "检查时间间隔(单位秒):"$interval8 datetime=`date +'%Y%m%d'`9 echo""> /home/info/info-$datetime10 while:11 do

12 echo `date +'%Y%m%d %H:%M:%S'` >> /home/info/info-$datetime13 cat /proc/meminfo | grep -E 'MemTotal|MemFree|Cached' |grep -v SwapCached|xargs >>/home/info/info-$datetime14 top -b -d 1 -n 1 |grep -E "PID.*USER|load|Cpu|Data" >> /home/info/info-$datetime15 sleep$interval16 echo "-------------------------------------" >> /home/info/info-$datetime17 done

注释:

第2-5行:设定一个内存监测时间间隔,如果用户输入,则为用户输入的值,如果用户没有输入,则默认为60s监测一次($1为我们执行程序是给程序的第一个参数)

第8行:datetime=date +'%Y%m%d' 通过date命令获取系统时间,并赋给datetime。变量date命令格式:date [选项]… [+格式]。

注意:一定要加反引号(),反引号在Linux中起着命令替换的作用。写成单引号和双引号会把命令当成字符串输出的哟!

第13行:首先查看meminfo文件中的内容,通过管道传递给grep命令,通过-E选项筛选出包含MemTotal或MemFree或Cached的内容(grep -E 选项可以用来扩展选项为正则表达式),并传递给下一个grep命令,通过-v选项排除掉包含SwapCached的内容,最后通过xargs将内容输出到文件(xargs将多行变成了单行,见下图)。

d7ad2d28ed0969d522cc6e6001328345.png

第14行:通过top查看内存使用情况,并通过grep过滤后输出到文件

84ef8ed36c48dad53be156df6c4769dd.png

运行脚本:./meminfo.sh [args1]

最后输出结果:cat /home/info/info-20170629

d79058306be0972db96f848e57b1b7b2.png

http://www.cnblogs.com/franjia/p/4384362.html

http://man.linuxde.net/xargs

脚本2

这个程序只是监测了top中的RES值,输出简单,并且可以在内存不在变化时自动停止监测(不过这个也有弊端,因为有些程序不是一直稳定增长的,很可能稳定一下,又增长了,这时候程序就停了)。.

同时会打屏输出:

#截取top的内存使用数

#如果文件存在,重命名if [ -a memory.txt ]then

mv memory.txt memory_at_`date +%H:%M:%S`.txtfi#如果没有输入参数,默认60s检查一次if [ $# -eq 0]thenDREAM=60

elseDREAM=$1

fi

echo "检查内存时间间隔(秒):${DREAM}"#当前内存数

RES_NOW=2#上一次内存数

RES_BEF=1#一致时退出while [ $RES_NOW -ne $RES_BEF ]doRES_BEF=$RES_NOW

#取现在内存

RES_NOW=$(top -d 1 -n 1|grep 'DataAccessEngin'|cut -d " " -f 14)

TIME=`date +'%y%m%d %H:%M:%S'`

#输出echo "${TIME}进程使用内存数=[$RES_NOW]"

echo "${TIME} ${RES_NOW}">>memory.txtsleep$DREAMdone

echo "结束"

输出结果:

6fa448ad8b199ddf4e7176a2df524031.png

同时会打屏输出:

fbfb1a1b95a02d38a400bd4c3185b387.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326279.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何在vm虚拟机里面安装win10操作系统

首先打开虚拟机,点击创建虚拟机 然后选择典型即可! 选择稍后安装操作系统 然后选择win10 64位 . 然后在找个路径: 默认60GB即可,也可以更改大小: 最后点击完成: 接下来我们需要用U盘制作一个启动盘…

CoreCLR源码探索(五) GC内存收集器的内部实现 调试篇

在上一篇中我分析了CoreCLR中GC的内部处理, 在这一篇我将使用LLDB实际跟踪CoreCLR中GC,关于如何使用LLDB调试CoreCLR的介绍可以看: 微软官方的文档,地址我在第3篇中的介绍,地址LLDB官方的入门文档,地址 源代码 本篇…

小米路由器青春版装linux,比较费心的折腾 篇二:小米路由器青春版折腾负载均衡...

比较费心的折腾 篇二:小米路由器青春版折腾负载均衡2020-06-04 11:00:233点赞10收藏8评论创作立场声明:本文的核心目的是对于比较久远的硬件进行折腾,提及的软件可以在官网、软件包或者github找到。开篇预警本文截图较多,但是前期…

mybatis入门(一)之基础安装

转载自 mybatis入门 安装 要使用 MyBatis&#xff0c; 只需将 mybatis-x.x.x.jar 文件置于 classpath 中即可。 如果使用 Maven 来构建项目&#xff0c;则需将下面的 dependency 代码置于 pom.xml 文件中&#xff1a; <dependency><groupId>org.mybatis</g…

安装windows 10操作系统

一、常见的操作系统简介&#xff1a; 1.Microsoft Windows 2.UNIX 3.Linux 4.MAC OS 5.MS-DOS 二、win10的亮点&#xff1a; 1.”开始”菜单的超级进化 2.通知中心 3.Edge浏览器 4.Cortana小娜 5.虚拟桌面 6.Windows Hello(刷脸登录) 7.Univer APP 8.Phone Compa…

2019蓝桥杯省赛---java---C---6(旋转)

题目描述 问题描述图片旋转是对图片最简单的处理方式之一&#xff0c;在本题中&#xff0c;你需要对图片顺时 针旋转 90 度。 我们用一个 nm 的二维数组来表示一个图片&#xff0c;例如下面给出一个 34 的 图片的例子&#xff1a;1 3 5 7 9 8 7 6 3 5 9 7这个图片顺时针旋转 9…

linux container 原理,容器概念与Linux Container原理

一、容器与LxC在像KVM等众多主机虚拟化解决方案中&#xff0c;对每一个虚拟机实例提供的是从底层硬件开始一直到上层的环境&#xff0c;在硬件级进行资源划分。虚拟机的内核是运行在硬件内核之上的。由于每个虚拟实例都有自己的运行内核&#xff0c;所以各实例之间有非常好的隔…

微软建议Windows 10开发人员升级到Visual Studio 2017

既然Visual Studio 2017已经发布&#xff0c;那就意味着微软开始专注于让其成为默认开发平台。Creators Update SDK的发布&#xff08;面向即将到来的Windows 10 Creators Update&#xff09;就是这种转变的一个很好的例子。该SDK只有Visual Studio 2017支持。 幸运的是&#…

mybatis入门(二)之XML 映射配置文件

转载自 mybatis XML 映射配置文件 MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置&#xff08;settings&#xff09;和属性&#xff08;properties&#xff09;信息。文档的顶层结构如下&#xff1a; configuration 配置 properties 属性settings 设置typeAliases…

无处不网络

一、Internet简介&#xff1a; 是一个国际互联网&#xff0c;将成千上万的计算机连在一起的计算机网络。涉及书籍、教育、电影、时事、运动、艺术、文化、技术开发等内容。 二、Internet的发展史&#xff1a; ARPAnet–>TCP/IP–>NSFnet–>ANSnet–>internet 三…

179. 最大数---LeetCode---JAVA

class Solution {public String largestNumber(int[] nums) {int n nums.length;String numsToWord[] new String[n];for(int i0;i<n;i){numsToWord[i] String.valueOf(nums[i]);}//[233&#xff0c;23333]排序后变为[23333&#xff0c;233]Arrays.sort(numsToWord,(a,b)…

p2p linux 开源项目,权威开源项目(linux系统、sip、live555)

1、IT知识交流(语言工具、系统问题、开源项目交流)http://stackoverflow.com/tags2、linux系统www.kernel.orghttp://www.gnu.org/copyleft/lesser.html3、pjsuahttp://www.pjsip.org/1、freeswitch1、opensipshttp://opensips.org/pub/opensips/4、live555http://www.live555.…

在Visual Studio中使用任何C++编译器

原文发表时间: 3/07/2017原文发表地址: Use any C Compiler with Visual Studio 微软Visual Studio 2017支持几种C编译器以适应各种各样的代码库。除了很多人熟悉的微软Visual C编译器外&#xff0c; Visual Studio2017还支持Clang, GCC以及其他针对某些平台的编辑器。 这篇文…

mybatis入门(三)之Mapper XML 文件

转载自 mybatis Mapper XML 文件 Mapper XML 文件 MyBatis 的真正强大在于它的映射语句&#xff0c;也是它的魔力所在。由于它的异常强大&#xff0c;映射器的 XML 文件就显得相对简单。如果拿它跟具有相同功能的 JDBC 代码进行对比&#xff0c;你会立即发现省掉了将近 95%…

linux的for循环怎么写,Linux命令:for循环写法总结

for循环写法总结关于shell中的for循环用法很多&#xff0c;感觉很全面&#xff0c;所以就转过来研究研究&#xff0c;嘿嘿...1、 for((i1;i<10;i))[[email protected] ~]# for ((i1;i<3;i )); do echo $(($i*4)); done482、在shell中常用的是for i in $(seq 10)[[email p…

2020蓝桥杯省赛---java---B---8(数字三角形)

题目描述 时间限制: 1.0s 内存限制: 512.0MB 本题总分&#xff1a;20 分【问题描述】上图给出了一个数字三角形。从三角形的顶部到底部有很多条不同的路径。 对于每条路径&#xff0c;把路径上面的数加起来可以得到一个和&#xff0c;你的任务就是找到最 大的和。路径上的每一…

ASP.NET Core MVC 源码学习:Routing 路由

前言 最近打算抽时间看一下 ASP.NET Core MVC 的源码&#xff0c;特此把自己学习到的内容记录下来&#xff0c;也算是做个笔记吧。 路由作为 MVC 的基本部分&#xff0c;所以在学习 MVC 的其他源码之前还是先学习一下路由系统&#xff0c;ASP.NET Core 的路由系统相对于以前的…

mybatis入门(四)之动态SQL

转载自 mybatis 动态SQL 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其它类似框架的经验&#xff0c;你就能体会到根据不同条件拼接 SQL 语句的痛苦。例如拼接时要确保不能忘记添加必要的空格&#xff0c;还要注意去掉列表最后一个列名的逗号。…

win10操作技巧

1.wind:返回桌面 2.wine:打开计算机 3.winx:打开Windows移动中心 4.设置桌面&#xff1a;设置–》个性化–》背景 5.设置主题&#xff1a;设置–》个性化–》主题&#xff08;锁屏&#xff09; 6.设置开始菜单 7.winp&#xff1a;选择投影 8.winl:锁屏 9.winr:打开运行…