eg3 finished Backend + Frontend cross communication

master
Jason Zhu 2023-05-05 00:00:15 +10:00
parent 43a2dfefc7
commit 7bdffc22cf
2 changed files with 26 additions and 8 deletions

View File

@ -15,3 +15,21 @@ How to test it:
1. Comment all other containers 1. Comment all other containers
2. Run `docker compose build` & `docker compose up` 2. Run `docker compose build` & `docker compose up`
3. Test by `curl localhost`, should return a html file (as `/eg3/frontend/index.html`) 3. Test by `curl localhost`, should return a html file (as `/eg3/frontend/index.html`)
## Backend + Frontend
In this section, we test frontend container can cross-communicate with backend container.
Steps:
1. Comment out proxy container
2. frontend has port 80 exposed; backend has port 5000 exposed;
3. Run `docker compose build` & `docker compose up`
4. Create a network: `docker network create mynetwork`
5. Add containers into network
1. `docker network connect mynetwork backend`
2. `docker network connect mynetwork frontend`
6. Inspect `mynetwork` has containers `docker network inspect mynetwork`
7. Test network:
1. Enter frontend container: `docker exec -it frontend /bin/sh`
2. Make a request to backend: `curl http://backend:5000`
3. Get response `{"version": "1.0.0"}`

View File

@ -20,10 +20,10 @@ services:
ports: ports:
- "80:80" # Uncomment this line if you want to run the frontend container only - "80:80" # Uncomment this line if you want to run the frontend container only
# backend: backend:
# container_name: backend container_name: backend
# build: build:
# context: ./backend context: ./backend
# dockerfile: Dockerfile dockerfile: Dockerfile
# ports: ports:
# - "5000:5000" # Uncomment this line if you want to run the backend container only - "5000:5000" # Uncomment this line if you want to run the backend container only