Am un API la backend.mysite.local
și îl pot accesa direct din browser.
Dar când încerc să apelez API-ul din containerul Node, primesc 502 Bad Gateway cu următoarea eroare:
connect() a eșuat (113: Gazda este inaccesibilă) în timpul conectării la
în amonte, client: 172.20.0.1, server: www.mysite.local, cerere: „GET
/api/items HTTP/1.1", în amonte:
„http://172.20.0.3:3000/api/items”, gazdă: „www.mysite.local”
Aceasta este configurația mea nginx (sunt nou în nginx, așa că s-ar putea să o fac într-un mod mai scurt, dar este în mare parte blocuri pentru redirecționarea de la portul 80 la portul 443 - așa că aș aprecia dacă o revizuiți de asemenea)
Server {
asculta 443 ssl;
nume_server backend.mysite.local;
certificat_ssl /etc/ssl/mysite.local.crt;
ssl_certificate_key /etc/ssl/mysite.local.key;
index index.php index.html;
nume_server backend.mysite.local;
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
root /var/www/html/public;
Locație / {
try_files $uri $uri/ /index.php?$query_string;
}
locație ~ \.php$ {
try_files $uri = 404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass php:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
setați $METHODS 'GET, POST, OPTIONS, HEAD';
setați $HEADERS 'Autorizare, Origine, X-Solicitat-Cu, Conținut-Tip, Accept';
if ( $request_method = POST ){
add_header „Acces-Control-Allow-Origin” „https://www.mysite.local”;
add_header 'Acces-Control-Allow-Credentials' 'true';
}
}
}
Server {
asculta 80;
nume_server http.backend.mysite.local;
returnează 301 https://backend.mysite.local$request_uri;
}
Server {
asculta 80;
nume_server nginx;
returnează 301 https://backend.mysite.local$request_uri;
}
Server {
asculta 80;
nume_server www.mysite.local;
returnează 301 https://www.mysite.local$request_uri;
}
Server {
asculta 80;
nume_server mysite.local;
returnează 301 https://www.mysite.local$request_uri;
}
Server {
asculta 443 ssl;
nume_server mysite.local;
certificat_ssl /etc/ssl/mysite.local.crt;
ssl_certificate_key /etc/ssl/mysite.local.key;
returnează 301 https://www.mysite.local$request_uri;
}
Server {
asculta 443 ssl;
nume_server www.mysite.local;
certificat_ssl /etc/ssl/mysite.local.crt;
ssl_certificate_key /etc/ssl/mysite.local.key;
Locație / {
proxy_pass http://node:3000;
}
}
Edit: Acesta este docker-compose.yml
:
retele:
site-ul meu:
şofer: pod
Servicii:
nginx:
imagine: nginx:stable-alpine
container_name: nginx
porturi:
- „8088:8088”
- „80:80”
- „443:443”
retele:
- site-ul meu
php:
construi:
context: ./laravel
dockerfile: Dockerfile
nume_container: php
porturi:
- „9000:9000”
retele:
- site-ul meu
nodul:
construi:
context: ./react
dockerfile: Dockerfile
container_name: reacționează
porturi:
- „3000:3000”