DevToolBoxKOSTENLOS
Blog

Docker Networking Guide: Bridge, Host, Overlay Netzwerke

14 Min.von DevToolBox

Docker-Netzwerke sind einer der kritischsten Aspekte der containerisierten Anwendungsarchitektur. Das Verständnis der Container-Kommunikation ist für zuverlässige, sichere und skalierbare Anwendungen unerlässlich.

Docker Netzwerk-Übersicht

Docker erstellt isolierte Netzwerkumgebungen für Container.

# List all Docker networks
$ docker network ls

NETWORK ID     NAME      DRIVER    SCOPE
a1b2c3d4e5f6   bridge    bridge    local
f6e5d4c3b2a1   host      host      local
1a2b3c4d5e6f   none      null      local

Docker Netzwerktypen

Bridge-Netzwerk (Standard)

Das Bridge-Netzwerk ist der Standard-Netzwerktreiber für Container.

# Create a user-defined bridge network
$ docker network create my-app-network

# Run containers on the custom network
$ docker run -d --name web --network my-app-network nginx:alpine
$ docker run -d --name api --network my-app-network node:20-alpine

# Containers can now reach each other by name
$ docker exec web ping api
PING api (172.18.0.3): 56 data bytes
64 bytes from 172.18.0.3: seq=0 ttl=64 time=0.089 ms

# User-defined bridge vs default bridge
# Default bridge: containers communicate only via IP addresses
# User-defined bridge: automatic DNS resolution by container name

# Create bridge with custom subnet
$ docker network create \
  --driver bridge \
  --subnet 172.20.0.0/16 \
  --gateway 172.20.0.1 \
  custom-bridge

Host-Netzwerk

Der Host-Netzwerkmodus entfernt die Netzwerkisolation zwischen Container und Host.

# Run container with host networking
$ docker run -d --network host nginx:alpine

# No port mapping needed — container uses host ports directly
# The nginx server is accessible at localhost:80

# Check: container shares host's network interfaces
$ docker exec <container-id> ip addr
# Shows the same interfaces as the host machine

# Warning: Only one container can bind to a given host port
# Host networking is only supported on Linux (not macOS/Windows)

Overlay-Netzwerk

Overlay-Netzwerke verbinden mehrere Docker-Daemons.

# Initialize Docker Swarm (required for overlay networks)
$ docker swarm init

# Create an overlay network
$ docker network create \
  --driver overlay \
  --attachable \
  my-overlay-network

# Create a service on the overlay network
$ docker service create \
  --name web \
  --network my-overlay-network \
  --replicas 3 \
  nginx:alpine

# Create encrypted overlay network for sensitive data
$ docker network create \
  --driver overlay \
  --opt encrypted \
  secure-overlay

Macvlan-Netzwerk

Macvlan ermöglicht die Zuweisung einer MAC-Adresse an Container.

# Create a Macvlan network
$ docker network create \
  --driver macvlan \
  --subnet 192.168.1.0/24 \
  --gateway 192.168.1.1 \
  -o parent=eth0 \
  my-macvlan

# Run container with its own IP on the LAN
$ docker run -d \
  --network my-macvlan \
  --ip 192.168.1.100 \
  --name legacy-app \
  my-app:latest

# The container appears as 192.168.1.100 on the physical network

None-Netzwerk

None deaktiviert alle Netzwerkfunktionen.

# Run container with no networking
$ docker run -d --network none alpine sleep 3600

# Only loopback interface is available
$ docker exec <container-id> ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536
    inet 127.0.0.1/8 scope host lo

Docker Compose Netzwerke

Docker Compose richtet standardmäßig ein Netzwerk ein.

# docker-compose.yml — Default networking
# All services share a network named <project>_default
services:
  web:
    image: nginx:alpine
    ports:
      - "80:80"
  api:
    image: node:20-alpine
    # Can reach web service at http://web:80
    # Can reach db service at postgres://db:5432
  db:
    image: postgres:16
    environment:
      POSTGRES_PASSWORD: secret

Benutzerdefinierte Netzwerke in Compose

