linux如何让系统监控一个服务(linux服务监控及运维)
类别:服务器 浏览量:2432
时间:2021-10-03 01:21:15 linux如何让系统监控一个服务
linux服务监控及运维目录
- 一, 安装psutil 包
- 二,找到操作系统中所有的服务的name和pid
- 三,找到需要监控但没有启动的服务
- 四,监控服务,如果没有开启则自动开启,[并发邮件通知工作人员]
1.1、安装压缩包:以root身份登陆CentOS依次 执行以下命令:
wget https://pypi.python.org/packages/source/p/psutil/psutil-2.1.3.tar.gz
如果wget 下不下来,则直接在浏览器中复制 粘贴链接https://pypi.python.org/packages/source/p/psutil/psutil-2.1.3.tar.gz 下载下来,用ftp传输工具传输到linux上,然后再进行下面的操作
1.2 解压: tar zxvf psutil-2.1.3.tar.gz
1.3 进入解压完的目录:cd psutil-2.1.3/
1.4 启动安装: python3 setup.py install
1.5 验证: 在命令窗口输入 python3,然后 输入 :
import psutil 不报错,则证明安装 成功
接着输入:
res = psutil.process_iter() for var in res: print(var)
则会显示一堆信息
二,找到操作系统中所有的服务的name和pid
import psutil proc_dict = {} #ID:进程名 proc_name = set() #关于进程的集合,集合去重 for p in psutil.process_iter(): proc_dict[p.pid] = p.name() proc_name.add(p.name()) print(proc_dict) print('\n\n--------------------------\n') print(proc_name)
proc_stop = monitor_name - proc_name
即:需要监控的服务name 减去 操作系统中所有服务的name
1.使用os.system(命令)启用 服务。
完整代码如下:
import psutil import os #如果需要发邮件给通知管理人员可能需要使用 request 和 json #import request #import json import time time_now = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime()) #要监控的服务 monitor_name = {'nginx'} #启动命令 monitor_map = {'nginx':'service nginx start'} while True: #操作系统中所有进程的字典 proc_dict = {} #操作系统中所有的进程名集合 proc_name = set() #psutil.process_iter()会返回操作系统下所有进程名及进程ID for p in psutil.process_iter(): proc_dict[p.pid] = p.name() proc_name.add(p.name()) print(proc_dict) print('\n\n--------------------------\n') print(proc_name) # monitor_name - proc_name == died process name #提取到那个监控进程没有启动 proc_stop = monitor_name - proc_name print(proc_stop) if proc_stop: for p in proc_stop: p_status = '停止' p_name = p data ={p_status,p_name,time_now} headers = {'Content-Type':'application/json;charset=utf-8'} #send_data = json.dumps(data).encode('utf-8') #发邮件给管理人员 #request.post(url=url,data=send_data,headers=headers) os.system(monitor_map[p]) proc_name = set() for p2 in psutil.process_iter(): proc_name.add(p2.name()) if p in proc_name: print("重启成功") else: print("重启失败") time.sleep(2000)
运行之后的效果:
到此这篇关于linux服务监控及运维的文章就介绍到这了,更多相关linux服务内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- linuxftp的下载命令(Linux ftp 命令行中下载文件get与上传文件put的命令应用详解)
- linux下date用法(Linux date命令的使用)
- tomcat在linux系统安装步骤(Tomcat的卸载和重装的实现图文)
- linux查看tcp状态(详解从Linux源码看SocketTCP的bind)
- 阿里云linux服务器怎么进(阿里云Linux主机安装WDCP管理面板包含lamp+lnmp+lanmp环境)
- linux基本命令pwd(在Linux上使用xargs命令的详细教程)
- 宝塔linux面板安装(宝塔Linux控制面板专业版破解步骤亲测可用)
- linux如何让系统监控一个服务(linux服务监控及运维)
- linux分区管理(在腾讯云的Linux系统服务器上格式化和分区磁盘的教程)
- linuxcrontab怎么不执行(Linux crontab 命令的使用)
- zabbix 查询linux使用率高的进程(详解Linux使用ss命令结合zabbix对socket做监控)
- linuxgzip命令(Linux bzip2 命令的使用)
- linux中swap分区的作用是(linux swap交换分区详解)
- amazonawslinux服务器设置(如何在AWS EC2的Linux服务器上开放一个端口)
- linux什么时候使用信号(浅谈Linux信号机制)
- ftp服务器怎么搭建linux(Linux下使用vsftp搭建FTP服务器附参数说明)
- 四川旅游攻略(四川旅游攻略自由行攻略)
- 上海迪士尼攻略(上海迪士尼攻略旅游)
- 哪里可以看熊猫(成都哪里可以看熊猫)
- oppo手机的三种录屏方法,你知道有哪些吗(oppo手机的三种录屏方法)
- 吉林神秘传染链跨省 传染源尚未找到,舒兰 封城(吉林神秘传染链跨省)
- 吉林舒兰 封城 聚集性疫情传播链已延至沈阳,有一个细节让人忧心(吉林舒兰封城)
热门推荐
- 云服务器是属于什么类型的服务(什么是真正的云服务器?云服务器优势盘点)
- docker容器镜像内容(Docker容器从镜像恢复代码的操作步骤)
- python去除字符串中间的空格(Python去除字符串前后空格的几种方法)
- sqlifnull如何使用(在 SQL 语句中处理 NULL 值的方法)
- docker容器网络设置(对docker中的overlay式网络详解)
- js判断对象是否存在
- html5 data属性
- python scrapy爬虫教程视频(详解python3 + Scrapy爬虫学习之创建项目)
- linux查询服务重启(Linux上定位后台服务偶发崩溃的解决方法)
- volume怎么添加docker(docker volume删除卷的操作)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9