Docker撰写服务通讯
Docker compose service communication
所以我有一个包含 3 个服务的 docker-compose 文件:后端、反应前端和 mongo。
后端 Dockerfile:
FROM ubuntu:latest
WORKDIR /backend-server
COPY ./static/ ./static
COPY ./config.yml ./config.yml
COPY ./builds/backend-server_linux ./backend-server
EXPOSE 8080
CMD ["./backend-server"]
前端 Dockerfile:
FROM nginx:stable
WORKDIR /usr/share/nginx/html
COPY ./build .
COPY ./.env .env
EXPOSE 80
CMD ["sh", "-c", "nginx -g \"daemon off;\""]
所以我想没什么不寻常的。
docker-compose.yml:
version: "3"
services:
mongo-db:
image: mongo:4.2.0-bionic
container_name: mongo-db
volumes:
- mongo-data:/data
network_mode: bridge
backend:
image: backend-linux:latest
container_name: backend
depends_on:
- mongo-db
environment:
- DATABASE_URL=mongodb://mongo-db:27017
..etc
network_mode: bridge
# networks:
# - mynetwork
expose:
- "8080"
ports:
- 8080:8080
links:
- mongo-db:mongo-db
restart: always
frontend:
image: frontend-linux:latest
container_name: frontend
depends_on:
- backend
network_mode: bridge
links:
- backend:backend
ports:
- 80:80
restart: always
volumes:
mongo-data:
driver: local
这是有效的。我的问题是,通过将 ports: - 8080:8080
添加到后端部分,该服务器对主机可用。理论上网络应该在没有这些行的情况下工作,正如我在 docker 文档和 this question 中所读到的那样,但是如果我删除它,API 调用就会停止工作(但是 curl 调用写在前端服务下的 docker-compose 仍然有效。
您的 React 前端正在从浏览器发出请求。
因此,在这种情况下,端点需要浏览器可以访问您的 API,而不是分发静态 js、css 和 html 文件的容器。
希望这张图片有意义。
P.S。如果你想特别不公开 API ,你可以让 Web 服务器将请求代理到 /api/ 到 API 容器,这将发生在网络级别并且意味着你只需要公开一台服务器。
我通过在 Nginx 之外提供我的 Angular 应用程序然后将 /app1/api/* 的流量代理到一个容器并将 /app2/api/* 的流量代理到另一个容器等
所以我有一个包含 3 个服务的 docker-compose 文件:后端、反应前端和 mongo。
后端 Dockerfile:
FROM ubuntu:latest
WORKDIR /backend-server
COPY ./static/ ./static
COPY ./config.yml ./config.yml
COPY ./builds/backend-server_linux ./backend-server
EXPOSE 8080
CMD ["./backend-server"]
前端 Dockerfile:
FROM nginx:stable
WORKDIR /usr/share/nginx/html
COPY ./build .
COPY ./.env .env
EXPOSE 80
CMD ["sh", "-c", "nginx -g \"daemon off;\""]
所以我想没什么不寻常的。
docker-compose.yml:
version: "3"
services:
mongo-db:
image: mongo:4.2.0-bionic
container_name: mongo-db
volumes:
- mongo-data:/data
network_mode: bridge
backend:
image: backend-linux:latest
container_name: backend
depends_on:
- mongo-db
environment:
- DATABASE_URL=mongodb://mongo-db:27017
..etc
network_mode: bridge
# networks:
# - mynetwork
expose:
- "8080"
ports:
- 8080:8080
links:
- mongo-db:mongo-db
restart: always
frontend:
image: frontend-linux:latest
container_name: frontend
depends_on:
- backend
network_mode: bridge
links:
- backend:backend
ports:
- 80:80
restart: always
volumes:
mongo-data:
driver: local
这是有效的。我的问题是,通过将 ports: - 8080:8080
添加到后端部分,该服务器对主机可用。理论上网络应该在没有这些行的情况下工作,正如我在 docker 文档和 this question 中所读到的那样,但是如果我删除它,API 调用就会停止工作(但是 curl 调用写在前端服务下的 docker-compose 仍然有效。
您的 React 前端正在从浏览器发出请求。 因此,在这种情况下,端点需要浏览器可以访问您的 API,而不是分发静态 js、css 和 html 文件的容器。
希望这张图片有意义。
P.S。如果你想特别不公开 API ,你可以让 Web 服务器将请求代理到 /api/ 到 API 容器,这将发生在网络级别并且意味着你只需要公开一台服务器。
我通过在 Nginx 之外提供我的 Angular 应用程序然后将 /app1/api/* 的流量代理到一个容器并将 /app2/api/* 的流量代理到另一个容器等