에 API가 있고 backend.mysite.local
브라우저에서 직접 액세스할 수 있습니다. 하지만 Node 컨테이너 내에서 API를 호출하려고 하면 다음 오류와 함께 502 Bad Gateway가 표시됩니다.
업스트림에 연결하는 동안 connect()가 실패했습니다(113: 호스트에 연결할 수 없음). 클라이언트: 172.20.0.1, 서버:www.mysite.local, 요청: "GET /api/items HTTP/1.1", 업스트림: "http://172.20.0.3:3000/api/items", 호스트: "www.mysite.local"
이것은 내 nginx 구성입니다. (나는 nginx를 처음 사용하기 때문에 더 짧은 방법으로 할 수도 있지만 대부분 포트 80에서 포트 443으로의 리디렉션을 위한 블록이므로 검토해 주시면 감사하겠습니다.)
server {
listen 443 ssl;
server_name backend.mysite.local;
ssl_certificate /etc/ssl/mysite.local.crt;
ssl_certificate_key /etc/ssl/mysite.local.key;
index index.php index.html;
server_name backend.mysite.local;
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
root /var/www/html/public;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location ~ \.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;
set $METHODS 'GET, POST, OPTIONS, HEAD';
set $HEADERS 'Authorization, Origin, X-Requested-With, Content-Type, Accept';
if ( $request_method = POST ){
add_header 'Access-Control-Allow-Origin' 'https://www.mysite.local';
add_header 'Access-Control-Allow-Credentials' 'true';
}
}
}
server {
listen 80;
server_name http.backend.mysite.local;
return 301 https://backend.mysite.local$request_uri;
}
server {
listen 80;
server_name nginx;
return 301 https://backend.mysite.local$request_uri;
}
server {
listen 80;
server_name www.mysite.local;
return 301 https://www.mysite.local$request_uri;
}
server {
listen 80;
server_name mysite.local;
return 301 https://www.mysite.local$request_uri;
}
server {
listen 443 ssl;
server_name mysite.local;
ssl_certificate /etc/ssl/mysite.local.crt;
ssl_certificate_key /etc/ssl/mysite.local.key;
return 301 https://www.mysite.local$request_uri;
}
server {
listen 443 ssl;
server_name www.mysite.local;
ssl_certificate /etc/ssl/mysite.local.crt;
ssl_certificate_key /etc/ssl/mysite.local.key;
location / {
proxy_pass http://node:3000;
}
}
편집: 이것은 다음과 같습니다 docker-compose.yml
:
networks:
mysite:
driver: bridge
services:
nginx:
image: nginx:stable-alpine
container_name: nginx
ports:
- "8088:8088"
- "80:80"
- "443:443"
networks:
- mysite
php:
build:
context: ./laravel
dockerfile: Dockerfile
container_name: php
ports:
- "9000:9000"
networks:
- mysite
node:
build:
context: ./react
dockerfile: Dockerfile
container_name: react
ports:
- "3000:3000"