一、Docker 概述
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
1、Docker 为什么出现
一款产品从开发环境到上线,两套环境!开发环境与应用环境。配置环境十分麻烦,每一个机器都要部署环境十分费时费力。一般来说直接发布jar/war包就可以了,项目能不能直接带上环境安装打包!
Docker的思想来自于集装箱!核心思想:隔离!打包装箱!每一个箱子是互相隔离的!
Docker通过隔离机制,可以将服务器利用到极致!
2、Docker的历史
2008年,Solomon Hykes 和他的朋友 Kamel Founadi、Sebastien Pahl 共同创立了一家名为 DotCloud 的公司,目标是利用一种叫做容器的技术来创建他们称作是“大规模的创新工具”:任何人都可以使用的编程工具。
2010年,dotCloud获得了创业孵化器Y Combinator的支持,并开始吸引到一些真正的投资,在接下来的3年中,dotCloud内部孵化了一款名为Docker的产品。
3、Docker 能干吗
虚拟机技术
虚拟机技术缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢
容器化技术
容器化技术不是模拟的一个完整的操作系统
比较Docker与虚拟机技术的不同
1、传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。
2、容器内的应用直接运行在宿主的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了。
3、每一个容器间是相互隔离的,每一个容器内都有一个属于自己的文件系统,互不影响。
二、Docker 安装
1、Docker 的基本组成
镜像(image): Docker镜像好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像 -> run ->tomcat01容器(提供服务器) 通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)
容器(container): Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。 启动、停止、删除、基本命令
目前可以把这个容器简单的理解为一个简易的linux系统
仓库(repository): 仓库就是存放镜像的地方!仓库分为公有的仓库和私有的仓库
2、 安装Docker
环境准备 1、linux 2、CentOS7
环境查看
#系统内核是3.10以上的
[root@localhost /]# uname -r
3.10.0-1127.el7.x86_64
#系统版本
[root@localhost /]# cat /etc/os-release
NAME="CentOS Linux"
VERSION="7 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="7"
PRETTY_NAME="CentOS Linux 7 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:7"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"
CENTOS_MANTISBT_PROJECT="CentOS-7"
CENTOS_MANTISBT_PROJECT_VERSION="7"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="7"
安装
在 CentOS 上安装 Docker 引擎 |码头工人文档
#1、卸载旧版本
$ sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
#2、安装需要环境
yum install -y yum-utils
# 3、设置镜像仓库 默认的是国外的
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
# 4、阿里云镜像地址
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 5、更新yum软件包索引
# yum makecache fast
# 6、安装docker引擎 docker-ce 社区版 ee企业版
yum install docker-ce docker-ce-cli containerd.io
# 7、启动Docker
systemctl start docker
# 8、docker version 查看是否安装成功
# 9、测试
docker run hello-world
10、查看hello-world镜像
docker images
# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest 9c7a54a9a43c 4 months ago 13.3kB
11、卸载docker
#1、卸载 Docker Engine、CLI、containerd 和 Docker Compose 软件包
sudo yum remove docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-ce-rootless-extras
#2、主机上的映像、容器、卷或自定义配置文件 不会自动移除。要删除所有映像、容器和卷,请执行以下操作:
rm -rf /var/lib/docker
rm -rf /var/lib/containerd
#/var/lib/docker docker的默认工作路径
注意:在此配置时,设置阿里云镜像时测试未成功。于是配置 daemon.json 文件配置多个镜像加速地址
- 修改或者创建 /etc/docker/daemon.json 文件
{
"registry-mirrors":[
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com",
"https://docker.mirrors.ustc.edu.cn",
"https://registry.hub.docker.com"
]
}
- 重启docker
systemctl restart docker
- 查看是否设置成功
docker info
3、阿里云镜像加速
centos
配置使用
#sudo mkdir -p /etc/docker
#sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://sxyo7j5h.mirror.aliyuncs.com"]
}
EOF
#sudo systemctl daemon-reload
#sudo systemctl restart docker
4、 回顾hello-world
run 运行的过程
底层原理
Docker是怎么工作的呢? Docker 是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socker从客户端访问!
DockerServer接收到Docker-Client的指令,就会执行这个命令!
Doker为什么比虚拟机快
1、Docker有着比虚拟机更少的抽象层 2、Docker利用是宿主机的内核,VM需要是Guest OS
所以说,新建一个容器的时候,docker不需要像vm一样重新加载一个OS,避免引导。vm是加载 Guest OS,分钟级别的,而Docker是利用宿主机的OS,省略了这个复制的过程