# docker-compose.yml — Custom networks for isolation
services:
  nginx:
    image: nginx:alpine
    ports:
      - "80:80"
      - "443:443"
    networks:
      - frontend

  api:
    build: ./api
    networks:
      - frontend
      - backend
    depends_on:
      - db
      - redis

  db:
    image: postgres:16
    volumes:
      - pg-data:/var/lib/postgresql/data
    networks:
      - backend

  redis:
    image: redis:7-alpine
    networks:
      - backend

  admin:
    image: adminer
    ports:
      - "8080:8080"
    networks:
      - backend

networks:
  frontend:
    driver: bridge
  backend:
    driver: bridge
    internal: true  # No external access

volumes:
  pg-data:

Netzwerkisolationsmuster

Verwenden Sie mehrere Netzwerke zur Service-Isolation.

# Three-tier architecture with network isolation
#
#  Internet
#     |
#  [nginx]     <-- frontend network
#     |
#   [api]      <-- frontend + backend network
#     |
#   [db]       <-- backend network (internal)
#
# nginx can reach api, but NOT db
# api can reach both nginx and db
# db is completely isolated from external access

DNS und Service Discovery

Docker bietet eingebaute DNS-Auflösung.

DNS-Auflösungsregeln

# DNS resolution in user-defined networks
# 1. Container name → IP address
$ docker exec web nslookup api
Server:    127.0.0.11
Address:   127.0.0.11#53
Name:      api
Address:   172.18.0.3

# 2. Service name in Compose → all container IPs (round-robin)
$ docker exec web nslookup api
# Returns IPs of all 'api' service replicas

# 3. Network aliases
$ docker run -d \
  --network my-network \
  --network-alias database \
  --network-alias db \
  --name postgres-primary \
  postgres:16

# Container is reachable as: postgres-primary, database, or db

# 4. Check DNS configuration inside a container
$ docker exec web cat /etc/resolv.conf
nameserver 127.0.0.11
options ndots:0

Container netzwerkübergreifend verbinden

Container können mit mehreren Netzwerken verbunden werden.

# Connect a running container to an additional network
$ docker network connect backend api-container

# Connect with a specific IP address
$ docker network connect --ip 172.20.0.10 backend api-container

# Disconnect from a network
$ docker network disconnect frontend api-container

# A container connected to multiple networks can route between them
# This is useful for "gateway" containers

Netzwerke inspizieren

Docker bietet Befehle zur Netzwerkinspektion.

# List all networks
$ docker network ls

# Inspect a network (shows connected containers, config)
$ docker network inspect my-app-network

# Find which networks a container is connected to
$ docker inspect --format='{{json .NetworkSettings.Networks}}' my-container

# Check container IP address
$ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' my-container

# Check port mappings
$ docker port my-container

# Test connectivity between containers
$ docker exec web ping -c 3 api
$ docker exec web wget -qO- http://api:3000/health

# Debug with a temporary network tools container
$ docker run --rm -it --network my-app-network \
  nicolaka/netshoot bash

Docker Netzwerk-Fehlerbehebung

Container können nicht kommunizieren

Überprüfen Sie das gemeinsame Netzwerk.

# Check if containers are on the same network
$ docker network inspect bridge --format='{{range .Containers}}{{.Name}} {{end}}'

# Solution: Use a user-defined network
$ docker network create app-net
$ docker run -d --name web --network app-net nginx
$ docker run -d --name api --network app-net node:20-alpine

# Now name resolution works
$ docker exec web ping api  # Works!

Port-Konflikte

Prüfen Sie auf Portkonflikte.

# Error: port is already allocated
# Find what is using the port
$ lsof -i :8080
$ ss -tlnp | grep 8080

# Solution 1: Map to a different host port
$ docker run -d -p 8081:80 nginx

# Solution 2: Stop the conflicting service
$ sudo systemctl stop apache2

DNS-Auflösungsfehler

Benutzerdefinierte DNS-Server angeben.

# Specify custom DNS servers
$ docker run -d --dns 8.8.8.8 --dns 8.8.4.4 my-app

# Or in docker-compose.yml
services:
  web:
    image: nginx
    dns:
      - 8.8.8.8
      - 8.8.4.4

Netzwerk-Performance

Host-Netzwerk für performance-kritische Dienste erwägen.

# Check MTU settings
$ docker network inspect bridge | grep -i mtu

# Set custom MTU for a network
$ docker network create --opt com.docker.network.driver.mtu=1400 my-network

