top of page
Writer's pictureSiddhesh Kadam

Docker Networking

In this tutorial we are going to understand Docker Networking Concept.

This is must to know to perform basic administration of networking such as connect/disconnect container to the network,list available networks, remove network etc...


Docker has default command line option to do networking operations.


To list all available network, run :

[root@siddhesh ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
005a608caf51        bridge              bridge              local
49c341ee02f5        host                host                local
6adeb6986dd0        none                null                local
[root@siddhesh ~]#

Lets try to understand different type of network driver available in docker :


1. Bridge : This is default network driver gets created and assigned to the container when you start your container. A bridge network is a Link Layer device which forwards traffic between network segments.


2. Host : It remove network isolation between the container and the Docker host, and use the host’s networking directly.


3. None : If you want to completely disable the networking stack on a container, you can use the none driver.


4. Overlay : This driver creates a distributed network among multiple Docker daemon hosts. This network sits on top of the host-specific networks, allowing containers connected to it from different network segment.


5. MacVlan : macvlan driver requires Linux Kernel 3.9 or greater. You can check your kernel version with uname -r. This driver can be used to assign a MAC address to each container’s virtual network interface, making it appear to be a physical network interface directly connected to the physical network.


To get further details on networks, run:


 [root@siddhesh ~]# docker network inspect bridge
[
    {
        "Name": "bridge",
        "Id": "005a608caf517bf9e6e49934ac9904049e296e23cfb4c5a81731522d440bba5a",
        "Created": "2020-04-05T22:41:30.548103709+05:30",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": null,
            "Config": [
                {
                    "Subnet": "172.17.0.0/16",
                    "Gateway": "172.17.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Containers": {},
        "Options": {
            "com.docker.network.bridge.default_bridge": "true",
            "com.docker.network.bridge.enable_icc": "true",
            "com.docker.network.bridge.enable_ip_masquerade": "true",
            "com.docker.network.bridge.host_binding_ipv4": "0.0.0.0",
            "com.docker.network.bridge.name": "docker0",
            "com.docker.network.driver.mtu": "1500"
        },
        "Labels": {}
    }
]
[root@siddhesh ~]#

Create another Bridge interface and attache to container.


[root@siddhesh ~]# docker network create -d bridge siddhesh-net
docker network create -d bridge siddhesh-net
6e0c72dead4ff315237bcdfbf2194cea0d310edea59398ca142715afbcc817f3
[root@siddhesh ~]#

Verify newly created interface using docker network.


[root@siddhesh ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
90d57756b07c        bridge              bridge              local
d0e010909698        host                host                local
f9a97fa21d1b        none                null                local
6e0c72dead4f        siddhesh-net        bridge              local
[root@siddhesh ~]#

Same can be verified using ifconfig linux command as follow.


[root@siddhesh ~]# ifconfig br-6e0c72dead4f
br-6e0c72dead4f Link encap:Ethernet  HWaddr 02:42:9A:79:3D:03
          inet addr:172.19.0.1  Bcast:172.19.255.255  Mask:255.255.0.0
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)
[root@siddhesh ~]#

Now lets try to run container using newly created bridge interface.


[root@siddhesh ~]# docker run --network=siddhesh-net -i -t centos
[root@siddhesh ~]#

Create macvlan interface using docker network and attach to container.


[root@siddhesh ~]# docker network create -d macvlan --subnet=10.0.0.0/24 --gateway=10.0.0.1 -o parent=eth0 siddhesh-macvlan
[root@siddhesh ~]#

[root@siddhesh ~]# docker run --network=siddhesh-macvlan -i -t centos
[root@96296b77a4cc /]# ip a l
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
4: eth0@if43179: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UNKNOWN groupdefault
    link/ether 02:42:0a:00:00:02 brd ff:ff:ff:ff:ff:ff link-netnsid 0
    inet 10.0.0.2/24 brd 10.0.0.255 scope global eth0
       valid_lft forever preferred_lft forever
[root@96296b77a4cc /]#

You can inspect/verify newly create network interface properties using docker network inspect.


[root@siddhesh ~]# docker network inspect siddhesh-macvlan
[
    {
        "Name": "siddhesh-macvlan",
        "Id": "8fdc29a2f665d951ec2f46a3798acaf42bf3a921c90385b59ee2154cf2e2b92e",
        "Created": "2020-04-06T17:07:46.223236645Z",
        "Scope": "local",
        "Driver": "macvlan",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "10.0.0.0/24",
                    "Gateway": "10.0.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {},
        "Options": {
            "parent": "eth0"
        },
        "Labels": {}
    }
]
[root@siddhesh ~]#


To remove existing network interface, run :


[root@siddhesh ~]# docker network rm siddhesh-macvlan
siddhesh-macvlan
[root@siddhesh ~]#





Kommentare

Mit 0 von 5 Sternen bewertet.
Noch keine Ratings

Rating hinzufügen
bottom of page