使用python实现统计Nginx进程所占用的物理内存 推荐
2017-06-13 12:02
666 查看
实现代码一:
此方法适用于对进行名统一的进行进行统计,如httpd,ngins或php-fpm等
实现代码二:此方法适用于某个用户进行使用内存统计,最后的结果是,一个用户所使用的所有内存信息,脚本使用方法,在执行脚本的时候在脚本后面加上要统计的用户名
执行结果如下:
此方法适用于对进行名统一的进行进行统计,如httpd,ngins或php-fpm等
#!/usr/bin/python #coding:utf8 from subprocess import Popen, PIPE import os #如果需要对httpd进行统计可以把nginx改为httpd,其它服务统计同理,但有部分无法实现,如oracle nginxpid = Popen(["pidof", "nginx"], stdout=PIPE) nginxpid = nginxpid.stdout.read().split() memsum = 0 for i in nginxpid: pidfile = os.path.join("/proc/", str(i), "status") with open(pidfile) as f: for mem in f: if mem.startswith("VmRSS"): pidmem = int(mem.split()[1]) memsum += pidmem print("%d %s" %(memsum,"KB"))
实现代码二:此方法适用于某个用户进行使用内存统计,最后的结果是,一个用户所使用的所有内存信息,脚本使用方法,在执行脚本的时候在脚本后面加上要统计的用户名
#!/usr/bin/python #coding:utf8 """此脚本需要系统安装smem软件,安装方法:yum -y install smem""" from subprocess import Popen, PIPE import sys allmeminfo = Popen(["smem", "-u"], stdout=PIPE) allmeminfo = allmeminfo.stdout.read().split("\n") for i in allmeminfo: if i.startswith(sys.argv[1]): meminfo = i.split() print("Process Name: "+meminfo[0]) print("Total Process: "+meminfo[1]) print("Physics Memroy Use: "+meminfo[5]+" KB")
执行结果如下:
相关文章推荐
- 使用 Python 实现多进程
- Python下使用optparse模块实现对多个文件进行统计【二】
- 使用Nginx+uWsgi实现Python的Django框架站点动静分离
- 使用nginx+lua实现信息访问量统计
- python 计算apache进程占用的内存大小以及占物理内存的比例
- 使用Python MrJob的MapReduce实现电影推荐系统
- python统计某一个进程名所占用的内存
- zabbix自动发现结合shell实现自动发现占用内存最大top10进程并监控其资源 推荐
- python实现对nginx的access日志的统计
- 使用 Python 实现多进程
- 使用Python MrJob的MapReduce实现电影推荐系统
- Python 使用python-nmap模块实现端口扫描器 推荐
- 为什么在Python里推荐使用多进程而不是多线程?
- 如何实现Nginx+Keepalived中Nginx进程的高可用 推荐
- 使用Python MrJob的MapReduce实现电影推荐系统
- 使用python的docker-py实现docker的api操作 推荐
- Shell脚本实现监控swap空间使用情况和查看占用swap的进程
- 使用nginx+Lua+GraphicsMagick实现图片自动裁剪 推荐
- 使用 Python 实现多进程
- 使用Nginx+uWsgi实现Python的Django框架站点动静分离