编写一个探测端口异常的Python脚本

在工作中需要时刻关注服务进程的健康状态或者metrics进程的健康状态,可以监控其服务的端口,下面编写一个监控kafka服务进程和其metrics进程的端口的Python脚本,直接上代码:

import socket
from prometheus_client import start_http_server,Summary
from prometheus_client import start_http_server, Gauge
from prometheus_client.core import CollectorRegistry
from prometheus_client.core import Gauge
import random
import time

# IP 地址到主机名的映射
ip_to_hostname = {
    "10.110.1.110":"hostname1",
    "10.110.1.111":"hostname2",
    "10.110.1.112":"hostname3",
}

def check_port(server, port):
    try:
        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        s.settimeout(1)  # 设置超时时间为1秒
        s.connect((server, port))
        s.close()
        return True
    except Exception as e:
        return False

def check_servers_ports(servers, ports):
    status = {}
    for server in servers:
        hostname = ip_to_hostname.get(server,"Unknown") #获取主机名,如果位置则默认为"Unknown"
        status[server] = {'hostname':hostname}

        for port in ports:
            status[server][port] = check_port(server, port)
    return status

gauge_metric = Gauge('kafka_server_and_monitor_port', 'Current status of kafka server and monitor', ['server', 'port', 'hostname'])

def get_kafka_server_and_monitor_status():
    servers = list(ip_to_hostname.keys())
    ports = [9092, 9100, 9990, 9308]

    port_status = check_servers_ports(servers, ports)

    print("# HELP kafka_server_and_monitor_port Current status of kafka server and monitor.")
    print("# TYPE kafka_server_and_monitor_port Gauge")

    for server in port_status:
        for port, status in port_status[server].items():
            if port == 'hostname': #跳过主机名
                continue
            gauge_metric.labels(server=server, port=str(port),hostname=port_status[server]['hostname']).set(1 if status else 0)

if __name__ == "__main__":
    registry = CollectorRegistry(auto_describe=False)
    registry.register(gauge_metric) 
    start_http_server(1333,registry=registry)
    while True:
        get_kafka_server_and_monitor_status()
        time.sleep(60)

使用nohup在后台启动进程:

nohup python3.6 kafka_port_monitor.py >/dev/null 2>&1 &

最后查看监控指标是否正常输出

curl  http://localhost:1334/metrics
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 你好,我是 CSDN 开发的 C 知道,关于你的问题,我可以回答。以下是一个简单的 Python 端口扫描脚本示例: ```python import socket target_host = input("请输入要扫描的目标主机:") target_ports = input("请输入要扫描的目标端口(多个端口用逗号分隔):") # 将输入的端口号转换为列表 target_ports = target_ports.split(",") # 创建 socket 对象 client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 设置超时时间 client.settimeout(.5) # 遍历端口列表,进行扫描 for port in target_ports: try: # 连接目标主机和端口 client.connect((target_host, int(port))) print("端口 {} 开放".format(port)) except: print("端口 {} 关闭".format(port)) finally: # 关闭连接 client.close() ``` 希望能够帮助到你。 ### 回答2: 端口扫描是网络安全中的一项重要任务,可以用来探测目标主机上开放的网络端口,进而判断目标主机上的服务或应用程序。下面是一个使用Python编写的简单端口扫描脚本。 ```python import socket # 定义要扫描的目标主机和端口范围 target_host = "localhost" target_ports = [80, 443, 8080] # 创建socket对象 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 设置超时时间(可选) sock.settimeout(2) # 遍历端口范围,进行扫描 for port in target_ports: try: # 尝试连接目标主机的指定端口 result = sock.connect_ex((target_host, port)) # 判断连接是否成功 if result == 0: print("Port {} is open".format(port)) else: print("Port {} is closed".format(port)) except socket.timeout: print("Port {} timed out".format(port)) except socket.error: print("Error connecting to port {}".format(port)) finally: # 关闭socket连接 sock.close() ``` 以上脚本使用了Python的`socket`模块,通过`socket.socket()`方法创建一个TCP socket对象,并设置超时时间。然后,通过遍历指定的端口范围,使用`sock.connect_ex()`方法来尝试连接目标主机的每个端口。连接成功则表示该端口为开放状态,否则表示该端口为关闭状态。异常处理部分用于处理超时或连接错误的情况。 该脚本可以通过修改`target_host`和`target_ports`的值来扫描不同的目标主机和端口范围。注意:在进行端口扫描时,请遵守法律和道德规范,确保已取得所有必要的授权。 ### 回答3: Python是一种功能强大的编程语言,可以用来编写端口扫描脚本。以下是一个简单的示例: ```python import socket # 定义要扫描的目标主机和端口范围 target_host = "127.0.0.1" start_port = 1 end_port = 100 # 循环扫描指定范围内的端口 for port in range(start_port, end_port+1): # 创建一个socket对象 client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client.settimeout(0.5) # 设置连接超时时间为0.5秒 try: # 尝试连接目标主机的指定端口 result = client.connect_ex((target_host, port)) if result == 0: print(f"端口 {port} 是开放的") except Exception as e: print(f"发生异常:{e}") finally: client.close() # 关闭socket连接 ``` 在上述代码中,我们首先导入了socket模块,然后定义了目标主机和要扫描的端口范围。接下来,我们通过一个循环迭代的方式,依次尝试连接每个端口。连接成功返回0,表示端口是开放的,然后我们打印出来。如果连接出现异常,则打印异常信息。最后,我们要记得关闭socket连接。 使用这个脚本,你可以指定要扫描的目标主机和端口范围,然后运行脚本,它将会依次扫描指定范围内的端口,并将开放的端口打印出来。请注意,扫描端口时可能需要一段时间,具体时间取决于目标主机和端口的数量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_49457994

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值