欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 基于python的Linux系統指定進程性能監控思路詳解

基于python的Linux系統指定進程性能監控思路詳解

熱門標簽:承德地圖標注公司 地圖標注黃河的位置 靈圖uu電子寵物店地圖標注 山東企業外呼系統公司 百度地圖標注公司位置要多少錢 地圖標注如何改成微信號 虛假地圖標注 濮陽好的聯通400電話申請 400電話號碼辦理多少錢

監控Linux服務器的工具、組件和程序網上有很多,但是一臺服務器上會有很多進程同時運行,特別是做性能測試的時候,可能一臺服務器上部署多個服務,如果只監控整個服務器的CPU和內存,當某個服務出現性能問題時,并不能有效準確的定位出(當然通過其他工具也可以實現),因此,很有必要只監控指定的進程。需求明確了,于是動手擼了一個性能監控腳本。

一、整體思路

1、為了方便的啟動監控和停止監控,在想查看監控結果的時候隨時查看監控結果,用flask開啟了一個服務,通過發送get請求可以隨時啟停監控和查看監控結果。
2、針對控制是否監控cpu、內存、IO,開啟多線程監控。
3、為了減少對其他組件的依賴,將監控結果寫到日志中。
4、為了方便查看監控結果,直接將結果以html方式返回。

二、配置文件

config.py

IP = '127.0.0.1'
PORT = '5555'
LEVEL = 'INFO' # log level
BACKUP_COUNT = 9 # log backup counter
LOG_PATH = 'logs' # log path
INTERVAL = 1 # interval, run command interval.
SLEEPTIME = 3 # interval, when stopping monitor, polling to start monitor when satisfying condition.
ERROR_TIMES = 5 # times, number of running command. When equal, automatically stopped monitor.
IS_JVM_ALERT = True # Whether to alert when the frequency of Full GC is too high.
IS_MONITOR_SYSTEM = True # Whether to monitor system's CPU and Memory.
IS_MEM_ALERT = True # Whether to alert when memory is too low. Alert by sending email.
MIN_MEM = 2  # Minxium memory, uint: G
# 0: don't clear cache, 1: clear page caches, 2: clear dentries and inodes caches, 3: include 1 and 2;
# echo 1 >/proc/sys/vm/drop_caches
ECHO = 0
SMTP_SERVER = 'smtp.sina.com' # SMTP server
SENDER_NAME = '張三'  # sender name
SENDER_EMAIL = 'zhangsan@qq.com' # sender's email
PASSWORD = 'UjBWYVJFZE9RbFpIV1QwOVBUMDlQUT09' # email password, base64 encode.
RECEIVER_NAME = 'baidu_all' # receiver name
RECEIVER_EMAIL = ['zhangsan@qq.com', 'zhangsi@qq.com'] # receiver's email
DISK = 'device1' # Which disk your application runs
START_TIME = 'startTime.txt' # Store the time of start monitoring.
FGC_TIMES = 'FullGC.txt' # Store the time of every FullGC time.
# html
HTML = '<html><body>{}</body><html>'
ERROR = '<p style="color:red">{}</p>'
HEADER = '<div id="header"><h2 align="center">Performance Monitor (pid={})</h2></div>'
ANALYSIS = '<div id="container" style="width:730px; margin:0 auto">{}</div>'