# Use host networking for maximum performance
$ docker run --network host my-performance-app

Netzwerk-Sicherheit Best Practices

Folgen Sie diesen Best Practices:

  • Benutzerdefinierte Bridge-Netzwerke verwenden.
  • Interne Netzwerke nutzen.
  • Nur nötige Ports veröffentlichen.
  • Verschlüsselte Overlay-Netzwerke.
  • Netzwerkrichtlinien implementieren.
  • Regelmäßig Konfigurationen prüfen.
# Bind to localhost only (not accessible from outside)
$ docker run -d -p 127.0.0.1:5432:5432 postgres:16

# Create internal network (no outbound internet)
$ docker network create --internal isolated-net

# In docker-compose.yml
networks:
  database:
    internal: true  # Containers cannot reach the internet

Erweiterte Themen

Benutzerdefinierte IPAM-Konfiguration

IP-Adressverwaltung konfigurieren.

# Custom IPAM configuration
$ docker network create \
  --driver bridge \
  --subnet 10.10.0.0/16 \
  --ip-range 10.10.1.0/24 \
  --gateway 10.10.0.1 \
  --aux-address "dns=10.10.0.2" \
  custom-ipam-net

# In docker-compose.yml
networks:
  app-net:
    driver: bridge
    ipam:
      config:
        - subnet: 172.28.0.0/16
          ip_range: 172.28.5.0/24
          gateway: 172.28.0.1

IPv6-Unterstützung

Docker unterstützt IPv6.

# Enable IPv6 in Docker daemon (/etc/docker/daemon.json)
{
  "ipv6": true,
  "fixed-cidr-v6": "2001:db8:1::/64"
}

# Create a dual-stack network
$ docker network create \
  --ipv6 \
  --subnet 172.20.0.0/16 \
  --subnet 2001:db8:2::/64 \
  dual-stack-net

Integriertes Load Balancing

Docker Swarm bietet integriertes Load Balancing.

# Docker Swarm built-in load balancing
$ docker service create \
  --name web \
  --replicas 5 \
  --publish published=80,target=80 \
  --network my-overlay \
  nginx:alpine

# Requests to port 80 on ANY swarm node
# are load-balanced across all 5 replicas
# using ingress routing mesh

# Scale the service
$ docker service scale web=10

Netzwerktreiber-Vergleich

TreiberAnwendungsfallIsolationPerformanceMulti-Host
BridgeSingle-host containersHighGoodNo
HostPerformance-critical appsNoneBestNo
OverlayMulti-host / SwarmHighGoodYes
MacvlanLegacy / physical networkHighGoodNo
NoneMaximum isolationCompleteN/ANo

Fazit

Docker-Netzwerke sind eine grundlegende Fähigkeit. Meistern Sie diese Konzepte für robuste containerisierte Anwendungen.

FAQ

Was ist der Unterschied zwischen Bridge und Host?

Bridge erstellt einen isolierten Netzwerk-Namespace. Host teilt den Host-Netzwerkstack direkt.

Wann Overlay-Netzwerke verwenden?

Wenn Container auf verschiedenen Hosts kommunizieren müssen.

Können Container verschiedener Netzwerke kommunizieren?

Standardmäßig nicht. Verwenden Sie docker network connect.

Wie Docker-DNS-Probleme debuggen?

Stellen Sie sicher, dass Container auf benutzerdefinierten Netzwerken sind.

𝕏 Twitterin LinkedIn
War das hilfreich?

Bleiben Sie informiert

Wöchentliche Dev-Tipps und neue Tools.

Kein Spam. Jederzeit abbestellbar.

Verwandte Tools ausprobieren

{ }JSON Formatter

Verwandte Artikel

Docker Compose Tutorial: Von den Grundlagen zum produktionsreifen Stack

Vollstaendiges Docker Compose Tutorial: docker-compose.yml Syntax, Services, Netzwerke, Volumes, Umgebungsvariablen, Healthchecks und Praxisbeispiele.

Docker Best Practices: 20 Tipps für Produktionscontainer

20 wesentliche Docker-Best-Practices: Multi-Stage-Builds, Sicherheitshärtung, Image-Optimierung und CI/CD-Automatisierung.

Docker vs Kubernetes

Docker und Kubernetes im Vergleich.