Last active
March 17, 2020 02:03
-
-
Save hivefans/b0eca00833bad16d1a2bb006edea1a32 to your computer and use it in GitHub Desktop.
|-|{"files":{"monitor_process.py":{"env":"plain"}},"tag":"bigdata"}
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| #!/bin/env python | |
| #-*- coding:utf-8 -*- | |
| import os,sys | |
| import os.path | |
| from os.path import isfile | |
| from traceback import format_exc | |
| import xmlrpclib | |
| import socket | |
| import time | |
| import json | |
| import copy | |
| class Resource(): | |
| def __init__(self, pid): | |
| self.host = socket.gethostname() | |
| self.pid = pid | |
| def get_cpu_user(self): | |
| cmd="cat /proc/" + str(self.pid) + "/stat |awk '{print $14+$16}'" | |
| return os.popen(cmd).read().strip("\n") | |
| def get_cpu_sys(self): | |
| cmd="cat /proc/" + str(self.pid) + "/stat |awk '{print $15+$17}'" | |
| return os.popen(cmd).read().strip("\n") | |
| def get_cpu_all(self): | |
| cmd="cat /proc/" + str(self.pid) + "/stat |awk '{print $14+$15+$16+$17}'" | |
| return os.popen(cmd).read().strip("\n") | |
| def get_mem(self): | |
| cmd="cat /proc/" + str(self.pid) + "/status |grep VmRSS |awk '{print $2*1024}'" | |
| return os.popen(cmd).read().strip("\n") | |
| def get_swap(self): | |
| cmd="cat /proc/" + str(self.pid) + "/stat |awk '{print $(NF-7)+$(NF-8)}' " | |
| return os.popen(cmd).read().strip("\n") | |
| def get_fd(self): | |
| cmd="cat /proc/" + str(self.pid) + "/status |grep FDSize |awk '{print $2}'" | |
| return os.popen(cmd).read().strip("\n") | |
| def run(self): | |
| self.resources_d={ | |
| 'process.cpu.user':[self.get_cpu_user,'COUNTER'], | |
| 'process.cpu.sys':[self.get_cpu_sys,'COUNTER'], | |
| 'process.cpu.all':[self.get_cpu_all,'COUNTER'], | |
| 'process.mem':[self.get_mem,'GAUGE'], | |
| 'process.swap':[self.get_swap,'GAUGE'], | |
| 'process.fd':[self.get_fd,'GAUGE'] | |
| } | |
| if not os.path.isdir("/proc/" + str(self.pid)): | |
| return | |
| output = [] | |
| for resource in self.resources_d.keys(): | |
| t = {} | |
| t['endpoint'] = self.host | |
| t['timestamp'] = int(time.time()) | |
| t['step'] = 60 | |
| t['counterType'] = self.resources_d[resource][1] | |
| t['metric'] = resource | |
| t['value']= self.resources_d[resource][0]() | |
| t['tags'] = 'pid=%s' %self.pid | |
| output.append(t) | |
| return output | |
| def dump_data(self): | |
| return json.dumps() | |
| if __name__ == "__main__": | |
| d = Resource(sys.argv[1]).run() | |
| if d: | |
| print json.dumps(d) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment