Рейтинг:1

nginx по умолчанию использует /usr/share/nginx/html вместо перехода в папку, указанную в корне

флаг in

Я использую letsencrypt, чтобы настроить ssl для проекта django, который размещен в производственном режиме с использованием nginx и gunicorn.

Используемая ОС (операционная система): amazon Linux 2

Всякий раз, когда я пытаюсь запустить сервер, я продолжаю получать страницу по умолчанию amazon Linux 2, и когда я проверяю журналы ошибок, я получаю следующую ошибку:

11.09.2021, 11:59:14 [ошибка] 18402#18402: *1961 open() "/usr/share/nginx/html/favicon.ico" не удалось (2: нет такого файла или каталога), клиент: 122.174 .182.129, сервер: example.com, запрос: "GET /favicon.ico HTTP/2.0", хост: "www.example.com", реферер: "https://www.example.com/"

Вывод судо nginx-T:

nginx: синтаксис файла конфигурации /etc/nginx/nginx.conf в порядке
nginx: проверка файла конфигурации /etc/nginx/nginx.conf прошла успешно
# файл конфигурации /etc/nginx/nginx.conf:
# Для получения дополнительной информации о настройке см.:
# * Официальная документация на английском языке: http://nginx.org/en/docs/
# * Официальная русскоязычная документация: http://nginx.org/ru/docs/

пользователь nginx;
рабочие_процессы авто;
журнал_ошибок /var/log/nginx/error.log;
pid /run/nginx.pid;

