Я новичок в python, и я пытаюсь решить простую проблему: у меня есть два блока операций (Блок A и Блок B), каждый блок выполняет различные команды оболочки, которые должны выполняться асин c внутри блок (в том же блоке я могу выполнить новую операцию, не дожидаясь результата первого).
Я могу начать выполнение операций «Блока Б» только тогда, когда все операции «Блока» A 'завершены.
import asyncio
import subprocess
import sys
import threading
async def run_command(number, timeSleep):
cmd = "(echo '"+ number +" Start -->' $(date) ;sleep "+timeSleep +" ;echo '"+ number +" End -->' $(date) ) >> /tmp/log.txt"
p = subprocess.Popen(cmd, stderr=subprocess.PIPE, shell=True)
async def block_a():
await asyncio.gather(
run_command("Block A: Operation 1","8"),
run_command("Block A: Operation 2","4"),
run_command("Block A: Operation 3","2"))
async def block_b():
await asyncio.gather(
run_command("Block B Operation 1","5"),
run_command("Block B Operation 2","4"),
run_command("Block B Operation 3","1"))
async def main():
await asyncio.gather(
block_a(),
block_b())
if __name__ == '__main__':
# Create the asyncio event loop
loop = asyncio.get_event_loop()
try:
loop.run_until_complete(main())
finally:
# Shutdown the loop even if there is an exception
loop.close()
Я получаю следующий вывод:
Block A: Operation 2 Start --> Thu Apr 9 21:21:27 CEST 2020
Block A: Operation 3 Start --> Thu Apr 9 21:21:27 CEST 2020
Block A: Operation 1 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 1 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 2 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 3 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 3 End --> Thu Apr 9 21:21:28 CEST 2020
Block A: Operation 3 End --> Thu Apr 9 21:21:29 CEST 2020
Block A: Operation 2 End --> Thu Apr 9 21:21:31 CEST 2020
Block B Operation 2 End --> Thu Apr 9 21:21:31 CEST 2020
Block B Operation 1 End --> Thu Apr 9 21:21:32 CEST 2020
Block A: Operation 1 End --> Thu Apr 9 21:21:35 CEST 2020
Я ожидаю начать операции блока B после того, как операции блока A завершены.
Результат, который я ожидал, выглядит примерно так:
Block A: Operation 2 Start --> Thu Apr 9 21:21:27 CEST 2020
Block A: Operation 3 Start --> Thu Apr 9 21:21:27 CEST 2020
Block A: Operation 1 Start --> Thu Apr 9 21:21:27 CEST 2020
Block A: Operation 3 End --> Thu Apr 9 21:21:29 CEST 2020
Block A: Operation 2 End --> Thu Apr 9 21:21:31 CEST 2020
Block A: Operation 1 End --> Thu Apr 9 21:21:35 CEST 2020
Block B Operation 1 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 2 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 3 Start --> Thu Apr 9 21:21:27 CEST 2020
Block B Operation 3 End --> Thu Apr 9 21:21:28 CEST 2020
Block B Operation 2 End --> Thu Apr 9 21:21:31 CEST 2020
Block B Operation 1 End --> Thu Apr 9 21:21:32 CEST 2020