Docker 是一款非常強大的容器化技術,網絡模型也非常重要。目前 Docker 支持四種網絡模型:host 模式、bridge 模式、none 模式和 container 模式。
host 模式
$ docker run --network host nginx
host 模式下,容器共享主機的網絡棧,也就是說容器將不再具有獨立的網絡命名空間。當容器中的進程需要訪問網絡時,直接使用主機的網絡設備。
bridge 模式
$ docker run --network bridge nginx
bridge 模式是 Docker 默認使用的網絡模式,容器會被分配一個私有網絡,并使用 NAT 訪問主機和外部網絡。如果需要讓多個容器相互通信,則需要創建一個共享網絡。
none 模式
$ docker run --network none nginx
none 模式下,容器沒有聯網功能,完全隔離于主機和其他容器之外。
container 模式
$ docker run --network container:container_name nginx
通過運行容器時添加 --network container:name 標志,可以讓新容器與現有容器共享網絡棧,實現容器間通信的效果。