ck28 -- 一木 -- DockerL2 原理分析与使用场景

一、Docker与虚拟机解析

1.1 架构区别

  • 虚拟机会虚拟独立的OS/内核,是一个完整的虚拟化方案
  • Docker只虚拟化软件,没有虚拟OS/内核,共享宿主机内核(namespace隔离不同容器)

1.2 使用场景区别

二、网络模式

2.1 bridge 网桥模式

  • Docker安装启动后会在宿主机上创建一个名为docker0的虚拟网桥,处于七层网络模型的数据链路层,后续每当我们创建一个新的docker容器,在不指定容器网络模式的情况下,docker会通过docker0与主机的网络连接,docker0相当于网桥。
  • 使用bridge模式新创建的容器,容器内部都会有一个虚拟网卡,名为eth0,容器之间可以通过容器内部的IP相互通信。
  • 命令:docker run -d -name tomcat01 --net=bridge -p 8085:80 tomcat:latest

2.2 host 模式

  • 如果容器指定host模式,则没有独立的network namespace,而是与宿主机共用network namespace。也就是说明容器本身不会有网卡信息,而是使用宿主机的网络信息。容器除了网络,其他比如文件系统、进程等依然都是隔离的。
  • 命令:指定 --net==host

2.3 container 模式

  • container模式和指定的容器共享,两者之间除了网络共享 (网卡、主机名、IP地址), 其他方面还是隔离的。
  • 命令:docker run -d -name tomcat02 --net=container:name/id -p 8000:80 tomcat:latest
    image

三、Docker-compose

3.1 简介

  • Docker Compose是