chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何利用Python實現(xiàn)快速Ping一個IP網(wǎng)段地址?

馬哥Linux運維 ? 來源:散盡浮華 2021 ? 作者:散盡浮華 2021 ? 2021-06-29 15:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

ping 命令是我們檢查網(wǎng)絡(luò)中最常用的命令,作為網(wǎng)絡(luò)人員,基本上每天都會用到,可以很好地幫助我們分析和判定網(wǎng)絡(luò)故障;如果有 10 設(shè)備,100 臺設(shè)備,1000 臺設(shè)備怎么辦?一個個 ping 過去人都要瘋掉了,這種情況在大型網(wǎng)絡(luò)中我們有可能遇到,那怎么辦呢?我們今天來看下如何用 python 來實現(xiàn)批量 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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 主機
    +關(guān)注

    關(guān)注

    0

    文章

    1053

    瀏覽量

    36631
  • Ping
    +關(guān)注

    關(guān)注

    0

    文章

    72

    瀏覽量

    16798
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4956

    瀏覽量

    73500
  • python
    +關(guān)注

    關(guān)注

    57

    文章

    4867

    瀏覽量

    89804

原文標(biāo)題:用 Python 實現(xiàn)快速 Ping 一個 IP 網(wǎng)段地址!

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    SCADA系統(tǒng)的NAT轉(zhuǎn)換與網(wǎng)段隔離解決方案

    IP172.16.0.x,兩者之間不在網(wǎng)段內(nèi)便無法進行通信。加上部分設(shè)備存在相同IP沖突問題,導(dǎo)致SCADA系統(tǒng)的建設(shè)受到困擾。 對此,
    的頭像 發(fā)表于 12-26 15:54 ?176次閱讀
    SCADA系統(tǒng)的NAT轉(zhuǎn)換與<b class='flag-5'>網(wǎng)段</b>隔離解決方案

    網(wǎng)段隔離器解決IP沖突問題,實現(xiàn)網(wǎng)段通信

    在互聯(lián)網(wǎng)的世界里,每臺設(shè)備都如同擁有獨特的“家庭住址”——IP地址。設(shè)備之間的通信,就如同人與人之間交流需要知道對方的住址
    的頭像 發(fā)表于 11-19 14:32 ?272次閱讀
    <b class='flag-5'>網(wǎng)段</b>隔離器解決<b class='flag-5'>IP</b>沖突問題,<b class='flag-5'>實現(xiàn)</b>跨<b class='flag-5'>網(wǎng)段</b>通信

    工業(yè)NAT網(wǎng)關(guān)實現(xiàn)PLC、機床等設(shè)備IP地址沖突的解決方案

    在工業(yè)自動化項目中,工程師經(jīng)常會遇到問題——IP地址沖突。比如臺編寫好程序的自動化設(shè)備,其內(nèi)部PLC的
    的頭像 發(fā)表于 11-06 16:58 ?650次閱讀
    工業(yè)NAT網(wǎng)關(guān)<b class='flag-5'>實現(xiàn)</b>PLC、機床等設(shè)備<b class='flag-5'>IP</b><b class='flag-5'>地址</b>沖突的解決方案

    NAT網(wǎng)關(guān)能夠實現(xiàn)哪些工業(yè)設(shè)備的網(wǎng)段隔離

    NAT網(wǎng)關(guān)在工業(yè)場景中可實現(xiàn)PLC、HMI、CNC、DCS、MES等設(shè)備的網(wǎng)段隔離與跨網(wǎng)段通信,具體功能及設(shè)備支持如下 : 、核心功能實現(xiàn)
    的頭像 發(fā)表于 10-27 11:03 ?511次閱讀
    NAT網(wǎng)關(guān)能夠<b class='flag-5'>實現(xiàn)</b>哪些工業(yè)設(shè)備的<b class='flag-5'>網(wǎng)段</b>隔離

    網(wǎng)段隔離器適用于哪些設(shè)備的NAT轉(zhuǎn)換

    等)網(wǎng)段隔離和NAT 轉(zhuǎn)換,可以將不同網(wǎng)段IP地址統(tǒng)成同一網(wǎng)段
    的頭像 發(fā)表于 10-24 10:52 ?404次閱讀
    <b class='flag-5'>網(wǎng)段</b>隔離器適用于哪些設(shè)備的NAT轉(zhuǎn)換

    NAT網(wǎng)關(guān)與網(wǎng)段隔離器有什么聯(lián)系

    景三維度展開分析: 、功能定位:互補性技術(shù)設(shè)計 NAT網(wǎng)關(guān) 核心功能是 網(wǎng)絡(luò)地址轉(zhuǎn)換(NAT) ,通過將私有IP地址轉(zhuǎn)換為公有
    的頭像 發(fā)表于 10-21 14:03 ?382次閱讀

    網(wǎng)段隔離器實現(xiàn)靜態(tài)NAT網(wǎng)絡(luò)通信

    在許多網(wǎng)絡(luò)場景中,不同網(wǎng)段之間需要進行通信,但又要保證各網(wǎng)段的相對獨立性和安全性。如果缺少網(wǎng)絡(luò)規(guī)劃與網(wǎng)段隔離,會使網(wǎng)絡(luò)面臨巨大的安全風(fēng)險,各類網(wǎng)絡(luò)攻擊更容易傳播。而靜態(tài)NAT能夠在實現(xiàn)
    的頭像 發(fā)表于 08-16 13:44 ?779次閱讀

    網(wǎng)段隔離器哪個好用?有哪些推薦?

    網(wǎng)段隔離器(又稱NAT轉(zhuǎn)換網(wǎng)關(guān))是解決網(wǎng)絡(luò)規(guī)劃、通信隔離與安全防護的核心設(shè)備,可實現(xiàn)網(wǎng)段通信、IP統(tǒng)管理,在工業(yè)網(wǎng)絡(luò)安全等領(lǐng)域發(fā)揮關(guān)鍵作
    的頭像 發(fā)表于 08-08 11:07 ?986次閱讀
    <b class='flag-5'>網(wǎng)段</b>隔離器哪個好用?有哪些推薦?

    編程軟件連接PLC出現(xiàn)IP沖突時如何解決?

    般來說,每個PLC都有自己的IP地址,用以和其他設(shè)備進行通信。而如果同網(wǎng)絡(luò)出現(xiàn)相同IP的設(shè)備,就會導(dǎo)致
    的頭像 發(fā)表于 07-31 17:08 ?971次閱讀
    編程軟件連接PLC出現(xiàn)<b class='flag-5'>IP</b>沖突時如何解決?

    交換機無法Ping通本機IPv6接口地址問題

    某互聯(lián)網(wǎng)電視CDN網(wǎng)絡(luò)ZXR10 5960-56QU-HC(簡稱5960)交換機下掛CDN服務(wù)器,vlan-if接口地址作為服務(wù)器網(wǎng)關(guān),在運行中出現(xiàn)服務(wù)器無法ping通IPv6網(wǎng)關(guān),并且5960也無法ping通該接口的IPv6
    的頭像 發(fā)表于 07-22 11:25 ?2328次閱讀
    交換機無法<b class='flag-5'>Ping</b>通本機IPv6接口<b class='flag-5'>地址</b>問題

    NAT網(wǎng)關(guān)與網(wǎng)段隔離器有什么區(qū)別

    NAT網(wǎng)關(guān)與網(wǎng)段隔離器在網(wǎng)絡(luò)通信中扮演不同角色, NAT網(wǎng)關(guān)的核心功能是地址轉(zhuǎn)換與端口復(fù)用,側(cè)重解決IP資源短缺和跨網(wǎng)段通信問題;網(wǎng)段隔離器
    的頭像 發(fā)表于 07-16 15:19 ?570次閱讀

    NAT網(wǎng)關(guān)實現(xiàn)網(wǎng)段訪問與設(shè)備統(tǒng)管理

    在出廠時預(yù)設(shè)了固定的IP地址,更改成本較高,工期也較長,亟待高效可靠的解決方案。 物通博聯(lián)推出的NAT網(wǎng)關(guān)適用于生產(chǎn)網(wǎng)絡(luò)對PLC、HMI、CNC、DCS、MES等網(wǎng)絡(luò)通訊和數(shù)據(jù)采集,兼有跨網(wǎng)段隔離和
    的頭像 發(fā)表于 06-21 15:41 ?864次閱讀
    NAT網(wǎng)關(guān)<b class='flag-5'>實現(xiàn)</b>跨<b class='flag-5'>網(wǎng)段</b>訪問與設(shè)備統(tǒng)<b class='flag-5'>一</b>管理

    TECS OpenStack資源池虛擬機網(wǎng)絡(luò)二層地址無法互通的問題處理

    某運營商TECS OpenStack使用主機overlay SDN方案組網(wǎng),運維人員在創(chuàng)建虛擬機測試虛擬機網(wǎng)絡(luò)狀態(tài)時發(fā)現(xiàn)問題:在其中臺主機上創(chuàng)建兩臺同網(wǎng)段虛擬機,虛擬機之間二層地址無法Pin
    的頭像 發(fā)表于 06-12 09:28 ?780次閱讀
    TECS OpenStack資源池虛擬機網(wǎng)絡(luò)二層<b class='flag-5'>地址</b>無法互通的問題處理

    網(wǎng)段通訊終極指南讓不同網(wǎng)段PLC設(shè)備實現(xiàn)無障礙對話

    直接通信的,需要特殊的配置或ip地址轉(zhuǎn)換器(耦合器)設(shè)備來實現(xiàn)通信,不同網(wǎng)段的PLC通訊需要跨網(wǎng)段耦合器。用捷米特功能模塊JM-ETH-NA
    的頭像 發(fā)表于 04-23 09:49 ?833次閱讀
    跨<b class='flag-5'>網(wǎng)段</b>通訊終極指南讓不同<b class='flag-5'>網(wǎng)段</b>PLC設(shè)備<b class='flag-5'>實現(xiàn)</b>無障礙對話

    網(wǎng)段隔離器實現(xiàn)網(wǎng)段PLC數(shù)據(jù)通信

    在工廠自動化生產(chǎn)中,不同生產(chǎn)環(huán)節(jié)的PLC處于不同網(wǎng)段,實現(xiàn)網(wǎng)段PLC數(shù)據(jù)通信對提升生產(chǎn)協(xié)同性至關(guān)重要。網(wǎng)段隔離器憑借自身特性,可有效解決這
    的頭像 發(fā)表于 04-18 15:15 ?771次閱讀
    <b class='flag-5'>網(wǎng)段</b>隔離器<b class='flag-5'>實現(xiàn)</b>多<b class='flag-5'>網(wǎng)段</b>PLC數(shù)據(jù)通信