У меня есть приложение, разработанное angular в качестве внешнего интерфейса и весенней загрузки для внутреннего интерфейса.
Я развернул их на Nginx
, работающем на Ubuntu
сервере, включая давайте зашифруем ssl-сертификаты
Внешний интерфейс развернут по следующему пути /var/www/my-app-domain.local
Бэкэнд - это jar, который работает на порту 8080
Конфигурация Nginx
находится в следующем файле, расположенном в /etc/nginx/conf.d/my-app-domain.local.conf
server {
listen 80;
listen [::]:80;
server_name my-app-domain;
location /api/ {
proxy_pass http://localhost:8080/;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-Port $server_port;
}
}
server {
server_name my-app-domain www.my-app-domain; # managed by Certbot
index index.html;
root /var/www/my-app-domain.local;
location / {
# try_files $uri $uri/ =404;
try_files $uri $uri/ /index.html;
}
listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/my-app-domain/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/my-app-domain/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
}server {
if ($host = my-app-domain) {
return 301 https://$host$request_uri;
} # managed by Certbot
if ($host = my-app-domain) {
return 301 https://$host$request_uri;
} # managed by Certbot
listen 80 ;
server_name my-app-domain www.my-app-domain;
return 404; # managed by Certbot
}
Когда я вызываю имя домена в браузере, он отклонил вызов API из веб-приложения, показывая эту ошибку в консоли: Не удалось загрузить ресурс: net :: ERR_CONNECTION_REFUSED для вызова http://localhost: 8080 / api / *****
Однако, когда я вызываю тот же API из браузера, он успешно вызывает без каких-либо проблем.
моя конфигурация Ngnix неверна? Что мне делать с этой ошибкой и как правильно вызывать API в производственной среде?