监控url 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_URLpycurl.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_VERIFYRESULTpycurl.INFO_FILETIME 文件的时间信息pycurl.HTTP_CONNECTCODE HTTP 连接代码pycurl.HTTPAUTH_AVAILpycurl.PROXYAUTH_AVAILpycurl.OS_ERRNOpycurl.NUM_CONNECTSpycurl.SSL_ENGINESpycurl.INFO_COOKIELISTpycurl.LASTSOCKETpycurl.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

浙公网安备 33010602011771号