0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何利用Python实现快速Ping一个IP网段地址?

马哥Linux运维 来源:散尽浮华 2021 作者:散尽浮华 2021 2021-06-29 15:59 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

ping 命令是我们检查网络中最常用的命令,作为网络人员,基本上每天都会用到,可以很好地帮助我们分析和判定网络故障;如果有 10 设备,100 台设备,1000 台设备怎么办?一个个 ping 过去人都要疯掉了,这种情况在大型网络中我们有可能遇到,那怎么办呢?我们今天来看下如何用 python 来实现批量 ping 测试主机。代码如下:

#!/usr/bin/python3# -*- coding: utf-8 -*-import os

import argparse

import socket

import struct

import select

import time

ICMP_ECHO_REQUEST = 8 # Platform specific

DEFAULT_TIMEOUT = 0.1

DEFAULT_COUNT = 4class Pinger(object):

“”“ Pings to a host -- the Pythonic way”“”

def __init__(self, target_host, count=DEFAULT_COUNT, timeout=DEFAULT_TIMEOUT):

self.target_host = target_host

self.count = count

self.timeout = timeout

def do_checksum(self, source_string):

“”“ Verify the packet integritity ”“”

sum = 0

max_count = (len(source_string)/2)*2

count = 0

while count 《 max_count:

val = source_string[count + 1]*256 + source_string[count]

sum = sum + val

sum = sum & 0xffffffff

count = count + 2

if max_count《len(source_string):

sum = sum + ord(source_string[len(source_string) - 1])

sum = sum & 0xffffffff

sum = (sum 》》 16) + (sum & 0xffff)

sum = sum + (sum 》》 16)

answer = ~sum

answer = answer & 0xffff

answer = answer 》》 8 | (answer 《《 8 & 0xff00)

return answer

def receive_pong(self, sock, ID, timeout):

“”“

Receive ping from the socket.

”“”

time_remaining = timeout

while True:

start_time = time.time()

readable = select.select([sock], [], [], time_remaining)

time_spent = (time.time() - start_time)

if readable[0] == []: # Timeout

return

time_received = time.time()

recv_packet, addr = sock.recvfrom(1024)

icmp_header = recv_packet[20:28]

