Python을 사용하여 일괄적으로 웹사이트 가용성 확인

高洛峰
풀어 주다: 2017-03-28 14:53:12
원래의
2003명이 탐색했습니다.

사이트가 점점 더 많아지면 관리가 상당히 복잡해지기 때문에 이 기사에서는 Python을 사용하여 웹사이트의 가용성을 일괄 확인하는 기능을 공유하겠습니다. 이는 모든 사람이 사이트를 관리하는 데 매우 실용적입니다. 웹사이트입니다. 도움이 필요한 친구들이 참고할 수 있습니다. > 이러한 사이트 중 일부는 중요하고 일부는 중요하지 않기 때문에 관리하기가 어렵습니다. 물론 중요하고 핵심적인 사이트는 만년 동안 문제가 없었던 일부 사이트처럼 점차적으로 관리됩니다. 그 추운 날에는 문제가 발생하면 서둘러 대처해야 하므로, 오늘은 이러한 사이트를 표준화된 방식으로 관리하는 것이 필요합니다. 규모가 크든 작든 먼저 통합 모니터링을 구현해야 하며, 최소한 해당 사이트에 접속할 수 없는 경우에는 비즈니스 측에서 피드백을 제공할 때까지 기다리지 마십시오. 그러면 우리가 충분히 전문적이지 않은 것 같습니다. 그러면 Python을 사용하여 여러 웹사이트의 가용성 모니터링을 구현하는 방법을 살펴보겠습니다. 스크립트 다음과 같습니다:

#!/usr/bin/env python
 
 
import pickle, os, sys, logging
from httplib import HTTPConnection, socket
from smtplib import SMTP
 
def email_alert(message, status):
 fromaddr = 'xxx@163.com'
 toaddrs = 'xxxx@qq.com'
 
 server = SMTP('smtp.163.com:25')
 server.starttls()
 server.login('xxxxx', 'xxxx')
 server.sendmail(fromaddr, toaddrs, 'Subject: %s\r\n%s' % (status, message))
 server.quit()
 
def get_site_status(url):
 response = get_response(url)
 try:
  if getattr(response, 'status') == 200:
   return 'up'
 except AttributeError:
  pass
 return 'down'
  
def get_response(url):
 try:
  conn = HTTPConnection(url)
  conn.request('HEAD', '/')
  return conn.getresponse()
 except socket.error:
  return None
 except:
  logging.error('Bad URL:', url)
  exit(1)
  
def get_headers(url):
 response = get_response(url)
 try:
  return getattr(response, 'getheaders')()
 except AttributeError:
  return 'Headers unavailable'
 
def compare_site_status(prev_results):
 
 def is_status_changed(url):
  status = get_site_status(url)
  friendly_status = '%s is %s' % (url, status)
  print friendly_status
  if url in prev_results and prev_results[url] != status:
   logging.warning(status)
   email_alert(str(get_headers(url)), friendly_status)
  prev_results[url] = status
 
 return is_status_changed
 
def is_internet_reachable():
 if get_site_status('www.baidu.com') == 'down' and get_site_status('www.sohu.com') == 'down':
  return False
 return True
 
def load_old_results(file_path):
 pickledata = {}
 if os.path.isfile(file_path):
  picklefile = open(file_path, 'rb')
  pickledata = pickle.load(picklefile)
  picklefile.close()
 return pickledata
 
def store_results(file_path, data):
 output = open(file_path, 'wb')
 pickle.dump(data, output)
 output.close()
 
def main(urls):
 logging.basicConfig(level=logging.WARNING, filename='checksites.log', 
   format='%(asctime)s %(levelname)s: %(message)s', 
   datefmt='%Y-%m-%d %H:%M:%S')
 
 pickle_file = 'data.pkl'
 pickledata = load_old_results(pickle_file)
 print pickledata
  
 if is_internet_reachable():
  status_checker = compare_site_status(pickledata)
  map(status_checker, urls)
 else:
  logging.error('Either the world ended or we are not connected to the net.')
  
 store_results(pickle_file, pickledata)
 
if __name__ == '__main__':
 main(sys.argv[1:])
로그인 후 복사

스크립트 핵심 설명:

1 .getattr()은 객체를 수신하고 객체 속성에 따라 객체의 값을 반환할 수 있는 Python의 내장 함수입니다. 2. Compare_site_status() 함수는

3. map()에는 두 개의 매개변수가 필요합니다. 하나는 함수이고 다른 하나는 시퀀스에 각 요소를 추가하는 것입니다.

요약

이 글의 전체 내용입니다. 도움이 필요한 친구들은

를 참고하세요.

위 내용은 Python을 사용하여 일괄적으로 웹사이트 가용성 확인의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!