IP和PORT:開啟服務的服務器IP和端口,必須和所監控的服務在同一臺服務器上;
BACKUP_COUNT:默認為9,即只保留最近9天監控結果;
INTERVAL:兩次監控的時間間隔,默認為1s,主要用于cpu和內存監控,當同時監控多個端口或進程時,請將該值設小一點;
ERROR_TIMES:命令執行失敗次數,當大于該次數時,則會自動停止監控;主要用于監控指定的進程,如果進程被殺掉,則必須自動停止監控,且必須手動觸發再次開始監控;如果監控指定的端口,當端口的進程被殺掉后,也會停止監控,如果端口被重新啟動,則自動開始監控;
IS_JVM_ALERT:僅針對java應用,如果頻繁FullGC,則郵件提醒;一般性能測試,FullGC的頻率不得小于3600秒;
IS_MONITOR_SYSTEM :是否監控系統總CPU使用率和剩余內存;
IS_MEM_ALERT:當系統剩余內存過低時,是否郵件提醒;
MIN_MEM:允許系統最小剩余內存,單位為G;
ECHO:當系統剩余內存過低時,是否釋放緩存;0為不釋放,1為釋放頁面緩存,2為釋放dentries和inodes緩存,3為釋放1和2;
DISK:磁盤號,如果監控IO,需要輸入磁盤號,通過df -h 文件名查看當前文件掛在哪個磁盤下;
START_TIME:記錄每次手動觸發開始監控的時間;
FGC_TIMES:記錄每次FullGC的時間,用于排查問題;

三、接口和服務

server.py

server = Flask(__name__)
permon = PerMon()
# 開啟多線程
t = [threading.Thread(target=permon.write_cpu_mem, args=()),
 threading.Thread(target=permon.write_io, args=())]
for i in range(len(t)):
 t[i].start()
# 開始監控
# http://127.0.0.1:5555/runMonitor?isRun=1&type=pid&num=23121&totalTime=3600
@server.route('/runMonitor', methods=['get'])
def runMonitor():......
# 畫監控結果圖
# http://127.0.0.1:5555/plotMonitor?type=pid&num=23121
@server.route('/plotMonitor', methods=['get'])
def plotMonitor():.......
server.run(port=cfg.PORT, debug=True, host=cfg.IP) # 開啟服務

通過在瀏覽器地址欄輸入對應的url,即可啟停監控和查看監控結果

url傳參:

1、開始監控

http://127.0.0.1:5555/runMonitor?isRun=1&type=pid&num=23121&totalTime=3600
isRun:1為開始監控,0為停止監控;
type和num:type=pid時,表明num為進程號,type=port,表明num為端口號;可以同時監控多個端口或進程,多個端口或進程用英文逗號隔開;
totalTime:為監控總時間,單位為秒;如果不傳入totalTime,則默認一直監控;

2、查看監控結果

http://127.0.0.1:
5555/plotMonitor?type=port&num=23121&system=1&startTime=2019-08-03 08:08:08&duration=3600
type和num:type=pid時,表明num為進程號,type=port,表明num為端口號;
system:表示查看系統監控結果;如果傳了type和num,不管sysytem是否傳值,都只能看到進程的監控結果;不傳type和num,只傳system,則可以查看系統監控結果;
startTime:查看監控結果開始時間;
duration:查看監控結果的時長,單位為秒;
如果不傳startTime和duration,則默認查看最近一次開始監控以來的所有結果;如果需要查看某一段時間內的監控結果,則需要傳startTime和duration,查看監控結果的時間范圍為從startTime開始到startTime+duration為止。
注:如果在查看監控結果輸入的一段時間內,服務被重啟過,則進程號會有變化,此時仍輸入重啟前的進程號,則只能查看對應進程號在對應時間段內的監控結果。一般情況下,端口號不會輕易變化,建議查看監控結果時輸入端口號。

四、監控

performance_monitor.py

使用top命令監控CPU和內存,使用jstat命令監控JVM內存(僅java應用),使用iotop命令監控進程讀寫磁盤,使用iostat命令監控磁盤IO,使用netstat命令根據端口查進程,使用ps命令查看服務啟動時長。因此,服務器必須支持以上命令,如不支持,請安裝。

注:由于進程可以開啟多個線程,在查看進程的IO時,是看不到任何IO;而查看進程開啟的某個線程IO時,是可以看到IO的,但是線程是一直是在變化的;故目前暫不支持監控指定進程IO的。

五、查看監控結果

draw_performance.py

1、分別畫CPU圖、內存和JVM圖、IO圖和句柄數圖;
2、為方便統計CPU和IO使用情況,計算百分位數;
3、為方便統計垃圾回收信息,計算java應用的ygc、fgc,以及各自的頻率。

監控結果效果圖如下:

六、擴展函數

extern.py 有兩個功能

