There are types of docker networks available now, but for standalone applications mostly “host” and “bridge” networks are used, which are “single-host networks“, means their effect is local to the individual host. Today, we are going to take a look at the difference both of them, host network V/s bridge network.
Note: Before proceeding further, make a note that this “host” network driver is only available to “Linux” as of now.
To learn more about docker networking, follow -> Learn Docker Networking
The main difference between both of them is:
- In the case of “host“, a container can directly use the host’s networking, for example in case of “Linux” the docker container can directly use the “eth0” for sending and receiving packets.
- In the case of “bridge“, there is a need for “port mapping“.
We are going to learn about this key difference by an example, depicted in the below photos, do follow along with this post carefully.
But, before going for the differences, we should learn about both of them:
To learn about bridge, follow -> Docker Bridge Network Driver
To learn about host, follow the post.
Learn the docker “host” network driver
Firstly, we are going to create an nginx container using the “host” network in docker.
Check the default available networks using the command below, we have to focus on the highlighted one.
$ docker network ls
data:image/s3,"s3://crabby-images/d76bb/d76bb1c00d54c44e1b2bb965b3003d0876570bf8" alt="Check currently available networks"
Now, inspect the default configuration of host network driver, because later it is going to be modified by the docker.
$ docker network inspect host
data:image/s3,"s3://crabby-images/b886b/b886b6fe23dbeb452851e93f06d09d11f2039a1c" alt="Check and inspect the default configuration of host network"
Now, create a Docker container named as “my-nginx” using the “– – network host” from the “nginx:alpine” image.
$ docker container run -d --network host --name m-nginx nginx:alpine
data:image/s3,"s3://crabby-images/0161a/0161a9f69fac3c8a98a7948a407b11659450befa" alt="Create an nginx container using the host network without specifying the port mapping"
Note: Here we are running an “nginx” container without specifying the “port mapping“.
Question: Why we are not using the “port mapping” with “host” network driver?
Answer: Because the “host” network driver is directly going to use the “eth0“, on Linux systems.
Now, after creating an “my-nginx” container without “port mapping” using the “host” network driver. Let us check whether our “nginx server” inside the “my-nginx” container is running correctly or not. Go to a browser and in the URL bar type the IP-Address of your docker host, as we did in the screenshot below.
data:image/s3,"s3://crabby-images/0102b/0102bdf09e687ac6d9a951634fc2bbe732d5d707" alt="The nginx server inside the container is running correctly"
data:image/s3,"s3://crabby-images/ea5d5/ea5d57a09716278d74b02b7c8a6cffcbb38130a3" alt="We can confirm that the nginx container is not using the port mapping"
data:image/s3,"s3://crabby-images/7ad9e/7ad9e20e1be2c3d98c93b22055751b389588dce7" alt="Diagram for host network"
From the picture above, it can be seen that “no port mapping” is done and still our “my-nginx” is running perfectly.
Note: This is the power of “host” network driver.
Check and inspect the default “host” network driver configuration using the following command:
$ docker network inspect host
data:image/s3,"s3://crabby-images/4941e/4941ecfb4e5322398fadcb0a3f8b701327e59963" alt="Again check and inspect the configuration of host network driver"
From the output of the command above, few points need to be noted:
- Scope = local <- the effect of this network is only to its docker host
- Driver = host <- the “host network driver” is being used
- Containers = {my-nginx} <- this confirms that our created container is attached to this network
Now that we have a little knowledge about both of them, proceed for the difference.
Host network V/s Bridge network
In order to understand this, we are going to create an “nginx” container named “my-nginx-bridge” using the “nginx:alpine” image, use the command below:
$ docker container run -d --network bridge --name my-nginx-bridge nginx:alpine
Note: We have specified the “– – network bridge“, so that it will use bridge network.
data:image/s3,"s3://crabby-images/1f0b9/1f0b9fe0750462a8d813aead01c1601239bf4e1f" alt="Create a new container using default bridge network"
The Difference
In the case of “bridge” network driver, it is showing a port opened, which was not the case with the “host” network driver, when we create the “my-nginx” container in the post’s earlier section.
data:image/s3,"s3://crabby-images/9ccf3/9ccf3b5cfb935f34ace6a49bf51f80eec745150d" alt="Nginx container created using default docker0 opens up port tcp 80"
So, because we have not specified any “port mapping“, the “nginx server” inside the “my-nginx-bridge” is running, but can not be accessed from the outside world, as shown below
data:image/s3,"s3://crabby-images/fd42e/fd42e9493145a5f60c107a85bd94d95bffc95fcd" alt="Nginx server inside the container is running perfectly but no port mapping results in error"
Stop and Remove the “my-nginx-bridge” container.
$ docker container stop my-nginx-bridge
$ docker container rm my-nginx-bridge
data:image/s3,"s3://crabby-images/807b4/807b47d8bea10e6f1f0efebabab4cfaca2d76eee" alt="Stop and remove the my-nginx-bridge container"
Now, that we have removed the “my-nginx-bridge” container, recreate it using the “port mapping“.
$ docker container run -d --network bridge --name my-nginx-bridge -p 80:80 nginx:alpine
Note: We have specified the “port mapping” using the “-p 80:80” option.
data:image/s3,"s3://crabby-images/e8a6c/e8a6c3459c48b0304e1f10d8c62c346cb11db213" alt="Recreate the my-nginx-bridge container"
As a result, we can now see that a “port mapping” is now available to the “my-nginx-bridge” container.
$ docker container ls
data:image/s3,"s3://crabby-images/45349/453492f0ce4b056191d02c706afbeb9c4d6dad71" alt="Port mapping is required for nginx container when used with bridge network"
data:image/s3,"s3://crabby-images/42831/42831aaaec91ea9a629eb4f69d8ca8e6198c6346" alt="Diagram for bridge network"
Again, go to the browser and type the IP-Address of your docker host in the URL bar, from the picture below we can confirm that now “nginx server” inside the “my-nginx-bridge” container is working correctly and can be accessible from the outside world because of “port mapping” we have used.
data:image/s3,"s3://crabby-images/5bd3d/5bd3d3ecec30579c20951dfb1c22050adbf2e851" alt="Nginx server inside my-nginx-bridge is working perfectly with port mapping"
Check and inspect eh “bridge” network driver, using the command below. From the output, we can confirm that the “my-nginx-bridge” is connected or attached to the “bridge” network.
$ docker network inspect bridge | grep -A 7 Containers
data:image/s3,"s3://crabby-images/db55d/db55d25f375c4007508239fbe99a58eefe9aed8e" alt="Check the configuration of docker0 bridge network"
Now, it is time to clean out docker host, stop an remove the “my-nginx-bridge” container.
$ docker container stop my-nginx-container
$ docker container rm my-nginx-bridge
data:image/s3,"s3://crabby-images/1514a/1514a7ed24de42fb1e3db99279a8dfdfb3febe1e" alt="Stop and remove the my-nginx-bridge container"
Conclusion
- No “Port Mapping” is required when the docker “host” network driver will be used.
- “Port Mapping” is required when the docker “bridge” network driver will be used.
Comment here