Gunicorn + Subprocesses вызывает исключение [Errno 10] - PullRequest
3 голосов
/ 07 января 2012

Я наткнулся на странное исключение, которое мне не удалось разрешить ... Кто-нибудь может подсказать, что не так или новый дизайн?Я запускаю приложение Gunicorn / Flask.В файле конфигурации я указываю некоторую работу с хуком on_starting [1].Внутри этого кода хука у меня есть такой код (ничего особенного):

# Called before the server is started
my_thread = package.MyThread()
my_thread.start()

Класс package.MyThread выглядит следующим образом.Команда ls не важна, это может быть любая команда.

class MyThread(threading.Thread):
  """
    Run a command every 60 seconds.

  """
  def __init__(self):
    threading.Thread.__init__(self)
    self.event = threading.Event()

  def run(self):
    while not self.event.is_set():
      ptest = subprocess.Popen(["ls"], stdout=subprocess.PIPE)
      ptest.communicate()
      self.event.wait(60)

  def stop(self):
    self.event.set()

При запуске сервера мне всегда предоставляется следующее исключение:

Exception in thread Thread-1:
Traceback (most recent call last):
  File "/usr/lib64/python2.6/threading.py", line 532, in __bootstrap_inner
    self.run()
  File "__init__.py", line 195, in run
    ptest.communicate()
  File "/usr/lib64/python2.6/subprocess.py", line 721, in communicate
    self.wait()
  File "/usr/lib64/python2.6/subprocess.py", line 1288, in wait
    pid, sts = _eintr_retry_call(os.waitpid, self.pid, 0)
  File "/usr/lib64/python2.6/subprocess.py", line 462, in _eintr_retry_call
    return func(*args)
OSError: [Errno 10] No child processes

Может кто-нибудь предложитьчто происходит здесь?Я не пытался реализовать изменения в [2], они казались хакерскими.

[1] - http://gunicorn.org/configure.html#server-hooks

[2] - Popen.communicate () выбрасывает OSError: «[Errno 10] Нет дочерних процессов»

1 Ответ

3 голосов
/ 07 января 2012

Ошибка связана с обработкой сигнала SIGCHLD.

Арбитр gunicorn перехватывает SIGCHLD, что прерывает subprocess.Popen. Модуль subprocess.Popen требует, чтобы SIGCHLD не был перехвачен (по крайней мере, это верно для Python 2.6 и более ранних версий).

Согласно bugs.python.org эта ошибка была исправлена ​​в Python 2.7.

...