一、实战:DNS域名轮询业务监控

一、项目介绍

大部分的DNS解析都是一个域名对应一个IP地址,但是通过DNS轮询技术可以做到一个域名对应多个IP,从而实现最简单且高效的负载均衡,不过此方法最大的弊端是目标主机不可用时无法被自动剔除,因此做好业务主机的服务可用监控至关重要。此项目通过分析当前域名的解析IP,再结合服务端口探测来实现自动监控,在域名解析中添加,删除IP时,无须对监控脚本进行更改。

二、思路

  1. 实现域名的解析,获取域名所有的A记录解析IP列表
  2. 对IP列表进行HTTP级别的探测

三、编写程序

通过dns.resolver,query()方法获取业务域名A记录信息,查询出所有IP地址列表,再使用httplib模块的request方法以get方式请求监控页面,监控业务所有服务的IP是否服务正常。

#!/usr/bin env python
import dns.resolver
import http.client


ip_list=[]                 #定义域名IP列表变量
app_domain="baidu.com"                #定义业务域名

def get_iplist(domain=""):                   #域名解析函数,解析成功IP将被迫追加到iplist
    try:
        A = dns.resolver.query(domain,'A')      #解析A记录类型
    except Exception as e:
        print("dns resolver error:"+str(e))
        return None
    for i in A.response.answer:
        for j in i.items:
            ip_list.append(j.address)             #追加到iplist
    return True


def checkip(ip):
    check_url=ip + ":80"
    get_content=""
    code=None
    conn=http.client.HTTPConnection(check_url,timeout=5)      #创建http连接对象,定义http连接超时时间(5秒)
    try:
        conn.request("GET","/",headers={"Host": app_domain}) #发起URL请求,添加http连接对象
        r=conn.getresponse()
        get_content=r.read(15)               #获取URL页面前15的字符,以便做可用性校验
        code=r.code                         #获取状态码
    finally:
        if get_content=="<!DOCTYPE HTML>":                #获取URL页面的内容一般是事先定义好的,比如"HTTP2000"等
            print(ip + " [OK]")
        elif code in [200,301,302]:                 #正常状态码
            print(ip + " [OK]")
        else:
            print(ip + " [Error]")                  #此处可放告警程序,可以是邮件、短信通知


if __name__ == '__main__':
    if get_iplist(app_domain) and len(ip_list) > 0:       #条件:域名解析正确至少返回一个IP
        for ip in ip_list:
            checkip(ip)
    else:
        print('dns resolver error.')
        
# run

/usr/local/bin/python3.6 /Users/xcn/PycharmProjects/自动化运维/IPy实用的IP地址处理模块/案例1.py
123.125.115.110 [OK]
220.181.57.216 [OK]
posted @ 2018-06-03 13:43  云原生运维社区  阅读(1437)  评论(0编辑  收藏  举报