DNS域名轮循业务监控

‘‘‘
                192.168.0.1
--> www.xxx.com 192.168.0.2
                192.168.0.3
获取业务域名A记录,查询出所有IP地址列表,在使用httplib模块的request()方法
以get方式请求监控页面,监控业务所有服务IP是否服务正常
‘‘‘
#!/usr/bin/env python
import dns.resolver
import os
import http.client
import socket
iplist=[] #定义ip列表变量
appdomain="51cto.com" #定义业务域名(例)
def get_iplist(domain=""): #域名解析函数,解析成功后IP将追加到iplist
    try:
        A=dns.resolver.query(domain,‘A‘)
    except Exception as e:
        print("dns resolver error:"+str(e))
        return
    for i in A.response.answer:
        for j in i.items:
            iplist.append(j.address)
    return True
def checkip(ip):
    checkurl=ip + ":80"
    getcontent=""
    #socket.setdefaulttimeout(5) #使用socet模块定义超时时间为5秒
    http.client.socket.setdefaulttimeout(5)
    conn=http.client.HTTPConnection(checkurl) #创建http链接对象
    try:
        conn.request("GET","/",headers={"HOST":appdomain}) #发起URL请求,添加host主机t头
        r=conn.getresponse()
        getcontent=r.read(15) #获取URL页面前1个字符,以便可用性校验
    finally:
        if getcontent=="<!doctype html>": #监控URL页的内容一般事先定义好的,比如“HTTP200”等
            print(ip+"[Ok]")
        else:
            print(ip+"[ERROR]") #此处可放置警告程序,可以是邮件,可以是短信
if __name__=="__main__":
    if get_iplist(appdomain) and len(iplist) > 0 : #条件:域名解析正确至少返回一个IP
        for ip in iplist:
            checkip(ip)
    else:
        print("DNS resolver error.")
时间: 2024-10-24 06:24:49

DNS域名轮循业务监控的相关文章

Python学习笔记-DNS域名轮循业务监控

大部分的DNS解析是一个域名对应一个IP地址,但是通过DNS轮循技术可将一个域名对应多个IP地址,这样可以实现简单且高效的负载平衡,但是轮循技术有一个缺点就是当目标主机不可用时,不能自动的删除,所以引出了要对业务主机的服务的可用性进行监控. 本例通过分析当前域名的解析IP,再结合服务端口探测来实现自动监控,在域名解析中添加.删除IP时,无须对监控脚步更改. ! Python 2.x中的"httplib"模块在Python 3.x中变为"http.client" #!

实践:DNS域名轮循业务监控

大部分的DNS解析都是一个域名对应一个IP地址,但是通过DNS轮循技术可以做到一个域名对应多个IP,从而实现最简单且高效的负载平衡,从而实现简单且高效的负载平衡,不过此方案最大的弊端是目标主机不可用时无法被自动剔除,因此做好业务主机的服务可用监控至关重要.本示例通过分析当前域名的解析IP,再结合服务端口探测来实现自动监控,在域名解析中添加.删除IP时,无须对监控脚本进行更改.实现架构如图1-1所示. 1.步骤 (1)实现域名的解析,获取域名所有的A记录解析IP列表: (2)对IP列表进行HTTP

Python之DNS域名轮询业务监控

看了大神天斯的书,特此做学习笔记,实现方式略微不同是python3.5 大部分的DNS解析都是一个域名对应一个IP地址,但是通过DNS轮询可做到一个域名对应多个IP,从而实现最简单且高效的负载均衡. 1, 实现步骤 1) 实现域名的解析,获取域名所有的A记录解析IP列表 2) 对IP列表进行HTTP级别的探测 2, 代码 #!/usr/local/bin/python3.5 #-*- coding:utf-8 -*- import dns.resolver import httplib2 ipl

DNS模块dnspython应用及业务监控示例

1 dnspython处理模块的安装,源码方式 wget http://www.dnspython.org/kits/1.9.4/dnspython-1.9.4.tar.gz tar zxf dnspython-1.9.4.tar.gz cd dnspython-1.9.4/ python setup.py install 2 解析示例 A记录查询示例 #!/usr/bin/env python # -*- coding: utf-8 -*- import dns.resolver domain

全面了解移动端DNS域名劫持等杂症:原理、根源、HttpDNS解决方案等

1.引言 对于互联网,域名是访问的第一跳,而这一跳很多时候会"失足"(尤其是移动端网络),导致访问错误内容.失败连接等,让用户在互联网上畅游的爽快瞬间消失. 而对于这关键的第一跳,包括鹅厂在内的国内互联网大厂,都在持续深入地研究和思考对策,本文将就鹅厂团队在这一块的技术实践,做一个深度的总结和技术分享,希望给大家带来些许启发. 学习交流: - 即时通讯/推送技术开发交流4群:101279154[推荐] - 移动端IM开发入门文章:<新手入门一篇就够:从零开发移动端IM> (

我在REST API应用网关负载均衡中加权轮循方法的实现

最近项目需要一个REST API应用网关,因此用GO写了一个,功能是在不断完善的,感觉最终功能跟nginx反向代理差不多的,除了业务处理.现在已经实现通过配置来控制转发行为.请求前端定义的地址A,通过认证后,转到后端指定地址B,并把结果返回. 现在增加支持多backend,因此要实现负载均衡. 大概网上看了下nginx源代码的算法,及其它网友的,基本上都是实时计算,最终落到backend的顺序,都是顺序的. 例如网友的例子: { a, b, c }三个服务器,weight值是{ 5, 1, 2

【处理多服务器日志合并处理问题】多服务器的日志合并统计——apache日志的cronolog轮循

转发:http://www.chedong.com/tech/rotate_merge_log.html 内容摘要:你完全不必耐心地看完下面的所有内容,因为结论无非以下2点:1 用 cronolog 干净,安全地轮循apache"日"志2 用 sort -m 合并排序多个日志或者用: clfmerge合并日志 根据个人的使用经历:1 先介绍apache日志的合并方法:2 然后根据由此引出的问题说明日志轮循的必要性和解决方法,介绍如何通过cronolog对apache日志进行轮循:中间有

DNS域名记录

DNS域名记录 DNS数据库 在DNS的解析过程中用到域名的解析资源的记录,这个解析记录在DNS当中称为DNS数据库. 这个数据库又分为正解和反解,正解就是从主机名到ip的过程,反解就是从ip反响解析到主机名的过程,无论是正解还是反解,每个域名所对应的解析记录我们称之为zone(域),也就是正向区域和反向区域. 区域传输 完全传输:传送整个解析库 增量传输:传递解析库变化的那部分内容 正解和反解在zone记录当中是由众多的RR(resource record)组成 记录的类型有在以下所示: SO

修改DNS域名转发器解决IP地址解析错误导致的网站不能访问

修改DNS域名转发器解决IP地址解析错误导致的网站不能访问 首先谢谢同事林路的指导,才能顺利解决问题 打开网站,访问一个域名,DNS解析到错误的IP地址,那么将不能正确访问该网站 1.使用8.8.8.8(google 公用dns定位本地dns解析和google解析),这里是zh.wikipedia.org ping zh.wikipedia.org     159.106.121.75(这个是很多dns异常解析的地址) nslookup -qt zh.wikipedia.org 8.8.8.8