http://baiying.blog.51cto.com/1068039/1112185
通过检测web的一个测试页来获取http状态码判断web server的状态,源脚本来自互联网,在此做小小的注释,供喜欢python的童鞋学习研究。
#!/usr/bin/env python
#script name check_web_stat.py
import socket #tcp建立socket连接用到
import re #正则表达式模块
import sys
def check_webserver(address, port, resource):
#建立http请求串
if not resource.startswith('/'): #判断是否以‘/’开头
resource = '/' + resource
request_string = "GET %s HTTP/1.1\r\nHost: %s\r\n\r\n" % (resource, address)
print 'HTTP request:'
print '|||%s|||' % request_string
#创建一个 TCP socket
s = socket.socket()
print "Attempting to connect to %s on port %s" % (address, port)
try:
s.connect((address, port))
print "Connected to %s on port %s" % (address, port)
s.send(request_string)
#获取前100个字节
rsp = s.recv(100)
print 'Received 100 bytes of HTTP response'
print '|||%s|||' % rsp
except socket.error, e:
print "Connection to %s on port %s failed: %s" % (address, port, e)
return False
finally:
#关闭socket连接
print "Closing the connection"
s.close()
lines = rsp.splitlines() #将一个段落的字符串以行为单位分割成一个列表
print 'First line of HTTP response: %s' % lines[0]
try:
version, status, message = re.split(r'\s+', lines[0], 2)
print 'Version: %s, Status: %s, Message: %s' % (version, status, message)
except ValueError:
print 'Failed to split status line'
return False
if status in ['200', '301']:
print 'Success - status was %s' % status
return True
else:
print 'Status was %s' % status
return False
if __name__ == '__main__':
from optparse import OptionParser #导入optionparser命令行工具模块
parser = OptionParser() #构造optionparser的对象
parser.add_option("-a", "--address", dest="address", default='localhost',
help="ADDRESS for webserver", metavar="ADDRESS")
parser.add_option("-p", "--port", dest="port", type="int", default=80,
help="PORT for webserver", metavar="PORT")
parser.add_option("-r", "--resource", dest="resource", default='index.html',
help="RESOURCE to check", metavar="RESOURCE")
#往optionparser对象中增加option :parser.add_option()
(options, args) = parser.parse_args() #调用optionparser的解析函数,在options中使用解析到的options,在args中使用其他的位置参数args
print 'options: %s, args: %s' % (options, args)
check = check_webserver(options.address, options.port, options.resource)
print 'check_webserver returned %s' % check
sys.exit(not check)
# python check_web_stat.py -a www.baidu.com -r index.php
options: {'resource': 'index.php', 'port': 80, 'address': 'www.baidu.com'}, args: []
HTTP request:
|||GET /index.php HTTP/1.1
Host: www.baidu.com
|||
Attempting to connect to www.baidu.com on port 80
Connected to www.baidu.com on port 80
Received 100 bytes of HTTP response
|||HTTP/1.1 200 OK
Date: Wed, 09 Jan 2013 01:19:06 GMT
Server: BWS/1.0
Content-Length: 9777
Content|||
Closing the connection
First line of HTTP response: HTTP/1.1 200 OK
Version: HTTP/1.1, Status: 200, Message: OK
Success - status was 200
check_webserver returned True
注:add_option()中参数的意义:
short option string: 为第一个参数,表示option的缩写,例如-f;
long option string: 为第二个参数,表示option的全拼,例如--file;
后面的参数皆为命名参数,命名参数为可选参数:
action=: 表示对此option的处理方式,默认值为store,表示存储option的值到解析后的options对象的成员中。action还可以有其他的值: 对于bool值,使用store_true来默认存储true,使用store_false来默认存储false,store_const用来存储 const设置的值到此option,append表示增加option的参数到list中,此时此option是一个list,可能包含多个 值,count表示对counter增加一,callback表示调用指定的函数。所有的action值如下:
store + store_true + store_false + store_const + append + count + callback
type=:表示此option的值的类型,默认为string,可以指定为string, int, choice, float and complex;
dest=:表示此option在经过optionparser解析后的options对象中成员的名字,默认使用long option string;
default=:表示比option的默认值;
metavar=:表示显示到help中option的默认值;
相关推荐
为了监控 NAS主机的运行状态, 以流量和CPU温度为主.应该可运行所有linux环境. 参考网上资料整理代码 , 供参考. 监控 CPU 温度, 内存使用量MB, CPU单核使用率(此项不太准), 网络流入差量KB , 流出差量KB, 运行时间...
本文实例为大家分享了python脚本监控docker容器的方法,供大家参考,具体内容如下 脚本功能: 1、监控CPU使用率 2、监控内存使用状况 3、监控网络流量 具体代码: #!/usr/bin/env python # --*-- coding:UTF-8 --*-...
在提供的`monitor-master`压缩包中,可能包含了实现上述功能的源代码,包括Python脚本、配置文件以及可能的依赖库。解压后,可以查看和学习其中的实现细节,如怎样与Nginx通信、如何解析响应、怎样集成DingTalk SDK...
在Python脚本中,你可以使用`psutil.cpu_percent()`来获取CPU使用率,`psutil.virtual_memory()`来获取内存信息,以及`psutil.disk_usage()`来检查磁盘空间。 在硬件监控方面,除了上述的CPU、内存和磁盘,还可以...
标题中的“Python-监视GPU访问的Python脚本”暗示了我们将在讨论如何使用Python来监控图形处理器(GPU)的使用情况。在现代计算中,GPU不仅用于图形处理,还广泛应用于深度学习、科学计算等高性能计算领域。因此,...
在本文中,我们将深入探讨如何利用Python2.7来编写针对Linux服务器的监控脚本,重点关注CPU、内存和网络资源的监控。 首先,我们需要了解Python的基础知识。Python是由Guido van Rossum创建的一种高级编程语言,以...
总结,这个"python学习资料python脚本实现监控apache,并使用mail发送报警共2页.pdf.zip"的资源提供了一个学习如何结合Python、系统监控和邮件通知的实践案例。通过学习和实践这个案例,你可以掌握如何利用Python进行...
Python作为一种强大的编程语言,因其简洁的语法和丰富的库资源,常常被用来进行网络监控,包括IP扫描和设备在线状态检测。本篇文章将详细讲解如何利用Python来实现网络环境中的IP掉线监测。 首先,我们要实现IP扫描...
【京东抢购Python脚本6月最新版】是一款专为京东平台设计的自动化脚本,旨在帮助用户在抢购活动中快速、准确地下单购买商品。这个脚本利用Python编程语言的强大功能,结合了网络请求、数据解析、定时任务等多个领域...
Python脚本监控Tomcat服务器是一种常见的自动化运维策略,它能够实时检查Tomcat服务的状态,并在服务出现问题时自动发送警报,比如通过邮件通知。这里我们详细介绍如何实现这一功能。 首先,监控Tomcat服务器的核心...
首先,我们要理解“Python淘宝抢购脚本”的核心是通过编程模拟用户行为,实现毫秒级响应的抢购。主要涉及的技术栈包括Python编程语言、Selenium库以及Chromedriver。Python是一种广泛应用于自动化任务的高级编程语言...
【Python开发-其它杂项】中的这个项目是一个Python脚本,其主要目的是实现对服务的监控,当服务出现故障时,脚本会自动发送短信通知,并尝试重新启动服务,以确保系统的持续运行和稳定性。这样的功能对于任何依赖...
通过这些Python脚本,管理员可以实时了解Hadoop集群的健康状况,及时发现并解决问题,确保大数据处理的稳定性和效率。学习和理解这些脚本有助于提升对Hadoop监控的理解,也能为自定义监控需求提供参考。
内容概要:本文档是一系列 Python 脚本代码的集合,涵盖从网络请求、文件与文件夹的操作、系统状态监控(如 CPU 使用率、内存占用)、网络管理以及常用任务自动化脚本等多个方面。每个脚本都有具体的应用实例,帮助...
该方案通过实现一个Windows图形应用程序,具备设备管理、脚本文件/工程控制管理、设备状态监控、测试参数配置及图形化输入输出界面等功能。该程序加载相应的Python脚本,并配置测试参数,然后连接自动化测试设备实现...
在运维领域,Python 脚本可以用来实现各种自动化任务,例如连接远程服务器并执行命令、解析日志文件并提取有用信息、监控系统状态并发送警报、批量部署软件或更新系统、执行备份和恢复任务等。 1. 连接远程服务器并...
此脚本文件用于zabbix监控redis哨兵时收集redis sentinel监控信息。
总的来说,“Python-splunk微信告警脚本”是一个实用的集成方案,它将 Splunk 强大的日志分析能力和微信的即时通讯功能结合起来,帮助IT团队更高效地监控系统状态,及时响应问题。通过深入理解和定制这个脚本,你...
为了持续监控服务器状态,通常会将Python脚本设置为定时任务。在Linux中,可以使用cron定时器来安排脚本的执行。在crontab配置文件中添加相应的定时规则,确保脚本在指定时间间隔内自动运行。 五、数据收集与可视化...
一个简单的Python运维脚本示例,用于自动化管理Kubernetes集群中的Pods 这个脚本使用了 kubernetes Python客户端库来与Kubernetes集群进行交互,实现了以下功能: 加载Kubernetes配置文件。 创建Kubernetes API...