Отмена всех задач в случае сбоя с помощью concurrent.futures в PythonPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Отмена всех задач в случае сбоя с помощью concurrent.futures в Python

Сообщение Anonymous »

Я использую библиотеку Python concurrent.futures с ThreadPoolExecutor и ProcessPoolExecutor. Я хочу реализовать механизм отмены всех запущенных или невыполненных задач в случае сбоя какой-либо из задач. В частности, я хочу:
  • Отменить все фьючерсы (как запущенные, так и невыполненные) в случае сбоя задачи.
  • Поднять ошибка, которая привела к сбою первой задачи, если эта ошибка молча игнорируется; в противном случае позвольте Python поднять его естественным путем.
Вот подход, который я пробовал:

Код: Выделить всё

from concurrent.futures import ProcessPoolExecutor, as_completed
from functools import partial

copy_func = partial(copy_from, table_name=table_name, column_string=column_string)
with ProcessPoolExecutor(max_workers=cores_to_use) as executor:
futures = {executor.submit(copy_func, file_path): file_path for file_path in file_path_list}
for f in as_completed(futures):
try:
f.result()
except Exception as e:
executor.shutdown(wait=False)  # Attempt to stop the executor
for future in futures:
future.cancel()  # Cancel all futures
raise e  # Raise the exception
Вопросы:
  • Правильно ли это обрабатывать отмену задач в ThreadPoolExecutor и ProcessPoolExecutor?
  • Есть ли более эффективные подходы для достижения этой функциональности?
  • Как я могу гарантировать, что возникающее исключение не будет игнорироваться молча?
  • Как я могу гарантировать, что возникшее исключение не будет игнорироваться молча?
  • li>
    Как освободить все ресурсы, используемые concurrent.futures после исключения?
Спасибо !


Подробнее здесь: https://stackoverflow.com/questions/790 ... -in-python
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Отмена всех задач в случае сбоя с помощью concurrent.futures в Python
    Anonymous » » в форуме Python
    0 Ответы
    13 Просмотры
    Последнее сообщение Anonymous
  • Отмена всех задач в случае сбоя с помощью concurrent.futures в Python
    Anonymous » » в форуме Python
    0 Ответы
    26 Просмотры
    Последнее сообщение Anonymous
  • Как распараллелить доступ к общему массиву в Python с помощью concurrent.futures?
    Anonymous » » в форуме Python
    0 Ответы
    41 Просмотры
    Последнее сообщение Anonymous
  • Проблемы со сбором всех тиковых данных с помощью Concurrent.futures в Python
    Anonymous » » в форуме Python
    0 Ответы
    24 Просмотры
    Последнее сообщение Anonymous
  • Как я могу отслеживать, какая функция какое значение вернула, с помощью concurrent.futures.ThreadPoolExecutor()?
    Anonymous » » в форуме Python
    0 Ответы
    16 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Python»