Настройка nginx в качестве прокси-сервера для kestrel (ASP.Net ядро)

Я пытаюсь настроить ASP.NET основная среда для размещения моего приложения, но у меня возникли проблемы с веб-сервером nginx. Когда я пытаюсь подключиться к домену я 502 Bad Gateway. Nginx должен просто работать как прокси-сервер для kestrel.

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

строка, которая является проблема http://aspdotnethost; в конце nginx.конфигурации. Когда я комментирую его, я перенаправляюсь в местоположение www по умолчанию.

Итак, как же на самом деле работает линия и как я могу ее правильно перенаправить на localhost:5000 ?

/и т. д./nginx/прокси.conf

proxy_redirect          off;
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;
client_max_body_size    10m;
client_body_buffer_size 128k;
proxy_connect_timeout   90;
proxy_send_timeout      90;
proxy_read_timeout      90;
proxy_buffers           32 4k;

/и т. д./nginx/nginx в.conf

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

http {
    include    /etc/nginx/proxy.conf;
    limit_req_zone $binary_remote_addr zone=one:10m rate=5r/s;
    server_tokens off;

    sendfile on;
    keepalive_timeout 29; # Adjust to the lowest possible value that makes sense for your use case.
    client_body_timeout 10; client_header_timeout 10; send_timeout 10;

    upstream aspdotnethost {
        server localhost:5000;
    }

    server {
        listen *:80;
        add_header Strict-Transport-Security max-age=15768000;
        return 301 https://$host$request_uri;
    }

    server {
        listen *:443    ssl;
        server_name     example.com *.example.com;

        #Redirects all traffic
        location / {
            proxy_pass  http://aspdotnethost;
            limit_req   zone=one burst=10;
        }
    }

}

проверка конфигурации Nginx:

[root@rs-zap353479-1 patrick]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

когда я набираю curl http://localhost:5000 затем я получаю html-документ возвращается. Так чтобы компонент должен быть найти в моих глазах.

14
задан Patrick Spiegel
21.03.2023 23:34 Количество просмотров материала 3131
Распечатать страницу

1 ответ

как и Евгений Рик, опубликованный в комментарии, я должен был добавить псевдоним к /etc/hosts.

в качестве дополнительного шага я должен указать proxy_temp_path на proxy.conf, создайте этот путь и chown его пользователю, который nginx работает под (в моем случае nginx).

0
отвечен Patrick Spiegel 2023-03-23 07:22

Постоянная ссылка на данную страницу: [ Скопировать ссылку | Сгенерировать QR-код ]

Ваш ответ

Опубликуйте как Гость или авторизуйтесь

Имя
Вверх