Настройка Django и Nginx не обслуживает статические файлы - PullRequest
0 голосов
/ 09 марта 2019

Мой Django-Nginx загадочным образом перестал обслуживать статические файлы на моем сайте после перезагрузки. Сайт работает нормально, но мне выдается ошибка «404», когда мой сайт пытается обслуживать CSS-файлы и другой статический контент.

«CoolBlog» - это название проекта, «Blog» - это название приложения.

Дерево каталогов:

site.mywebsite.com
|
├── database
│   └── db.sqlite3
├── source
│   ├── blog
│   ├── CoolBlog
│   ├── functional_tests.py
│   ├── manage.py
│   ├── requirements.txt
│   └── static
├── static
│   ├── admin
│   ├── bootstrap-4.3.1-dist
│   ├── css
│   └── styles.css
└── virtualenv
    ├── bin
    └── lib

Соответствующий раздел из CoolBlog / settings.py:

STATIC_ROOT = os.path.join(BASE_DIR, '../static')
STATIC_URL = '/static/'

Сайты-Доступные / site.mywebsite.com:

server{
    listen 80;
    server_name site.mywebsite.com;

    location /source/static {
        alias /home/elspeth/sites/site.mywebsite.com/static;
        autoindex on;
    }

    location / {
        proxy_pass http://unix:/tmp/site.mywebsite.com.socket;
        proxy_set_header Host $host;
    }
}

Версии программного обеспечения / ОС:

  • Ubuntu 16.04.6 LTS

  • Джанго 2.1.7

  • Nginx / 1.10.3

  • Gunicorn 19

Я бы очень признателен за совет о том, как действовать.

1 Ответ

0 голосов
/ 09 марта 2019
  1. Выполнить ./manage.py collectstatic
  2. Пример конфигурации django + gunicorn + nginx: https://docs.gunicorn.org/en/latest/deploy.html

    server {
        server_name www.site.com;
        client_max_body_size 5M;
        location = /favicon.ico { access_log off; log_not_found off; }
    
        location /static {
            alias /home/caocao/coding/caocao/static;
        }
    
        location /media {
            alias /home/caocao/coding/caocao/media;
        }
    
        location / {
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
            proxy_redirect off;
            proxy_pass http://unix:/home/caocao/coding/caocao/gunicorn.sock;
        }
    
        listen 443 ssl; # managed by Certbot
        ssl_certificate /etc/letsencrypt/live/www.site.com-0001/fullchain.pem; # managed by Certbot
        ssl_certificate_key /etc/letsencrypt/live/www.site.com-0001/privkey.pem; # managed by Certbot
        include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
        ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
    }
    
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...