1、概要
{#6333-1542263216886}大部分的DNS解析都是一个域名对应一个IP地址,但是通过DNS轮循技术可以做到一个域名对应多个IP,从而实现最简单且高效的负载平衡,不过此方案最大的弊端是目标主机不可用时无法被自动剔除,因此做好业务主机的服务可用监控至关重要。本示例通过分析当前域名的解析IP,在结合服务端口探测来实现自动监控,在域名解析中添加、删除IP时,无须对监控脚本进行更改。
{#6174-1542263209110}2、步骤
{#6543-1542263233534}1)实现域名的解析,获取域名所有的A记录解析IP列表
{#9361-1542263233534}2)对IP列表进行HTTP级别的探测
{#6356-1542263232054}3、代码解析
{#7836-1542263281079}通过dns.resolver.quer()方法获取业务域名A记录信息,查询出所有IP地址列表,再使用(在Python2中httplib模块,Python3中http.client模块)的request()方法以GET方式请求监控页面,监控业务所有服务的IP是否服务正常。{#8093-1542263272855}
{#3488-1542263076551}[root@localhost ~]# cat simple_A.py
#!/usr/bin/env python
#coding=utf-8
import dns.resolver
import os
import httplib
#定义域名IP列表变量
iplist = []
#定义目标域名
appdomain = "www.baidu.com"
#域名解析函数,解析成功IP追加到iplist
def get_iplist(domain=""):
try:
#解析A记录
A = dns.resolver.query(domain,'A')
except Exception,e:
print "dns resolver error:" +str(e)
return
#使用responese.answer方法
for i in A.response.answer:
for j in i.items:
#追加到iplist
iplist.append(j)
return True
def checkip(ip):
#将解析的Ip转为字符串格式,以便跟:80端口合并
oip = ('%s') % ip
checkurl = oip+":80"
getcontent = ""
#定义http链接超时时间
httplib.socket.setdefaulttimeout(5)
#创建http链接对象
conn=httplib.HTTPConnection(checkurl)
try:
#发起url请求,添加host主机
conn.request('GET',"/",headers={"Host":appdomain})
r = conn.getresponse()
#只获取url页面的15个字符,用来做可用性校验
getcontent = r.read(15)
finally:
#监控url页面的类型要先查清楚,在做对比,这里<!DOCTYPE html>要大写,也可以对比http状态码
if getcontent == "<!DOCTYPE html>":
print oip+" [ok]"
else:
#这里可以放置告警程序,比如发短信,邮件等
print oip+" [error]"
if __name__ == "__main__":
#域名解析正确且至少返回1个IP
if get_iplist(appdomain) and len(iplist) > 0:
for ip in iplist:
checkip(ip)
else:
print "dns resolver error."
[root@localhost ~]# python simple_A.py
{#9243-1542263060649}www.a.shifen.com. [ok]
{#1888-1542263060649}14.215.177.38 [ok]
{#6225-1542263060649}14.215.177.39 [ok]
#运行结果来看,域名www.baidu.com解析出2个IP地址,并且服务都是正常的。
继续阅读
历史上的今天
11 月
15
- 2023Linux中&和&&和管道符|和逻辑运算符||及分号;的用法
- 2020Docker安装Nexus 3私服仓库 Python最后更新:2024-1-25