python監(jiān)控進(jìn)程狀態(tài),記錄重啟時(shí)間及進(jìn)程號(hào)的實(shí)例
本腳本為本人在性能測(cè)試過(guò)程中編寫(xiě),用于對(duì)進(jìn)程狀態(tài)的監(jiān)控,也可以用于日常的監(jiān)控,適用性一般,擴(kuò)展性還行
# -*- coding: UTF-8 -*-
# author=baird_xiang
import os
import time
import re
import copy
nginxRestart_num= -1
nginxReload_num= -1
logSender_num= -1
es_num= -1
nginxParent_pid=[]
nginxChild_pid=[]
logSender_pid=[]
es_pid=[]
nginxRestart_time =[]
nginxReload_time=[]
logSender_time=[]
es_time=[]
def get_restart(thread_name):
global nginxRestart_num,nginxReload_num,logSender_num,es_num
while True:
try:
for i in thread_name:
if i=='nginx_restart':
nP_pid = os.popen("sudo pgrep -lo nginx |grep -v grep|awk '{print $1}'").read()
nP_time = os.popen("sudo ps aux|grep nginx |grep -v grep|awk 'NR==1{print $9}'").read()
nginx_path = os.popen("sudo ps aux|grep nginx |grep -v grep|awk 'NR==1{print $11}'").read()
date = time.strftime('%Y-%m-%d',time.localtime(time.time()))
nP_time_now = date + '-' + nP_time.split('\n')[0]
if nP_pid and (nP_pid not in nginxParent_pid) and (nginx_path=='/usr/sbin/nginx\n'):
nginxParent_pid.append(nP_pid)
nginxRestart_num=nginxRestart_num+1
# if nP_time and (nP_time_now not in nginxRestart_time) and (color!='-c\n'):
nginxRestart_time.append(nP_time_now)
elif i=='nginx_reload':
nR_pid = os.popen("sudo pgrep -ln nginx|grep -v grep |awk '{print $1}'").read()
nR_time = os.popen("sudo ps aux|grep nginx |grep -v grep|awk 'NR==2{print $9}'").read()
nginx_path = os.popen("sudo ps aux|grep nginx |grep -v grep|awk 'NR==1{print $11}'").read()
date = time.strftime('%Y-%m-%d',time.localtime(time.time()))
nR_time_now = date + '-' + nR_time.split('\n')[0]
if nR_pid and (nR_pid not in nginxChild_pid) and (nginx_path=='/usr/sbin/nginx\n') :
nginxChild_pid.append(nR_pid)
nginxReload_num=nginxReload_num+1-nginxRestart_num
#if nR_time and (nR_time_now not in nginxReload_time) and (color!='-c\n'):
nginxReload_time.append(nR_time_now)
elif i=='log_sender':
lS_pid = os.popen("sudo ps aux|grep log_sender |grep -v grep|awk 'NR==1{print $2}'").read()
lS_time = os.popen("sudo ps aux|grep log_sender |grep -v grep|awk 'NR==1{print $9}'").read()
color = os.popen("sudo ps aux|grep log_sender |grep -v grep|awk 'NR==1{print $12}'").read()
wwwdate = os.popen("sudo ps aux|grep log_sender |grep -v grep|awk 'NR==1{print $1}'").read()
date = time.strftime('%Y-%m-%d',time.localtime(time.time()))
lS_time_now = date + '-' + lS_time.split('\n')[0]
if lS_pid and (color!='-c\n') and ( lS_pid not in logSender_pid ) and (wwwdate=='www-data\n'):
logSender_pid.append(lS_pid)
logSender_num=logSender_num+1
#if lS_time and (lS_time_now not in logSender_time) and (color!='-c\n'):
logSender_time.append(lS_time_now)
elif (i=='elasticsearch') and (os.popen("sudo ps -ef |grep elasticsearch |grep -v grep|awk 'NR==1{print $2}'").read()):
time.sleep(1)
e_pid = os.popen("sudo ps aux|grep elasticsearch |grep -v grep|awk 'NR==1{print $2}'").read()
e_time = os.popen("sudo ps aux|grep elasticsearch |grep -v grep|awk 'NR==1{print $9}'").read()
color = os.popen("sudo ps aux|grep elasticsearch |grep -v grep|awk 'NR==1{print $12}'").read()
elastic = os.popen("sudo ps aux|grep elasticsearch |grep -v grep|awk 'NR==1{print $1}'").read()
date = time.strftime('%Y-%m-%d',time.localtime(time.time()))
e_time_now = date + '-' + e_time.split('\n')[0]
if e_pid and (color!='-c\n') and (e_pid not in es_pid) and (elastic =='elastic+\n'):
es_pid.append(e_pid)
es_num=es_num+1
# if e_time and (e_time_now not in es_time) and (color!='-c\n') and (elastic =='elastic+\n'):
es_time.append(e_time_now)
else:
pass
except (OSError,IOError): #防止進(jìn)入循環(huán)但是這個(gè)時(shí)候進(jìn)程重啟,導(dǎo)致popen讀取不到進(jìn)程信息就會(huì)出錯(cuò)
pass
def set_nginxRestart_txt():
now_path = os.getcwd()
file_name = now_path + '/nginxRestart_%s.txt'%(nginxRestart_time[-1])
#寫(xiě)入文本
file1 = open(file_name,'w')
for i in range(1,len(nginxRestart_time)):
file1.write('重啟時(shí)間:'+nginxRestart_time[i]+'重啟前父進(jìn)程號(hào): '+ nginxParent_pid[i-1]+'重啟后父進(jìn)程號(hào): ' +nginxParent_pid[i] + '\n')
file1.close()
file2 = open(file_name,'a+')
file2.write('nginx restart次數(shù)為: ' + str(nginxRestart_num) + '\n')
file2.close()
def set_nginxReload_txt():
now_path = os.getcwd()
file_name = now_path + '/nginxReload_%s.txt'%(nginxReload_time[-1])
#寫(xiě)入文本
file1 = open(file_name,'w')
for i in range(1,len(nginxReload_time)):
file1.write('重啟時(shí)間:'+nginxReload_time[i] + '\n')
file1.close()
file2 = open(file_name,'a+')
file2.write('nginx reload次數(shù)為:' + str(nginxReload_num) + '\n')
file2.close()
def set_logsender_txt():
now_path = os.getcwd()
file_name = now_path + '/logsender_restart_%s.txt'%(logSender_time[-1])
#寫(xiě)入文本
file1 = open(file_name,'w')
for i in range(1,len(logSender_time)):
file1.write('重啟時(shí)間:'+logSender_time[i]+'重啟前進(jìn)程號(hào): '+ logSender_pid[i-1]+'重啟后進(jìn)程號(hào): ' + logSender_pid[i] + '\n')
file1.close()
file2 = open(file_name,'a+')
file2.write('logsender重啟次數(shù)為: '+ str(logSender_num) + '\n')
file2.close()
def set_es_txt():
now_path = os.getcwd()
file_name = now_path + '/esRestart_%s.txt'%(es_time[-1])
#寫(xiě)入文本
file1 = open(file_name,'w')
for i in range(1,len(es_time)):
file1.write('重啟時(shí)間:'+es_time[i] +'重啟前進(jìn)程號(hào): ' +es_pid[i-1] +'重啟后進(jìn)程號(hào): ' + es_pid[i] +'\n')
file1.close()
file2 = open(file_name,'a+')
file2.write('elasticsearch重啟次數(shù)為: ' + str(es_num) + '\n')
file2.close()
if __name__ =="__main__":
thread_name=['nginx_restart','nginx_reload','log_sender','elasticsearch']
try:
get_restart(thread_name)
except (KeyboardInterrupt,SystemExit):
set_nginxRestart_txt()
set_nginxReload_txt()
set_logsender_txt()
set_es_txt()
以上這篇python監(jiān)控進(jìn)程狀態(tài),記錄重啟時(shí)間及進(jìn)程號(hào)的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解利用上下文管理器擴(kuò)展Python計(jì)時(shí)器
本文將和大家一起了解什么是上下文管理器?和?Python?的?with?語(yǔ)句,以及如何完成自定義。然后擴(kuò)展?Timer?以便它也可以用作上下文管理器,感興趣的可以了解一下2022-06-06
使用?OpenCV-Python?識(shí)別答題卡判卷功能
這篇文章主要介紹了使用?OpenCV-Python?識(shí)別答題卡判卷,本文分步驟通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12
Python數(shù)組條件過(guò)濾filter函數(shù)使用示例
數(shù)組條件過(guò)濾簡(jiǎn)潔實(shí)現(xiàn)方式,使用filter函數(shù),實(shí)現(xiàn)一個(gè)條件判斷函數(shù)即可,示例代碼如下2014-07-07
Python中Dataframe元素為不定長(zhǎng)list時(shí)的拆分分組
本文主要介紹了Python中Dataframe元素為不定長(zhǎng)list時(shí)的拆分分組,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
PyCharm安裝庫(kù)numpy失敗問(wèn)題的詳細(xì)解決方法
今天使用pycharm編譯python程序時(shí),由于要調(diào)用numpy包,但又未曾安裝numpy,于是就根據(jù)pycharm的提示進(jìn)行安裝,最后竟然提示出錯(cuò),下面這篇文章主要給大家介紹了關(guān)于PyCharm安裝庫(kù)numpy失敗問(wèn)題的詳細(xì)解決方法,需要的朋友可以參考下2022-06-06
python實(shí)現(xiàn)簡(jiǎn)易的學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)易的學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
Python讀取Excel數(shù)據(jù)實(shí)現(xiàn)批量生成合同
Python在自動(dòng)化辦公方面具有極大的優(yōu)勢(shì),可以解決我們工作中遇到的很多重復(fù)性問(wèn)題。本文將通過(guò)Python讀取Excel數(shù)據(jù)實(shí)現(xiàn)批量生成合同,需要的可以參考一下2022-05-05
爬山算法簡(jiǎn)介和Python實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了爬山算法,爬山法(climbing method)是一種優(yōu)化算法,其一般從一個(gè)隨機(jī)的解開(kāi)始,然后逐步找到一個(gè)最優(yōu)解(局部最優(yōu))然后用Python實(shí)現(xiàn)了這個(gè)算法,需要的朋友可以參考下2014-04-04

