nginx дает ошибку 502 с uwsgi для запуска django на ubuntu 18.04 LTS - PullRequest
0 голосов
/ 08 июля 2020

Примечание: я новичок в django и его развертывании.

Развернуто django через uwsgi и nginx в соответствии с шагами, упомянутыми в этом руководстве - за исключением императора -васальная конфигурация и без какой-либо виртуальной среды.

Боковое примечание: на сайте используется python3 manage.py 0.0.0.0:8800

Но похоже, что nginx сталкивается с проблемами разрешения в сокете и выдает ошибку 502 неверного шлюза в браузере.

Журнал ошибок nginx показывает следующую ошибку:

2020/07/08 21:05:40 [критический] 3943 # 3943: * 3 connect () к unix: ///home/ubuntu/deploymenttst/MySite/MySite.sock не удалось (13: Permission denied) при подключении к восходящему потоку, клиент: 192.168.12.12, сервер : 192.168.12.12, запрос: «GET / HTTP / 1.1», восходящий поток: «uwsgi: // unix: ///home/ubuntu/deploymenttst/MySite/MySite.sock:», хост: «192.168.12.12: 8400 "

Конфигурация выглядит следующим образом:

  1. В файле settings.py проекта конфигурация a re установлен как (кроме wsgi по умолчанию):

    DEBUG = False
    ALLOWED_HOSTS = [ "192.168.12.12" ]
    STATIC_URL = '/static/'
    STATICFILES_DIRS = (
        os.path.join(BASE_DIR, 'static'),
    )
    STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
    
  2. Файл MySite_ nginx .conf внутри /etc/nginx/sites-available/MySite_nginx.conf имеет следующие записи конфигурации:

    # MySite_nginx.conf
    
    # the upstream component nginx needs to connect to
    upstream django {
        server unix:///home/ubuntu/deploymenttst/MySite/MySite.sock; # for a file socket
        #server 127.0.0.1:8008;
    }
    
    # configuration of the server
    server {
        # the port your site will be served on
        listen      8400;
        # the domain name it will serve for
        server_name 192.168.12.12; # substitute your machine's IP address or FQDN
        charset     utf-8;
    
        # max upload size
        client_max_body_size 75M;   # adjust to taste
    
    #    # Django media
        location /media  {
            alias /home/ubuntu/deploymenttst/MySite/media;  # your Django project's media files - amend as required
        }
    
        location /static {
            #alias /home/ubuntu/deploymenttst/MySite/main/static; # your Django project's static files - amend as required
            #alias /home/ubuntu/deploymenttst/MySite/register/static; # your Django project's static files - amend as required
            alias /home/ubuntu/deploymenttst/MySite/static; # your Django project's static files - amend as required
        }
    
        # Finally, send all non-media requests to the Django server.
        location / {
            uwsgi_pass  django;
            include     /home/ubuntu/deploymenttst/MySite/uwsgi_params; # the uwsgi_params file you installed
        }
    }
    

    Он был связан символом с /etc/nginx/sites-enabled/MySite_nginx.conf.

  3. Файл uwsgi_params создается внутри каталога проекта, содержащего следующие записи :

    uwsgi_param  QUERY_STRING       $query_string;
    uwsgi_param  REQUEST_METHOD     $request_method;
    uwsgi_param  CONTENT_TYPE       $content_type;
    uwsgi_param  CONTENT_LENGTH     $content_length;
    
    uwsgi_param  REQUEST_URI        $request_uri;
    uwsgi_param  PATH_INFO          $document_uri;
    uwsgi_param  DOCUMENT_ROOT      $document_root;
    uwsgi_param  SERVER_PROTOCOL    $server_protocol;
    uwsgi_param  REQUEST_SCHEME     $scheme;
    uwsgi_param  HTTPS              $https if_not_empty;
    
    uwsgi_param  REMOTE_ADDR        $remote_addr;
    uwsgi_param  REMOTE_PORT        $remote_port;
    uwsgi_param  SERVER_PORT        $server_port;
    uwsgi_param  SERVER_NAME        $server_name;
    
  4. Содержимое файла MySite_uwsgi.ini выглядит следующим образом:

    [uwsgi]
    
    # Django-related settings
    # the base directory (full path)
    chdir           = /home/ubuntu/deploymenttst/MySite
    # Django's wsgi file
    module          = MySite.wsgi
    # the virtualenv (full path)
    #home            = /home/ubuntu/deploymenttst/MySite/
    
    # process-related settings
    # master
    master          = true
    # maximum number of worker processes
    processes       = 20
    # the socket (use the full path to be safe
    socket          = /home/ubuntu/deploymenttst/MySite/MySite.sock
    # ... with appropriate permissions - may be needed
    chmod-socket    = 666
    uid = www-data
    gid = www-data
    # clear environment on exit
    vacuum          = true
    
  5. Stati c файлы были собранные внутри каталога stati c внутри каталога проекта с использованием python3 manage.py collectstatic

  6. В одном из терминалов windows процесс uwsgi успешно запускается с использованием: uwsgi --ini MySite_uwsgi.ini

  7. nginx был остановлен, запущен и перезапущен несколько раз при каждом изменении конфигурации, а также в противном случае.

  8. uid: gid MySite каталог проекта был установлен на www-data: www:data с использованием sudo chown -R www-data:www:data *

Почему я по-прежнему возникает ошибка 502 плохого шлюза, из-за которой с приложением django невозможно связаться из-за проблем с разрешением?

1 Ответ

0 голосов
/ 09 июля 2020

Проблема решена путем помещения проекта в каталог / tmp.

nginx, запущенный из www-data, пользователь не смог получить доступ к внутреннему каталогу MySite и, следовательно, к сокету или файлам, размещенным там, несмотря на то, что он назначен пользователю www-data.

Теперь мой другой вопрос касается причины проблемы с разрешением для nginx, несмотря на предоставление uid и gid каталога для www-data, что могло бы иметь была проблема?

Примечание. Мой пользователь с именем ubuntu является sudoer.

...