Docker 2024 04/Docker Compose
Docker Compose bietet eine komfortable Möglichkeit Images zu bauen und Container bzw. Container im Serviceverbund zu starten. Die Erstellung von Volumes und Networks wird stark erleichtert. Zudem muss der oft Komplexe docker run Befehl nicht abgelegt werden.
Im folgenden werden einige der zuvor erstellten Beispiele mit Docker Compose nachgebaut.
Der Standard Name für Docker Compose Dateien ist docker-compose.yml. Mit dem Parameter-fkann jedoch direkt eine Docker Compose Datei angegeben werden. Z.b.:docker-compose -f service1.yml
Beispiel 1) Erster Container
Siehe hier
Inhalt docker-compose.yml
services:
#Service name
ubuntu:
#Container name, --name
container_name: ubuntu
#Used image
image: ubuntu:22.04
#Command to run
command: bash
#Parameter -it
stdin_open: true
tty: true
Service detached starten:
docker compose up -d
Mit Service verbinden und schließen
docker attach ubuntu
exit
Der Container ist nun im Exited State docker ps -a. Der Container wird mit folgendem Kommando korrekt gelöscht, bzw. auch gestoppt sofern dieser gestartet ist. Es werden so ebenfalls alle erstellten Netzwerke gelöscht. Wird Docker Compose verwendet so wird nicht Standardmäßig das bridge Netzwerk bridge verwendet.
docker compose down
Beispiel 2) Node Webserver (bestehendes Image, Folder Mount)
Siehe hier
Inhalt docker-compose.yml
services:
#Service name
node_webserver:
#Container name, --name
container_name: node_webserver
#Used image
image: example5:1.0
#Folder/Volume mount -v
volumes:
- ./http:/var/www
ports:
- 8000:5000
Service starten
docker compose up -d
Logs einsehen
docker compose logs [service name optional]
Ressourcen einsehen
docker compose stats [service name optional]
Informationen einsehen
docker compose ps [service name optional]
Webserver testen http://localhost:8000
Service beenden
docker compose down
Beispiel 3) Node Webserver (existing Image, Volume Mount)
Siehe hier
Inhalt docker-compose.yml
services:
#Service name
node_webserver:
#Container name, --name
container_name: node_webserver
#Used image
image: example5:1.0
#Folder/Volume mount -v
volumes:
- www:/var/www
ports:
- 8000:5000
volumes:
www:
Das Volume wird automatisch erstellt und bleibt auch nach docker compose down erhalten.
Beispiel 5) Networking
Inhalt Dockerfile
Siehe hier
Inhalt docker-compose.yml
services:
app:
container_name: app
hostname: app
build:
context: .
image: networking_example2:1.0
networks:
- tier1
- tier2
depends_on:
- database
database:
container_name: database
hostname: database
image: networking_example2:1.0
networks:
- tier2
reverseproxy:
container_name: reverseproxy
hostname: reverseproxy
image: networking_example2:1.0
networks:
- tier1
networks:
tier1:
tier2:
Löschen des bestehenden Images:
docker image example5:1.0
Das starten des Services erstellt automatisch das Image bzw. die Images:
docker compose up -d
Das oder die Images können auch explizit gebaut werden:
docker compose build
Beispiel 4) Node Webserver (building Image)
Inhalt Dockerfile
Siehe hier
Inhalt docker-compose.yml
services:
#Service name
node_webserver:
#Container name, --name
container_name: node_webserver
#Build image
build:
context: .
image: example5:1.0
#Folder/Volume mount -v
volumes:
- www:/var/www
ports:
- 8000:5000
volumes:
www:
Löschen des bestehenden Images:
docker image example5:1.0
Das starten des Services erstellt automatisch das Image bzw. die Images:
docker compose up -d
Das oder die Images können auch explizit gebaut werden:
docker compose build