• Python多线程批量Ping主机IP的脚本




    Python 编写多线程 Ping 主机IP的脚本

    1. 先编写一个 Ping 主机IP的脚本

    ping_ip.py

    import subprocess
    import time
    
    # 记录开始执行的时间
    start_time = time.time()
    
    # 定义用来 ping 的254 个 ip
    ip_list = ['10.3.1.'+str(i) for i in range(1,255)]  
    
    for ip in ip_list:
        res = subprocess.call('ping -n 2 -w 5 %s' % ip,stdout=subprocess.PIPE)  # linux 系统将 '-n' 替换成 '-c'
        print(ip,True if res == 0 else False)
    
    print('执行所用时间:%s' % (time.time() - start_time))

    2. 改造成多线程的脚本

    ping_threading.py

    import threading
    import subprocess
    import time
    from queue import Queue
    
    # 定义工作线程
    WORD_THREAD = 50
    
    # 将需要 ping 的 ip 加入队列
    IP_QUEUE = Queue() 
    for i in range(1,255):
        IP_QUEUE.put('10.3.1.'+str(i))
    
    # 定义一个执行 ping 的函数
    def ping_ip():
        while not IP_QUEUE.empty():
            ip = IP_QUEUE.get()
            res = subprocess.call('ping -n 2 -w 5 %s' % ip,stdout=subprocess.PIPE)  # linux 系统将 '-n' 替换成 '-c'
            # 打印运行结果
            print(ip,True if res == 0 else False)
    
    if __name__ == '__main__':
        threads = []
        start_time = time.time()
        for i in range(WORD_THREAD):
            thread = threading.Thread(target=ping_ip)
            thread.start()
            threads.append(thread)
    
        for thread in threads:
            thread.join()
    
        print('程序运行耗时:%s' % (time.time() - start_time))

    3.运行效果对比

    单线程的运行结果
    单线程的运行结果
    50个线程的运行结果
    50个线程的运行结果

  • 相关阅读:
    java基础1
    display:inline
    运用<ul><li>做导航栏
    ul和li 基本用法分析(这里主要想学习怎么用在导航栏中)
    转换(旋转)transform
    典型相关分析
    相关性模型-相关系数
    拟合算法
    插值算法
    评估类模型之优劣解距离法Topsis模型
  • 原文地址:https://www.cnblogs.com/cute/p/13524272.html
Copyright © 2020-2023  润新知