python 测试端口连通_Python语言 实现端口连通性检测「终于解决」

python 测试端口连通_Python语言 实现端口连通性检测「终于解决」本文主要向大家介绍了Python语言实现端口连通性检测,通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。#-*-coding:utf-8-*-#!/bin/envpython#AUTHOR:karl#DATE:2018-1-19#VERSION:V1.0######################importtimeimportosimportparamikoi…

大家好,欢迎来到IT知识分享网。

本文主要向大家介绍了Python语言 实现端口连通性检测,通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。

# -*- 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 实现.

数据库中效果

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

本文由职坐标整理并发布,希望对同学们学习Python有所帮助,更多内容请关注职坐标编程语言Python频道!

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/26529.html

(0)
上一篇 2023-04-29 19:00
下一篇 2023-05-03 10:00

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信