type, code, checksum, packet_ID, sequence = struct.unpack(

“bbHHh”, icmp_header

if packet_ID == ID:

bytes_In_double = struct.calcsize(“d”)

time_sent = struct.unpack(“d”, recv_packet[28:28 + bytes_In_double])[0]

return time_received - time_sent

time_remaining = time_remaining - time_spent

if time_remaining 《= 0:

return

def send_ping(self, sock, ID):

“”“

Send ping to the target host

”“”

target_addr = socket.gethostbyname(self.target_host)

my_checksum = 0

# Create a dummy heder with a 0 checksum.

header = struct.pack(“bbHHh”, ICMP_ECHO_REQUEST, 0, my_checksum, ID, 1)

bytes_In_double = struct.calcsize(“d”)

data = (192 - bytes_In_double) * “Q”

data = struct.pack(“d”, time.time()) + bytes(data.encode(‘utf-8’))

# Get the checksum on the data and the dummy header.

my_checksum = self.do_checksum(header + data)

header = struct.pack(

“bbHHh”, ICMP_ECHO_REQUEST, 0, socket.htons(my_checksum), ID, 1

packet = header + data

sock.sendto(packet, (target_addr, 1))

def ping_once(self):

“”“

Returns the delay (in seconds) or none on timeout.

”“”

icmp = socket.getprotobyname(“icmp”)

try:

sock = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp)

except socket.error as e:

if e.errno == 1:

# Not superuser, so operation not permitted

e.msg += “ICMP messages can only be sent from root user processes”

raise socket.error(e.msg)

except Exception as e:

print(“Exception: %s” %(e))

my_ID = os.getpid() & 0xFFFF

self.send_ping(sock, my_ID)

delay = self.receive_pong(sock, my_ID, self.timeout)

sock.close()

return delay

def ping(self):

“”“

Run the ping process

”“”

for i in range(self.count):

print (“Ping to %s.。。” % self.target_host,)

try:

delay = self.ping_once()

except socket.gaierror as e:

print (“Ping failed. (socket error: ‘%s’)” % e[1])

break

if delay == None:

print (“Ping failed. (timeout within %ssec.)” % self.timeout)

else:

delay = delay * 1000

print(“Get pong in %0.4fms” % delay)

if __name__ == ‘__main__’:

alive = []

host_prefix = ‘192.168.242.’

for i in range(1, 255):

host = host_prefix + str(i)

pinger = Pinger(target_host=host)

delay = pinger.ping_once()

if delay == None:

print(“Ping %s 失败,超时2秒” % host)

else:

print(“ping %s = %s ms” % (host, round(delay * 1000, 4)))

alive.append(host)

# time.sleep(0.5)

测试如下:

8b6ab878-d895-11eb-9e57-12bb97331649.gif

原文链接:www.yjsec.com/2020/11/07
编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 主机
    +关注

    关注

    0

    文章

    1047

    浏览量

    36433
  • Ping
    +关注

    关注

    0

    文章

    72

    浏览量

    16767
  • 代码
    +关注

    关注

    30

    文章

    4941

    浏览量

    73151
  • python
    +关注

    关注

    57

    文章

    4858

    浏览量

    89588

原文标题:用 Python 实现快速 Ping 一个 IP 网段地址!

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    网段隔离器解决IP冲突问题,实现网段通信

    在互联网的世界里,每台设备都如同拥有独特的“家庭住址”——IP地址。设备之间的通信,就如同人与人之间交流需要知道对方的住址
    的头像 发表于 11-19 14:32 132次阅读
    <b class='flag-5'>网段</b>隔离器解决<b class='flag-5'>IP</b>冲突问题,<b class='flag-5'>实现</b>跨<b class='flag-5'>网段</b>通信

    NAT网关能够实现哪些工业设备的网段隔离

    NAT网关在工业场景中可实现PLC、HMI、CNC、DCS、MES等设备的网段隔离与跨网段通信,具体功能及设备支持如下 : 、核心功能实现
    的头像 发表于 10-27 11:03 343次阅读
    NAT网关能够<b class='flag-5'>实现</b>哪些工业设备的<b class='flag-5'>网段</b>隔离

    网段隔离器适用于哪些设备的NAT转换

    等)网段隔离和NAT 转换,可以将不同网段IP地址成同一网段
    的头像 发表于 10-24 10:52 298次阅读
    <b class='flag-5'>网段</b>隔离器适用于哪些设备的NAT转换

    NAT网关与网段隔离器有什么联系

    景三维度展开分析: 、功能定位:互补性技术设计 NAT网关 核心功能是 网络地址转换(NAT) ,通过将私有IP地址转换为公有
    的头像 发表于 10-21 14:03 249次阅读

    网段隔离器实现静态NAT网络通信

    在许多网络场景中,不同网段之间需要进行通信,但又要保证各网段的相对独立性和安全性。如果缺少网络规划与网段隔离,会使网络面临巨大的安全风险,各类网络攻击更容易传播。而静态NAT能够在实现
    的头像 发表于 08-16 13:44 653次阅读

    编程软件连接PLC出现IP冲突时如何解决?

    般来说,每个PLC都有自己的IP地址,用以和其他设备进行通信。而如果同网络出现相同IP的设备,就会导致
    的头像 发表于 07-31 17:08 829次阅读
    编程软件连接PLC出现<b class='flag-5'>IP</b>冲突时如何解决?

    NAT网关与网段隔离器有什么区别

    NAT网关与网段隔离器在网络通信中扮演不同角色, NAT网关的核心功能是地址转换与端口复用,侧重解决IP资源短缺和跨网段通信问题;网段隔离器
    的头像 发表于 07-16 15:19 454次阅读

    NAT网关实现网段访问与设备统管理

    在出厂时预设了固定的IP地址,更改成本较高,工期也较长,亟待高效可靠的解决方案。 物通博联推出的NAT网关适用于生产网络对PLC、HMI、CNC、DCS、MES等网络通讯和数据采集,兼有跨网段隔离和
    的头像 发表于 06-21 15:41 741次阅读
    NAT网关<b class='flag-5'>实现</b>跨<b class='flag-5'>网段</b>访问与设备统<b class='flag-5'>一</b>管理

    网段通讯终极指南让不同网段PLC设备实现无障碍对话

    直接通信的,需要特殊的配置或ip地址转换器(耦合器)设备来实现通信,不同网段的PLC通讯需要跨网段耦合器。用捷米特功能模块JM-ETH-NA
    的头像 发表于 04-23 09:49 722次阅读
    跨<b class='flag-5'>网段</b>通讯终极指南让不同<b class='flag-5'>网段</b>PLC设备<b class='flag-5'>实现</b>无障碍对话

    网段隔离器实现网段PLC数据通信

    在工厂自动化生产中,不同生产环节的PLC处于不同网段实现网段PLC数据通信对提升生产协同性至关重要。网段隔离器凭借自身特性,可有效解决这
    的头像 发表于 04-18 15:15 649次阅读
    <b class='flag-5'>网段</b>隔离器<b class='flag-5'>实现</b>多<b class='flag-5'>网段</b>PLC数据通信

    工厂无线局域网WIFI如何跨网段访问多个PLC?

    通讯,三菱PLC则不能与上位机通信,就会导致上位机中的监控系统得不到数据来源,相关的监控、控制与管理等应用也无法实现。 通过接入物通博联PLC网络耦合器,可以将不同网段IP地址
    的头像 发表于 12-31 14:34 1079次阅读
    工厂无线局域网WIFI如何跨<b class='flag-5'>网段</b>访问多个PLC?

    ISP与IP地址

    才能接入互联网,与其他设备进行通信和数据传输。这是前提也是基础。   ISP通常使用DHCP来为用户提供IP地址的动态分配。当设备连接到ISP的网络时,DHCP服务器会自动从IP地址
    的头像 发表于 12-27 10:41 924次阅读

    CIDR的IP地址分配与管理

    传统IP地址分类,也就是ABC类等。但是,有种情况,“如果公司可能被分配了
    的头像 发表于 12-26 10:01 947次阅读

    突破跨网段通讯问题:不同网段PLC设备如何通讯?

    不能直接通信的,需要特殊的配置或ip地址转换器(耦合器)设备来实现通信,不同网段的PLC通讯需要跨网段耦合器。用过捷米特功能模块JM-ETH
    的头像 发表于 12-10 11:55 1546次阅读
    突破跨<b class='flag-5'>网段</b>通讯问题:不同<b class='flag-5'>网段</b>PLC设备如何通讯?

    无需修改设备IP实现网段访问的解决方案

    数字化、网络化改造造成困扰。 在有组网设备存在IP地址端冲突且无法修改网段时,可通过物通博联网段耦合器(NAT网关),将车间生产设备的IP
    的头像 发表于 12-09 17:16 1119次阅读
    无需修改设备<b class='flag-5'>IP</b><b class='flag-5'>实现</b>跨<b class='flag-5'>网段</b>访问的解决方案