ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

如果使用的库不支持异步,可以使用多进程并将其转化为异步对象

2021-04-13 23:56:55  阅读:154  来源: 互联网

标签:异步 admin 使用 device time 进程 password loop


之前博文:
协程异步 SSH登录网络设备 以思科设备举例

 

目标:

如果编程当中,有些python库不支持异步IO,那么我们可以结合多进程的方式来实现类似协程异步的效果。

 

实验环境:

1.网络设备用eve模拟思科的IOS设备
2.python3
3.使用的python库有:
   a.asyncio
   b.asyncssh
   c.sys
   d.time
4.win10运行代码
5.实验拓扑:

如果使用的库不支持异步,可以使用多进程并将其转化为异步对象

 
代码如下:

from netmiko import ConnectHandler
import time
import asyncio
import concurrent.futures

def ssh_device(config):
    net_connect = ConnectHandler(**config)
    run_config = net_connect.send_command('show run')
    print(run_config)

async def main(host):

    loop = asyncio.get_running_loop()
    with concurrent.futures.ProcessPoolExecutor() as pool:
        result = await loop.run_in_executor(pool, ssh_device, host)
        print('custom process pool', result)

if __name__ == '__main__':
    # 6台需要访问的主机列表
    host_list = [
        {
            'device_type': 'cisco_ios',
            'ip': '172.16.1.101',
            'username': 'admin',
            'password': 'admin',
            'secret': 'admin',
        },
        {
            'device_type': 'cisco_ios',
            'ip': '172.16.1.102',
            'username': 'admin',
            'password': 'admin',
            'secret': 'admin',
        },
        {
            'device_type': 'cisco_ios',
            'ip': '172.16.1.103',
            'username': 'admin',
            'password': 'admin',
            'secret': 'admin',
        },
        {
            'device_type': 'cisco_ios',
            'ip': '172.16.1.104',
            'username': 'admin',
            'password': 'admin',
            'secret': 'admin',
        },
        {
            'device_type': 'cisco_ios',
            'ip': '172.16.1.200',
            'username': 'admin',
            'password': 'admin',
            'secret': 'admin',
        },
        {
            'device_type': 'cisco_ios',
            'ip': '172.16.1.100',
            'username': 'admin',
            'password': 'admin',
            'secret': 'admin',
        }
    ]
    # 记录开始时间
    start_time = time.time()
    # 定义存放异步任务的列表
    tasks = []
    # 启动一个循环事件
    loop = asyncio.get_event_loop()
    # 遍历需要配置的主机列表,创建任务对象
    for conf in host_list:
        tasks.append(loop.create_task(main(conf)))
    # 等待所有的异步任务执行完毕
    loop.run_until_complete(asyncio.wait(tasks))
    # 记录程序执行结束时间
    end_time = time.time()
    # 计算时间差
    delta_time = end_time - start_time
    print(delta_time)

 

执行如下:
12s左右的耗时:
如果使用的库不支持异步,可以使用多进程并将其转化为异步对象

 
如果使用同步的方式要38s左右:
如果使用的库不支持异步,可以使用多进程并将其转化为异步对象

标签:异步,admin,使用,device,time,进程,password,loop
来源: https://blog.51cto.com/jackor/2704503

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有