# Загрузить динамические модули. См. /usr/share/doc/nginx/README.dynamic.
включить /usr/share/nginx/modules/*.conf;

События {
    worker_connections 1024;
}
http {
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                      '$статус $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    журнал_доступа /var/log/nginx/access.log основной;

    отправить файл включен;
    tcp_nopush включен;
    tcp_nodelay включен;
    keepalive_timeout 65;
    типы_хэш_макс_размер 4096;

    включить /etc/nginx/mime.types;
    default_type application/octet-stream;

    # Загрузите файлы модульной конфигурации из каталога /etc/nginx/conf.d.
    # См. http://nginx.org/en/docs/ngx_core_module.html#include
    # для дополнительной информации.
    включить /etc/nginx/conf.d/*.conf;
    сервер {

    #if ($host = www.example.com) {
    # вернуть 301 https://$host$request_uri;
    #} # управляется Certbot
   #
   # если ($host = example.com) {
   # вернуть 301 https://$host$request_uri;
   # } # под управлением Certbot


    слушать 80;
    имя_сервера example.com www.example.com;
    корень /home/ec2-пользователь/бизнес;
    если ($host = www.example.com) {
        вернуть 301 https://$host$request_uri;
    } # управляется Certbot

    если ($host = example.com) {
        вернуть 301 https://$host$request_uri;
    } # управляется Certbot
    location = /favicon.ico { access_log off; log_not_found выключен; }

    местоположение/статический {
        корень /home/ec2-пользователь/бизнес;
    }

    место расположения / {
        proxy_set_header Хост $http_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 $ схема;
        proxy_pass http://unix:/home/ec2-user/buisness/buisness.sock;
    }

}

  # сервер {
   # слушать 80;
    # слушать [::]:80;
     #   имя сервера  _;
     # root /home/ec2-user/business;

        # Загрузить файлы конфигурации для блока сервера по умолчанию.
# include /etc/nginx/default.d/*.conf;
 # error_page 404 /404.html;
  # местоположение = /404.html {
   # }

    # error_page 500 502 503 504 /50x.html;
     # местоположение = /50x.html {
      # }
    #}

# Настройки для сервера с поддержкой TLS.

    сервер {
        слушать 443 ssl http2;
        слушать [::]:443 ssl http2;
        имя_сервера example.com www.example.com;
        корень /home/ec2-пользователь/бизнес/;


        ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; # под управлением Certbot
        ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; # под управлением Certbot
        ssl_session_cache общий: SSL: 1 м;
        ssl_session_timeout 10 м;
        ssl_ciphers HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers включен;

        # Загрузить файлы конфигурации для блока сервера по умолчанию.
        включить /etc/nginx/default.d/*.conf;
        страница_ошибки 404 /404.html;
            местоположение = /40x.html {
        }

       error_page 500 502 503 504 /50x.html;
            местоположение = /50x.html {
        }
}

}


# файл конфигурации /etc/nginx/mime.types:

типы {
    текст/html html htm shtml;
    текст/CSS CSS;
    текст/xml xml;
    изображение/gif gif;
    изображение/jpeg jpeg jpg;
    приложение/javascript js;
    приложение/атом+xml атом;
    приложение/rss+xml rss;

    текст/математика ммл;
    текст/простой текст;
    текст/vnd.sun.j2me.app-дескриптор jad;
    текст/vnd.wap.wml wml;
    текст/x-компонент htc;

    изображение/png png;
    изображение/svg+xml svg svgz;
    изображение/tiff tif tiff;
    изображение/vnd.wap.wbmp wbmp;
    изображение/веб-сайт;
    изображение/значок x ico;
    изображение/x-jng jng;
    изображение/x-ms-bmp bmp;

    шрифт/woff woff;
    шрифт/woff2 woff2;

    приложение/java-архив jar war ear;
    приложение/json json;
    приложение/mac-binhex40 hqx;
    документ приложения/msword;
    заявка/pdf pdf;
    приложение/постскриптум ps eps ai;
    приложение/rtf rtf;
    приложение /vnd.apple.mpegurl m3u8;
    application/vnd.google-earth.kml+xml кмл;
    application/vnd.google-earth.kmz кмз;
    приложение/vnd.ms-excel xls;
    приложение /vnd.ms-fontobject eot;
    приложение /vnd.ms-powerpoint ppt;
    приложение/vnd.oasis.opendocument.graphics odg;
    application/vnd.oasis.opendocument.presentation odp;
    application/vnd.oasis.opendocument.spreadsheet ods;
    приложение/vnd.oasis.opendocument.text odt;
    приложение/vnd.openxmlformats-officedocument.presentationml.presentation
                                                     пткс;
    приложение/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                                                     xlsx;
    приложение/vnd.openxmlformats-officedocument.wordprocessingml.document
                                                     документ;
    приложение /vnd.wap.wmlc wmlc;
    приложение /x-7z-сжатый 7z;
    приложение /x-cocoa cco;
    приложение/x-java-архив-diff jardiff;
    приложение/x-java-jnlp-файл jnlp;
    запуск приложения /x-makeself;
    приложение/x-perl pl pm;
    приложение/x-pilot prc pdb;
    приложение /x-rar-сжатый rar;
    application/x-redhat-package-manager об/мин;
    приложение /х-море море;
    приложение /x-shockwave-flash swf;
    приложение /x-stuffit сидеть;
    приложение/x-tcl tcl tk;
    application/x-x509-ca-cert der pem crt;
    приложение /x-xpinstall xpi;
    приложение/xhtml+xml xhtml;
    приложение/xspf+xml xspf;
    приложение/zip-архив;

    приложение/октет-поток bin exe dll;
    приложение/октетный поток deb;
    приложение/октет-поток dmg;
    приложение/октетный поток iso img;
    приложение/октет-поток msi msp msm;

    аудио/миди мид миди кар;
    аудио/мпег мп3;
    аудио/огг огг;
    аудио/x-m4a m4a;
    аудио/x-realaudio ra;

    видео/3gpp 3gpp 3gp;
    видео/mp2t ц;
    видео/mp4 mp4;
    видео/mpeg mpeg mpeg mpg;
    видео/быстрое перемещение;
    видео/вебм вебм;
    видео/x-flv flv;
    видео/x-m4v m4v;
    видео/x-мнг мнг;
    видео/x-ms-asf asx asf;
    видео/x-ms-wmv wmv;
    видео/x-msvideo avi;
}

Когда я бегу судо nginx-t : я не получаю ошибок

PS: это мой первый хостинг ssl с letsencrypt и nginx, поэтому мне не жаль, если файл .conf выглядит очень кластеризованным.

Любая помощь будет высоко оценена, спасибо!

флаг cn
Комментарии не для расширенного обсуждения; этот разговор был [перемещен в чат] (https://chat.stackexchange.com/rooms/129529/discussion-on-question-by-madhav-nginx-defaulting-to-usr-share-nginx-html-inste) .
Рейтинг:0
флаг in

Хорошо, я решил это

КОРОТКИЙ ОТВЕТ: Вам необходимо добавить правила, включенные в серверный блок 80, в серверный блок 443.

ДЛИННЫЙ ОТВЕТ: Мой файл nginx.conf:

# Для получения дополнительной информации о настройке см.:
# * Официальная документация на английском языке: http://nginx.org/en/docs/
# * Официальная русскоязычная документация: http://nginx.org/ru/docs/

пользователь nginx;
рабочие_процессы авто;
журнал_ошибок /var/log/nginx/error.log;
pid /run/nginx.pid;

# Загрузить динамические модули. См. /usr/share/doc/nginx/README.dynamic.
включить /usr/share/nginx/modules/*.conf;

События {
    worker_connections 1024;
}
http {
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                      '$статус $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    журнал_доступа /var/log/nginx/access.log основной;

    отправить файл включен;
    tcp_nopush включен;
    tcp_nodelay включен;
    keepalive_timeout 65;
    типы_хэш_макс_размер 4096;

    включить /etc/nginx/mime.types;
    default_type application/octet-stream;

    # Загрузите файлы модульной конфигурации из каталога /etc/nginx/conf.d.
    # См. http://nginx.org/en/docs/ngx_core_module.html#include
    # для дополнительной информации.
    включить /etc/nginx/conf.d/*.conf;
    сервер {

    слушать 80;
    имя_сервера example.com www.example.com;
    корень /home/ec2-пользователь/бизнес;
    если ($host = www.example.com) {
        вернуть 301 https://$server_name$request_uri;
    } # управляется Certbot

    если ($host = example.com) {
        вернуть 301 https://$server_name$request_uri;
    } # управляется Certbot
    location = /favicon.ico { access_log off; log_not_found выключен; }

    местоположение/статический {
        корень /home/ec2-пользователь/бизнес;
    }


    место расположения / {
        proxy_set_header Хост $http_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 $ схема;
        proxy_pass http://unix:/home/ec2-user/buisness/buisness.sock;
    }

}



# Настройки для сервера с поддержкой TLS.

    сервер {
        слушать 443 ssl http2;
        слушать [::]:443 ssl http2;
        имя_сервера www.example.com example.com;


        ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; # под управлением Certbot
        ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; # под управлением Certbot
        ssl_session_cache общий: SSL: 1 м;
        ssl_session_timeout 10 м;
        ssl_ciphers HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers включен;

        # Загрузить файлы конфигурации для блока сервера по умолчанию.
        #include /etc/nginx/default.d/*.conf;
        включить /etc/nginx/conf.d/*.conf;
       # include /home/ec2-user/business/Main;

    location = /favicon.ico { access_log off; log_not_found выключен; }

    местоположение/статический {
        корень /home/ec2-пользователь/бизнес;
    }

    место расположения / {
        proxy_set_header Хост $http_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 $ схема;
        proxy_pass http://unix:/home/ec2-user/buisness/buisness.sock;
    }
}
}

Правила упоминаются:

location = /favicon.ico { access_log off; log_not_found выключен; }

    местоположение/статический {
        корень /home/ec2-пользователь/бизнес;
    }


    место расположения / {
        proxy_set_header Хост $http_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 $ схема;
        proxy_pass http://unix:/home/ec2-user/buisness/buisness.sock;
    }

После изменения вашего .conf файла выполните следующие действия:

  1. судо nginx-t : Это вернет подтверждение о наличии синтаксических ошибок в вашем файле.

  2. sudo systemctl перезапустить nginx : это обновит ваш nginx

Пара предупреждений для будущих читателей:

  1. Проверьте, действительно ли существует ваш корневой путь
  2. Измените свой прокси-пасс в зависимости от того, где вы .носок файл найден

Спасибо Бобби(боббилиеву) из Digital Ocean - Он помог мне решить проблему

Также проверьте чат, связанный с модом в комментариях, чтобы узнать об улучшениях, предложенных модом. Никита, и спасибо Майкл Хэмптон тоже.

Ссылка на вопрос, заданный в цифровом океане: Вопрос

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.