首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在函数内调用时不使用多个工作进程的ThreadPoolExecutor

在函数内调用时不使用多个工作进程的ThreadPoolExecutor
EN

Stack Overflow用户
提问于 2020-10-19 00:55:19
回答 1查看 13关注 0票数 0

我正在尝试创建一个模块,该模块扫描给定的IP地址,并根据端口的当前状态返回每个端口的true或false。当上下文管理器被自己调用时,它工作得很好,但是当它在一个函数中被调用时,它会停止使用所有分配给它的线程。下面是我的代码:

代码语言:javascript
复制
import socket
import concurrent.futures

def _scan(ip, port):
    scanner = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    scanner.settimeout(1)
    try:
        scanner.connect((ip, port))
        scanner.close()
        return True
    except:
        return False

def portScan(ip, workers, portNum):
    with concurrent.futures.ThreadPoolExecutor(max_workers=workers) as executor:
        for port in range(portNum):
            future = executor.submit(_scan, ip, port + 1)
            print(future.result())

portScan("1.1.1.1", 100, 1000)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-19 01:15:36

问题是,在提交下一个之前,您需要等待每个将来都完成。您可以改用map。它将工作分散到所有线程,并以与提交的参数相同的顺序迭代结果。

代码语言:javascript
复制
import socket
import concurrent.futures

def _scan(params):
    ip, port = params
    scanner = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    scanner.settimeout(1)
    try:
        scanner.connect((ip, port))
        scanner.close()
        return True
    except:
        return False


def portScan(ip, workers, portNum):
    with concurrent.futures.ThreadPoolExecutor(max_workers=workers) as executor:
        for result in executor.map(_scan, ((ip, port) for port in range(portNum))):
            print(result)

portScan("127.0.0.1", 5, 22)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64415921

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档