Docker可以运行于任何安装了现代Linux内核的x64主机上。推荐的内核版本是3.8或者更高。Docker的开销比较低,可用于服务器、台式机或者笔记本。它包括以下几个部分。
- 一个原生的Linux容器格式,Docker中称为libcontainer。
- 文件系统隔离: 每个容器都有自己的root文件系统。
- 进程隔离:每个容器都运行在自己的进程环境中。
- 网络隔离:容器间的虚拟网络接口和IP地址都是分开的。
- 资源隔离和分组:使用cgroup(即control group,linux 的内核特性之一)将CPU和内存资源之类的资源独立分配给每个Docker容器。
- 写时复制: 文件系统都是通过写时复制创建的,这就意味着文件系统是分层的、快速的,而且占用的磁盘空间更小。
- 日志: 容器产生的STDOUT、STDERR和STDIN这些IO流都会被收集并记入日志,用来进行日志分析和故障排错。
- 交互式shell:用户可以创建一个伪终端,将其连接到STDIN,为容器提供一个交互式的shell
安装先决条件:
- 运行Linux3.8或者更高版本内核(64bit)
- 内核必须支持一种合适的存储驱动(storage driver),例如:
- Device Manager;
- AUFS
- vfs
- btrfs
- ZFS
- 默认存储驱动通常是Device Mapper或AUFS
- 内核必须支持并开启cgroup和命名空间(namespace)功能。
检查前提条件