python 实现端口连通性检测

发布时间:2019-09-13 09:24:05编辑:auto阅读(1985)

    # -*- coding: utf-8 -*-
    #!/bin/env python
    #AUTHOR:karl
    #DATE:2018-1-19
    #VERSION:V1.0
    ######################
    import time
    import os
    import paramiko
    import datetime
    import sys
    import MySQLdb
    import threading 
    #######################################
    #首次插入数据是REG=0,更新数据REG为其他
    #######################################
    REG=1
    private_key = paramiko.RSAKey.from_private_key_file('/home/appdeploy/.ssh/id_rsa')
    def Data_mysql(info):
        try:
            string=info
            Pip=string.split(" ")[0]
            Sip=string.split(" ")[1]
            Dip=string.split(" ")[2]
            Port=string.split(" ")[3]
            Result=string.split(" ")[4].replace('\n','')
            con = MySQLdb.connect(host='localhost',user="root",passwd="******",db="zabbix",port=3306,charset="utf8")
            dt = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
            cursor=con.cursor()
            valuse=(dt,Result,Pip,Sip,Dip,Port)
            if REG == 0:
                sql="""INSERT INTO Balant_telnet (create_time,telnet_result,telnet_physicalip,telnet_sourceip,telnet_desip,telnet_port) VALUES (%s,%s,%s,%s,%s,%s) """
                result=cursor.execute(sql,valuse)
            else:
                sql="""UPDATE Balant_telnet set create_time='%s',telnet_result=%s where telnet_physicalip='%s' and telnet_sourceip='%s' and telnet_desip='%s' and telnet_port='%s';""" %(valuse)
                result=cursor.execute(sql)
            cursor.close()
            con.commit()
            con.close()
        except MySQLdb.Error, e:
            print "Error %d: %s" % (e.args[0], e.args[1])
            sys.exit(1)
    def check_port(value,content):
        ager={}
        ager[value]=content
        ssh=paramiko.SSHClient()
        try:
            ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
            ssh.connect(value,port=22,username='appdeploy',pkey=private_key,timeout=5)
            cmd="sh /home/appdeploy/monitor.sh {value}".format(value=ager[ager.keys()[index]]) 
            stdin,stdout,stderr = ssh.exec_command(cmd)
            for file_d in stdout.readlines():  
                Data_mysql(file_d)
        except:
            result=cmd+','+'failed'+'\n'
        ssh.close()
    ###################################
    # 对配置文件进行参数解析
    ###################################
    def get_parameter():
        ager={}
        value=[]
        with open("monitor_config") as context:
            for line in context:
                while not "," in list(line):
                    host=line.strip()[1:-1]
                    value=[]
                    break
                line=line.strip().split(",")
                value=value+line
                ager[str(host)]=value
        return ager
    if __name__ == '__main__':
        threads=[]
        parm=get_parameter()
        files=range(len(parm.keys()))
        for index,content in parm.items():
            t = threading.Thread(target=check_port,args=(index,content))
            threads.append(t)
        for index in files:
            threads[index].start()
        for index in files:
            threads[index].join()

    配置文件:

    [10.117.194.23]

    10.117.194.77,10.116.41.82,9920

    10.117.194.77,10.116.47.12,1080

    10.117.194.77,10.116.45.56,1081

    [10.117.194.24]

    10.117.194.78,10.116.41.82,9920

    10.117.194.78,10.116.47.12,1080

    10.117.194.78,10.116.45.56,1081

    10.117.194.78,10.116.145.33,8001

    【】里面的IP 是物理IP,下面分别对应着应用的源IP,目标IP和测试端口号


    agent 直接用shell 实现.


    数据库中效果 

    image.png

    在zabbix 中 加入对表中数据的监控。在zabbix 的mysql 模板中加入Balant 的监控项,也可以加入图像,我们最后的结果是要展示在grafana 上进行展示。为1就说明应用端口是正常运行。

    image.png





关键字