Я не знаю, почему сервер Nginx не работает - PullRequest
0 голосов
/ 24 октября 2019

Привет! Я пытаюсь запустить какое-нибудь приложение django, используя nginx + gunicorn + supervisor.

Следуя этому руководству Мне удалось воспроизвести все шаги с успехом, но по какой-то причине я не могу заставить его работать. Я считаю, что проблема связана с частью проекта nginx, так как я не могу даже предоставить статический файл для тестирования. Я впервые использую все эти инструменты.

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

nginx.conf:

worker_processes 1;

user nobody nogroup;
# 'user nobody nobody;' for systems with 'nobody' as a group instead
error_log  /home/seba94/log/nginx/nginx.error.log warn;
#pid /run/nginx.pid;

events {
  worker_connections 1024; # increase if you have lots of clients
  accept_mutex off; # set to 'on' if nginx worker_processes > 1
  # 'use epoll;' to enable for Linux 2.6+
  # 'use kqueue;' to enable for FreeBSD, OSX
}

http {
  include /etc/nginx/mime.types;
  # fallback in case we can't determine a type
  default_type application/octet-stream;
  access_log /home/seba94/log/nginx/nginx.access.log combined;
  sendfile on;

  upstream app_server {
    # fail_timeout=0 means we always retry an upstream even if it failed
    # to return a good HTTP response

    # for UNIX domain socket setups
    server unix:/tmp/gunicorn.sock fail_timeout=10s;

    # for a TCP configuration
    #server 127.0.0.1:8000 fail_timeout=0;
  }


  server {
    # if no Host match, close the connection to prevent host spoofing
    listen 80 default_server;
    return 444;
  }

  server {
    # use 'listen 80 deferred;' for Linux
    # use 'listen 80 accept_filter=httpready;' for FreeBSD
listen 80;
    client_max_body_size 4G;

    # set the correct host(s) for your site
    server_name reg.rocstar.tv;

    keepalive_timeout 5;

    # path for static files
    root /home/seba94/static;

    location /register/ {
      # checks for static file, if not found proxy to app
      try_files $uri @proxy_to_app;
    }


    location /media/  {
      #path for Django media files
      alias /home/seba94/register-page/register_page/media;
    }

    location /static/ {
      #path for Django static files
      alias /home/seba94/register-page/register_page/static;
    }

    location /todd-logo.png {
      alias /home/seba94/static/todd-logo.png;
    }


    location @proxy_to_app {
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header X-Forwarded-Proto $scheme;
      proxy_set_header Host $http_host;
      # we don't want nginx trying to do something clever with
      # redirects, we set the Host: header above already.
      proxy_redirect off;
      proxy_pass http://app_server;
    }

    error_page 500 502 503 504 /500.html;
    location = /500.html {
      root /home/seba94/static;
    }
  }

supervisord.conf:

[supervisord]
logfile=/home/seba94/log/supervisord/supervisord.log

[inet_http_server]
port=127.0.0.1:9001

[rpcinterface:supervisor]
supervisor.rpcinterface_factory=supervisor.rpcinterface:make_main_rpcinterface

[program:register-page-django]
command=/home/seba94/.local/share/virtualenvs/register-page-jYLn8mRO/bin/gunicorn register_page.wsgi -c /home/seba94/conf/gunicorn.conf.py
directory=/home/seba94/register-page/register_page
user=seba94
autostart=true
autorestart=true
stdout_logfile=/home/seba94/log/supervisord/register_page.log
stderr_logfile=/home/seba94/log/supervisord/register_page.err.log

[supervisorctl]

gunicorn.conf.py:

import multiprocessing

#Server socket config
bind = "unix:/tmp/gunicorn.sock"
backlog = 2048

#Workers config. Eventlet is an asynchronus worker
workers = multiprocessing.cpu_count() * 2
worker_class = "eventlet"
worker_connections = 1000


#access-logfile = "/home/seba94/log/gunicorn/gunicorn.log"
#error-logfile = "/home/seba94/log/gunicorn/gunicorn.error.log"


name = "register-page-gunicorn"


#Server mechanics
#daemon = True

Я могу успешно запустить все процессы без ошибок из cmd с помощью следующих команд:

  • sudo service nginx start
  • sudo supervisord -c /home/seba94/conf/supervisord.conf
  • sudo supervisorctrl start register-page-django

Nginx имеет следующий статус:

● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
   Active: active (running) since Wed 2019-10-23 20:38:58 UTC; 31min ago
     Docs: man:nginx(8)
  Process: 5552 ExecStop=/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /run/nginx.pid (code=exited, status=0/SUCCESS)
  Process: 5599 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
  Process: 5594 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
 Main PID: 5601 (nginx)
    Tasks: 2 (limit: 1108)
   CGroup: /system.slice/nginx.service
           ├─5601 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
           └─5760 nginx: worker process

oct 23 20:38:58 register-page-server systemd[1]: Starting A high performance web server and a reverse proxy server...
oct 23 20:38:58 register-page-server systemd[1]: Started A high performance web server and a reverse proxy server.

Честно говоря, я не могу найти никаких ошибокдаже не в файлах журналов, поэтому я не знаю, почему я даже не вижу свой статический файл todd-logo.png. Также я не вижу работающего приложения Django. Любая помощь более чем приветствуется

Редактировать:

Кажется, что все файлы конфигурации и команды в этой проблеме в порядке, проблема, казалось, была конфигурация брандмауэра из предыдущегопроект. Это может быть примером использования этих инструментов, работающих в настоящее время

1 Ответ

0 голосов
/ 29 октября 2019

Пожалуйста, поделитесь выводом curl -v http://domain -name в вопросе.

...