设为首页 收藏本站
查看: 1594|回复: 0

[经验分享] python脚本监控网站状态

[复制链接]

尚未签到

发表于 2017-4-28 12:05:27 | 显示全部楼层 |阅读模式
  http://baiying.blog.iyunv.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的默认值;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-370409-1-1.html 上篇帖子: Python Web 开发框架 Pylons 下篇帖子: 三Python内置函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表