我需要下载许多文件从一个文件夹在一个单一的服务器,所以我正在寻找一种方法来做得更快。经过一点阅读,似乎多线程或异步方法都可以工作,但我似乎不能让这两种方法都起作用。在
我使用的异步方法如下。这是可行的,即没有错误,但它一次只下载一个文件,因此不能提高速度。有没有地方可以修改它,这样我就可以提高速度了?在async def get_file(self):
async with aioftp.ClientSession(self.host, self.port, self.login, self.password) as client:
async for path, info in client.list(recursive=True):
if info["type"] == "file":
await client.download(path, destination=self.dest_dir,write_into=True, block_size=self.block_size)
def async_update(self):
loop = asyncio.get_event_loop()
loop.run_until_complete(self.get_file())
loop.close()
然后我尝试在多处理中使用simple Pool()函数,如下所示:
^{pr2}$
但这失败了,并出现了一个错误。我一回到服务器就会更新这个错误。在