監控url python腳本

 python代碼:python

#!/usr/bin/python
#coding:utf-8
import StringIO
import pycurl
import sys
import os
class urlpass:
    def __init__(self):
        self.contents = ''
    def body_callback(self,buf):
        self.contents = self.contents + buf
def urlgzip(input_url):
    t = urlpass()
    c = pycurl.Curl()
    c.setopt(pycurl.WRITEFUNCTION,t.body_callback)
    c.setopt(pycurl.ENCODING, 'gzip')
    c.setopt(pycurl.URL,input_url)
    c.perform()
    http_code = c.getinfo(pycurl.HTTP_CODE)#響應代碼
    http_conn_time = c.getinfo(pycurl.CONNECT_TIME)#遠程服務器鏈接時間
    http_pre_tran = c.getinfo(pycurl.PRETRANSFER_TIME)#鏈接上後開始傳輸的時間
    http_start_tran = c.getinfo(pycurl.STARTTRANSFER_TIME)#接收第一個字節的時間
    http_total_time = c.getinfo(pycurl.TOTAL_TIME)#上一請求總時間
    http_size = c.getinfo(pycurl.SIZE_DOWNLOAD)#下載數據大小
    #print 'http_code http_size conn_time pre_tran start_tran total_time'
    return "http_code:%d,http_size:%d,conn_time:%f,pre_tran:%f,start_tran:%f,total_time:%f"%(http_code,http_size,http_conn_time,http_pre_tran,http_start_tran,http_total_time)
if __name__ == '__main__':
    #input_url = sys.argv[1]
    input_url='http://www.testurl.com'
    urlinfo=urlgzip(input_url)
    print type(urlinfo)
    print urlinfo
pycurl.NAMELOOKUP_TIME 域名解析時間
pycurl.CONNECT_TIME 遠程服務器鏈接時間
pycurl.PRETRANSFER_TIME 鏈接上後到開始傳輸時的時間
pycurl.STARTTRANSFER_TIME 接收到第一個字節的時間
pycurl.TOTAL_TIME 上一請求總的時間
pycurl.REDIRECT_TIME 若是存在轉向的話,花費的時間
 
pycurl.EFFECTIVE_URL
pycurl.HTTP_CODE HTTP 響應代碼
pycurl.REDIRECT_COUNT 重定向的次數
pycurl.SIZE_UPLOAD 上傳的數據大小
pycurl.SIZE_DOWNLOAD 下載的數據大小
pycurl.SPEED_UPLOAD 上傳速度
pycurl.HEADER_SIZE 頭部大小
pycurl.REQUEST_SIZE 請求大小
pycurl.CONTENT_LENGTH_DOWNLOAD 下載內容長度
pycurl.CONTENT_LENGTH_UPLOAD 上傳內容長度
pycurl.CONTENT_TYPE 內容的類型
pycurl.RESPONSE_CODE 響應代碼
pycurl.SPEED_DOWNLOAD 下載速度
pycurl.SSL_VERIFYRESULT
pycurl.INFO_FILETIME 文件的時間信息
 
pycurl.HTTP_CONNECTCODE HTTP 鏈接代碼
pycurl.HTTPAUTH_AVAIL
pycurl.PROXYAUTH_AVAIL
pycurl.OS_ERRNO
pycurl.NUM_CONNECTS
pycurl.SSL_ENGINES
pycurl.INFO_COOKIELIST
pycurl.LASTSOCKET
pycurl.FTP_ENTRY_PATH
 
 
發微信告警
#!/usr/bin/python
#coding:utf-8
import StringIO
import pycurl
import sys
import os
import requests
import json
class urlpass:
    def __init__(self):
        self.contents = ''
    def body_callback(self,buf):
        self.contents = self.contents + buf
def urlgzip(input_url):
    t = urlpass()
    c = pycurl.Curl()
    c.setopt(pycurl.WRITEFUNCTION,t.body_callback)
    c.setopt(pycurl.ENCODING, 'gzip')
    c.setopt(pycurl.URL,input_url)
    c.perform()
    http_code = c.getinfo(pycurl.HTTP_CODE)#響應代碼
    http_conn_time = c.getinfo(pycurl.CONNECT_TIME)#遠程服務器鏈接時間
    http_pre_tran = c.getinfo(pycurl.PRETRANSFER_TIME)#鏈接上後開始傳輸的時間
    http_start_tran = c.getinfo(pycurl.STARTTRANSFER_TIME)#接收第一個字節的時間
    http_total_time = c.getinfo(pycurl.TOTAL_TIME)#上一請求總時間
    http_size = c.getinfo(pycurl.SIZE_DOWNLOAD)#下載數據大小
    #print 'http_code http_size conn_time pre_tran start_tran total_time'
    return "狀態碼:%d,頁面下載大小KB:%d,鏈接時間秒:%f,開始傳輸時間:%f,總時長秒:%f"%(http_code,http_size,http_conn_time,http_start_tran,http_total_time)

def get_token():

  url='https://qyapi.weixin.qq.com/cgi-bin/gettoken'
  values = {'corpid' : 'weixin corpid' ,
      'corpsecret':'weixin token',
       }#asia monitor
  req = requests.post(url, params=values)
  data = json.loads(req.text)
  return data["access_token"]

def send_msg(info01):
  url="https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token="+get_token()
  values = """{"touser" : "1" ,
      "toparty":"1",
      "msgtype":"text",
      "agentid":"1",
      "text":{
        "content": "新加坡API:{%s}"
      },
      "safe":"0"
      }""" %(info01)

  data = json.loads(values)
  req = requests.post(url, values)

if __name__ == '__main__':
    #input_url = sys.argv[1]
    input_url='http://www.test.com'

    urlinfo=urlgzip(input_url)
    send_msg(urlinfo)
    print type(urlinfo)
    print urlinfo
相關文章
相關標籤/搜索