Table of Contents
Introduction to Docker Networking
Networking is a crucial aspect of containerized applications, enabling seamless communication between containers, the host system, and external networks. Docker simplifies this with built-in networking modes, making it easy to configure and manage connectivity.
This article dives into Docker’s networking concepts, internal and external container communication, and how to map ports effectively.
Networking Concepts in Docker
- Bridge Network(Default)
- Containers on the same bridge network can communicate with each other using container names or IP addresses.
- External access requires port mapping.
- Ideal for standalone containers.
- Example:
docker network inspect bridge docker run --name app -d -p 8080:80 nginx
- Host Network
- The container shares the host machine’s network stack, eliminating network isolation.
- Faster but lacks security isolation.
- Example:
docker run --network host -d nginx
- None Network
- The container has no network access and operates in complete isolation.
- Useful for security-focused applications.
- Example:
docker run --network none nginx
- Custom Networks
- User-defined networks allow more control, such as specifying subnets, DNS, and IPs.
- Enable container communication using names without explicit links.
- Example:
docker network create my-network docker run --network my-network --name app1 -d nginx docker run --network my-network --name app2 -d busybox
How Containers Communicate
- Internal Communication
- Containers on the same network can resolve each other by their names.
- For example, two containers on a custom network can communicate using hostnames.
- External Communication
- Port mapping connects containers to external systems.
- Use the
-p
flag to map container ports to the host:
docker run -d -p 8080:80 nginx
- Access the containerized service via
http://localhost:8080
.
Port Mapping and Linking Containers
- Port Mapping
- Expose container ports to the host to make services accessible externally.
- Syntax:
-p <host_port>:<container_port>
.
- Linking Containers(Deprecated)
- Use custom networks instead of linking. However, for legacy applications, linking allows containers to communicate without explicitly being on the same network.
- Example:
docker run --name db -d mysql docker run --link db:db -d app
Conclusion
Docker networking provides powerful and flexible tools to connect containers and enable communication both internally and externally. By understanding Docker’s networking modes and mastering port mapping, you can design efficient and secure architectures for your containerized applications.