У меня есть контейнер nginx в AWS, который выполняет обратный прокси-сервер для моего веб-сайта, например, https://example.com. У меня есть серверные службы, которые автоматически регистрируются в локальном DNS - aws.local (это делается с помощью автоматического обнаружения AWS ECS).У меня проблема в том, что nginx разрешает только имя в IP во время запуска, поэтому, когда сервисный контейнер перезагружается и получает новый IP, nginx все еще пытается использовать старый IP, и у меня появляется ошибка «502 Bad Gateway».
Здеськод, который я запускаю:
worker_processes 1;
events { worker_connections 1024; }
http {
sendfile on;
include /etc/nginx/mime.types;
log_format graylog2_json '{ "timestamp": "$time_iso8601", '
'"remote_addr": "$remote_addr", '
'"body_bytes_sent": $body_bytes_sent, '
'"request_time": $request_time, '
'"response_status": $status, '
'"request": "$request", '
'"request_method": "$request_method", '
'"host": "$host",'
'"upstream_cache_status": "$upstream_cache_status",'
'"upstream_addr": "$upstream_addr",'
'"http_x_forwarded_for": "$http_x_forwarded_for",'
'"http_referrer": "$http_referer", '
'"http_user_agent": "$http_user_agent" }';
upstream service1 {
server service1.aws.local:8070;
}
upstream service2 {
server service2.aws.local:8080;
}
resolver 10.0.0.2 valid=10s;
server {
listen 443 http2 ssl;
server_name example.com;
location /main {
proxy_pass http://service1;
}
location /auth {
proxy_pass http://service2;
}
Я нахожу советы по изменению конфигурации nginx для разрешения имен по запросу, но затем я вижу, что мой браузер пытается открыть "service2.aws.local: 8070" и не работает, так какего локальное DNS-имя AWS.Я должен видеть https://example.com/auth" в моем браузере.
server {
set $main service1.aws.local:2000;
set $auth service2.aws.local:8070;
location /main {
proxy_http_version 1.1;
proxy_pass http://$main;
}
location /auth {
proxy_http_version 1.1;
proxy_pass http://$auth;
}
Можете ли вы помочь мне исправить это?Спасибо !!!