Gunicorn бросает OSError Errno 1 при запуске

Я пытаюсь развернуть Django 1.5 с помощью Gunicorn/nginx/supervisor, но на этом этапе я просто пытаюсь запустить Gunicorn правильно.

Я пытаюсь начать с командной строки:

gunicorn project.wsgi:application --workers 3 --user=django --group=django --bind=127.0.0.1:8100

и с ошибкой

OSError: [Errno 1] Operation not permitted: '/tmp/wgunicorn-c7BU9r'

След:

2013-11-01 20:03:24 [17860] [INFO] Starting gunicorn 18.0
2013-11-01 20:03:24 [17860] [INFO] Listening at: http://127.0.0.1:8000 (17860)
2013-11-01 20:03:24 [17860] [INFO] Using worker: sync
Traceback (most recent call last):
  File "/opt/envs/bedlounge-front/bin/gunicorn", line 9, in <module>
    load_entry_point('gunicorn==18.0', 'console_scripts', 'gunicorn')()
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/app/wsgiapp.py", line 71, in run
    WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]").run()
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/app/base.py", line 143, in run
    Arbiter(self).run()
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/arbiter.py", line 175, in run
    self.manage_workers()
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/arbiter.py", line 470, in manage_workers
    self.spawn_workers()
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/arbiter.py", line 529, in spawn_workers
    self.spawn_worker()
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/arbiter.py", line 482, in spawn_worker
    self.cfg, self.log)
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/workers/base.py", line 49, in __init__
    self.tmp = WorkerTmp(cfg)
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/workers/workertmp.py", line 25, in __init__
    util.chown(name, cfg.uid, cfg.gid)
  File "/opt/envs/bedlounge-front/lib/python2.7/site-packages/gunicorn/util.py", line 157, in chown
    os.chown(path, uid, gid)
OSError: [Errno 1] Operation not permitted: '/tmp/wgunicorn-c7BU9r'

Если я начинаю без аргументов пользователя и группы (как мой обычный пользователь), он начинается просто отлично. Я понимаю, что хотел бы начать это под другим пользователем или группой.

Может ли кто-нибудь помочь мне с тем, что я делаю неправильно? Или любую информацию, которая поможет мне решить эту проблему?

Спасибо!

Ответ 1

Проблема может заключаться в том, что ваш пользователь пытается запустить процесс как другой пользователь. Я предполагаю, что вы создали пользователя и группу в ОС. Вы можете попробовать свою предыдущую команду как root или использовать sudo.

Я использую следующую конфигурацию Supervisor, которая указывает пользователя как в командной строке, так и в качестве опции:

[program:gunicorn]
command=/opt/mysite/virtual_env/bin/python \
    /opt/mysite/virtual_env/bin/gunicorn_django -w 2 --user=appsrun
directory = /opt/mysite/virtual_env/app/
user = appsrun