`
san_yun
  • 浏览: 2653727 次
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

通过Pexpect实现系统监控

 
阅读更多
Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Python 模块。

1.Expect的主要流程
ssh = pexpect.spawn('/bin/bash', ['-c', 'ssh %s' %(server)],timeout=1.5)
ssh.sendline("tail -200 /duitang/logs/usr/www.duitang.nginx.access.log ")
ssh.expect([pexpect.EOF,pexpect.TIMEOUT])
print ssh.before

1.通过spawn启动子程序。
2.发送命令。
3.等待子程序产生特定输出,做出特定的响应。
4.获取缓冲区的结果。

2.spawn介绍
spawn 是Pexpect最主要的接口. 使用这个类来启动和控制子程序,其构造函数如下:

class spawn:
    def __init__(self,command,args=[],timeout=30,maxread=2000,\
    searchwindowsize=None, logfile=None, cwd=None, env=None) 


args  当子程序需要参数时,还可以使用一个参数的列表:
child = pexpect.spawn ('/usr/bin/ssh', ['user@example.com'])
child = pexpect.spawn ('ls', ['-latr', '/tmp'])  

logfile 参数指定了 Pexpect 产生的日志的记录位置。
比如,ssh.logfile = sys.stdout

3.使用 Pexpect 控制子程序
为了控制子程序,等待子程序产生特定输出,做出特定的响应,可以使用 expect 方法。方法定义:
expect(self, pattern, timeout=-1, searchwindowsize=None) 

pattern 可以是正则表达式, pexpect.EOF , pexpect.TIMEOUT ,或者由这些元素组成的列表

4.打印 before 成员的内容
child = pexpect.spawn('/bin/ls /')
child.expect (pexpect.EOF)
print child.before

5.通过Pexpect监控应用
主要的设计思路2部分:
1. 通过Pexpect自动登录到每台服务器
2. 在每台服务器执行命令或分析日志
3. 通过记录输出的内容来监控应用

6.希望做的监控项目
1.数据库连接数
2.jvm内存,solr状态
2.web服务器状态
3.web服务器服务器连接数
4.系统load
5.memcached状态
6.ningx,SYN_RECV,统计最近访问频率最高的来源IP,统计最近访问频率最高的URL




检查步骤:
s9 gunicorn
s9 nginx
s9 mani
--------------
s8 gunicorn
s8 mani
返回数据格式:
{
    nginx:[{'s1':''},{'s9':''}],
    mysql:[{"s10":"连接数:1003"},{"s11":"连接数:200"}],   
}

参考:
http://www.ibm.com/developerworks/cn/linux/l-cn-pexpect1/
http://www.ibm.com/developerworks/cn/linux/l-cn-pexpect2/


后记:
前面的方案存在一个问题,每台机器都要执行一遍ssh,非常慢,可以通过多线程的方式:



  • 大小: 28.1 KB
分享到:
评论

相关推荐

    python Pexpect 实现输密码 scp 拷贝的方法

    Pexpect允许我们创建子进程并监控其输出,从而在适当的时候向其发送输入。以下是一个使用Pexpect自动输入密码并执行scp拷贝的示例: ```python import os from pexpect import spawn # 获取当前脚本的目录 cwd = ...

    详解用Python实现自动化监控远程服务器

    本文将详细介绍如何利用Python来实现远程服务器的自动化监控,并通过具体示例代码进行演示。 #### 一、Python监控远程服务器的背景与优势 Python作为一门高级语言,具备良好的可读性和较低的学习曲线,使得其在...

    毕业设计主机安全态势感知系统.zip

    主机安全态势感知系统是网络安全领域的重要组成部分,它通过对主机系统的实时监控,分析并预测潜在的安全威胁,为网络安全防护提供决策支持。本设计以Python作为主要开发语言,构建了一套高效、实用的主机安全态势...

    Python 实现的运维管理系统.zip

    这个名为"Python实现的运维管理系统"的压缩包文件,显然是一个利用Python语言构建的用于自动化运维任务的系统。 在运维管理中,Python可以用于以下关键功能: 1. **配置管理**:Python可以编写脚本自动配置服务器...

    python通过ssh-powershell监控windows的方法

    然而,随着PowerShell的普及,越来越多的功能可以通过PowerShell来实现,这为跨平台监控提供了便利。 本文将详细介绍如何使用Python结合SSH协议,通过PowerShell远程监控Windows服务器,并提供实际代码示例,以便...

    Python实现快速多线程ping的方法

    这个程序使用了`pexpect`库来执行系统命令,并通过`threading`库创建线程,实现并行ping。 首先,我们导入了所需的库:`pexpect`用于执行系统命令(如ping),`datetime`用于获取当前时间,以及`threading`库来创建...

    python实现批量探测IP存活性并发送邮件告警.pdf

    例如,运维工程师可以使用该系统来监控大量的 IP 主机,并及时发现故障主机。这样可以提高运维效率和网络安全性。 结论 本文档介绍了如何使用 Python 实现批量探测 IP 存活性并发送邮件告警。该系统可以应用于实际...

    Python-Python实现跨平台批量运维小神器

    10. **性能监控**:Python还可以通过`psutil`库获取系统资源信息,如CPU、内存、磁盘和网络使用情况,用于实时监控系统状态。 综上所述,"Python实现跨平台批量运维小神器"很可能是结合了上述各种功能的工具集合,...

    Python在自动化运维业务中的设计与实现.rar

    2. 库丰富:Python拥有众多用于网络管理、系统管理、监控、日志分析等的库,如paramiko(SSH连接)、nmap(端口扫描)、pexpect(交互式进程控制)等。 3. 脚本能力强大:Python能够方便地执行shell命令、处理文本...

    开源运维自动化平台架构实现与运营实践.pdf

    其核心组件包括:ELVES-CENTER(中心控制台)、openapi(开放接口)、scheduler(调度器)、heartbeat(心跳机制)、queue(消息队列)、crond(定时任务)、dashbord(监控仪表盘)、cmdb(配置管理系统)、proxy...

    python实现批量探测IP存活性并发送邮件告警.docx

    ### Python实现批量探测IP存活性并发送邮件告...这对于减轻运维人员的工作负担、提高系统监控效率具有重要意义。此外,根据实际应用场景的不同,还可以考虑进一步扩展该脚本的功能,例如增加日志记录、错误重试机制等。

    20个常用Python运维库和模块

    能够实现获取系统运行的进程和系统利用率(内存,CPU,磁盘,网络等),主要用于系统监控,分析和系统资源及进程的管理。 2、IPy(http://github.com/haypo/python-ipy),辅助IP规划。 3、dnspython...

    Python实现ssh批量登录并执行命令

    在Python编程中,SSH(Secure Shell)是一种广泛用于远程登录和执行命令的安全协议。...同时,通过结合`paramiko`库,我们可以构建更复杂的脚本来自动化更复杂的任务,如文件传输、监控系统状态等。

    python自动化运维

    Python自动化运维是现代IT环境中一个不可或缺的技术领域,它利用Python编程语言来实现系统管理、监控、部署、故障排查等一系列日常运维任务的自动化。Python因其语法简洁、库资源丰富以及跨平台性而备受青睐,成为...

    python运维自动化开发项目.zip

    例如,通过os模块创建、删除、移动文件,使用pexpect库进行交互式命令执行,如安装软件、更新系统。 2. **监控系统**:Python能与各种监控工具(如Nagios、Zabbix)集成,编写自定义插件监测服务器性能指标(CPU、...

    Python_Ansible for DevOps的例子.zip

    Python的库如Fabric、Pexpect、Paramiko等,允许开发者编写自动化脚本,执行远程命令、文件传输、系统监控等任务。此外,Python还可以用于构建持续集成/持续部署(CI/CD)管道,通过工具如Jenkins、Travis CI等进行...

    adb_python_alipay_AntForest-master.zip

    这通常通过截屏分析或日志监控来实现。 4. 发送触控事件:利用adb的`input tap`命令,根据之前获取的坐标模拟点击操作,实现自动收取能量、偷取能量和浇水。 5. 脚本编写:编写Python脚本,定义函数来执行各项操作...

    易语言源码易语言呼叫网管源码.rar

    易语言可以调用第三方库,如Pexpect或SharpPcap,来实现这些功能,使管理员能在本地控制远端设备。 4. **性能监控**:系统需定期收集网络性能数据,如带宽利用率、延迟、丢包率等。易语言可以通过发送特定的网络...

    Python_一个关于物联网框架库操作系统平台的伟大资源的协作列表.zip

    3. **操作系统平台**:在物联网设备上,常见的操作系统有Raspberry Pi OS(基于Debian的Linux发行版)、MicroPython(针对微控制器的Python实现)、CircuitPython(更简单的MicroPython分支)和Contiki-OS(面向资源...

    paramiko.tar.gz

    开发者也可以通过 Paramiko 进行复杂的任务,例如实现自定义的文件同步脚本、远程监控系统或者分布式计算。 总的来说,Paramiko是一个强大且灵活的SSH工具,它简化了Python程序与远程服务器的安全交互,对于任何...

Global site tag (gtag.js) - Google Analytics