1、端口轉進程

try:
 result = os.popen(f'netstat -nlp|grep {port} |tr -s " "').readlines()
 res = [line.strip() for line in result if str(port) in line]
 p = res[0].split(' ')
 pp = p[3].split(':')[-1]
 if str(port) == pp:
 pid = p[-1].split('/')[0]
except Exception as err:
 logger.logger.error(err)

2、查找包含監控結果的日志

整體思路:

        (1)根據輸入的開始時間和結束時間,查找包含這段時間的所有日志文件;
        (2)根據查找出來的日志文件,找出包含監控結果的所有日志;
        (3)畫圖的時候遍歷找出的所有日志。

補充

1、為了方便查看最近一次開始監控的時間,會將每一次開始監控的時間寫到startTime.txt文件中;

2、為了方便排查java應用可能出現的問題,將每一次Full GC的時間寫到FullGC.txt文件中。

項目地址:https://github.com/leeyoshinari/performance_monitor

總結

以上所述是小編給大家介紹的基于python的Linux系統指定進程性能監控,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

標簽:安康 福州 淮安 上海 鷹潭 德宏 泰安 樂山

巨人網絡通訊聲明:本文標題《基于python的Linux系統指定進程性能監控思路詳解》,本文關鍵詞  基于,python,的,Linux,系統,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于python的Linux系統指定進程性能監控思路詳解》相關的同類信息!
  • 本頁收集關于基于python的Linux系統指定進程性能監控思路詳解的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    91免费视频网址| 日韩欧美激情在线| 国产精品视频免费看| 国内精品不卡在线| 精品无码一区二区三区| 欧美一区二区三区的| 亚洲国产精品欧美一二99| 久久久久亚洲av无码麻豆| 91久久精品一区二区| 亚洲欧美激情一区二区| 99国产一区二区三精品乱码| 男人的天堂久久久| 一区二区中文字幕在线| 大白屁股一区二区视频| 国产又黄又爽又无遮挡| 亚洲丝袜精品丝袜在线| 91天堂素人约啪| 欧美三级韩国三级日本三斤| 亚洲午夜精品17c| 国产污在线观看| 91精品国产综合久久福利 | 国产精品偷伦视频免费观看了| 色88888久久久久久影院野外| 亚洲欧美激情小说另类| 人妻巨大乳一二三区| 欧美日韩一区二区在线观看视频| 亚洲一区二区三区四区不卡| 久久久久成人精品无码中文字幕| 日韩女优制服丝袜电影| 久久国内精品自在自线400部| 国产一级久久久久毛片精品| 久久精品男人的天堂| 丁香婷婷综合五月| 在线国产亚洲欧美| 午夜久久久久久久久| 免费在线观看你懂的| 久久蜜臀中文字幕| 成人开心网精品视频| 欧美日韩专区在线| 免费观看久久久4p| 久草福利资源在线| 亚洲美女偷拍久久| 中文字幕 日本| 久久久久成人黄色影片| 成人av电影在线播放| 欧美色倩网站大全免费| 日本不卡在线视频| 精品在线观看一区| 一区二区三区免费看视频| 粉嫩av懂色av蜜臀av分享| 久久色.com| 9i看片成人免费高清| 欧美二区三区的天堂| 精品一二线国产| 色嗨嗨av一区二区三区| 午夜国产不卡在线观看视频| 日本乱子伦xxxx| 亚洲三级在线看| 中出视频在线观看| 国产精品欧美一区喷水| caopor在线| 国产日韩亚洲欧美综合| 被黑人猛躁10次高潮视频| 欧美成人video| 成人av动漫网站| 日韩精品一区二区三区在线播放| 高清av一区二区| 91精品免费在线| 成人国产视频在线观看| 欧美一级二级三级蜜桃| 丁香婷婷综合激情五月色| 欧美一级理论片| 成人h动漫精品一区二| 亚洲午夜av在线| 精品在线一区二区三区| 色域天天综合网| 欧美aaaaa成人免费观看视频| 国产一区二区精彩视频| 午夜国产精品影院在线观看| 国产天堂av在线| 日韩av一区二区在线影视| 日韩黄色免费观看| 激情欧美一区二区| 欧美日韩另类国产亚洲欧美一级| 国模冰冰炮一区二区| 欧美人xxxx| av亚洲精华国产精华精华| 精品99一区二区| 女性生殖扒开酷刑vk| 国产精品久线在线观看| 国产免费一区二区三区网站免费| 一级精品视频在线观看宜春院 | 日韩午夜av电影| 91在线精品一区二区三区| 国产亚洲欧美一区在线观看| 东京热av一区| 亚洲免费观看高清在线观看| 精品熟妇无码av免费久久| 天天综合色天天| 欧美日韩中文字幕精品| 成人综合婷婷国产精品久久免费| 精品少妇一区二区三区免费观看| 91亚洲精华国产精华精华液| 日本一二三四高清不卡| 亚洲第一综合网| 琪琪一区二区三区| 91.com视频| 免费啪视频在线观看| 亚洲精品日产精品乱码不卡| 色老板免费视频| 国产精品一区二区x88av| 精品处破学生在线二十三| 日韩av手机在线播放| 亚洲一区二区三区国产| 欧美亚洲一区二区三区四区| 成人av网站大全| 国产精品久久久久久亚洲伦 | 天天综合天天综合色| 欧美日韩精品综合在线| 91麻豆.com| 有坂深雪av一区二区精品| 日本国产一区二区| 99久久久国产精品免费蜜臀| 中文字幕一区二区三区不卡 | 日本一区二区视频在线播放| 青青国产91久久久久久| 日韩美一区二区三区| 国产精品无码毛片| 日韩av一级片| 欧美一区二区三区爱爱| 国产精品久久久免费观看| 日韩精品高清不卡| 日韩欧美国产精品| 日韩精品电影一区二区| 激情综合网激情| 国产欧美一区二区在线观看| 久久精品日韩无码| 国产91精品露脸国语对白| 国产精品视频第一区| 色综合久久久久网| 黑人性生活视频| 偷拍与自拍一区| 精品三级在线观看| 少妇视频在线播放| 成人免费视频视频在线观看免费 | 国产人成亚洲第一网站在线播放 | 日本高清不卡一区| 深夜视频在线观看| 日韩精品久久理论片| 精品国产一区二区三区久久影院| 人妻一区二区视频| 国产传媒欧美日韩成人| 综合久久给合久久狠狠狠97色| 在线这里只有精品| 香港三日本8a三级少妇三级99| 免费观看在线色综合| 欧美高清在线视频| 色婷婷一区二区三区四区| 无码人妻aⅴ一区二区三区玉蒲团| 日精品一区二区| 国产欧美一区二区精品性色| 色综合久久久久久久久| 91丝袜在线观看| 国产一区二区三区高清播放| 国产精品美女一区二区三区 | 精品日韩一区二区三区| 潮喷失禁大喷水aⅴ无码| 972aa.com艺术欧美| 天天影视色香欲综合网老头| 久久久久久一级片| 色8久久人人97超碰香蕉987| 呦呦视频在线观看| 国产 欧美在线| 亚洲第一成人在线| 久久女同互慰一区二区三区| 色综合中文综合网| 精品国产三级电影在线观看| 免费成人美女女在线观看| 91网页版在线| 麻豆一区二区三| 1024成人网色www| 欧美一区二区三区四区五区 | 91麻豆精品在线观看| 欧美aaaaa成人免费观看视频| 国产精品剧情在线亚洲| 欧美一区二区视频在线观看2020 | 亚洲成人福利片| 久久精品人人做人人爽人人| 91久久线看在观草草青青| 法国伦理少妇愉情| 99精品国产99久久久久久白柏| 蜜桃视频在线观看一区| 亚洲欧洲日产国码二区| 国产乱色国产精品免费视频| 国产福利一区二区| 亚洲黄网站在线观看| 精品美女被调教视频大全网站| 永久免费看片直接| 91视频在线免费| 国产白丝网站精品污在线入口|