Docker概述与安装

134 阅读5分钟

一、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 能干吗

虚拟机技术

image.png

虚拟机技术缺点:

1、资源占用十分多

2、冗余步骤多

3、启动很慢

容器化技术

容器化技术不是模拟的一个完整的操作系统

image.png

比较Docker与虚拟机技术的不同

1、传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。

2、容器内的应用直接运行在宿主的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了。

3、每一个容器间是相互隔离的,每一个容器内都有一个属于自己的文件系统,互不影响。

二、Docker 安装

1、Docker 的基本组成

image.png

镜像(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 查看是否安装成功

image.png

# 9、测试
docker run hello-world

image.png

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、阿里云镜像加速

image.png

centos image.png

配置使用

#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 运行的过程 image.png

底层原理

Docker是怎么工作的呢? Docker 是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socker从客户端访问!

DockerServer接收到Docker-Client的指令,就会执行这个命令!

image.png

Doker为什么比虚拟机快

1、Docker有着比虚拟机更少的抽象层 2、Docker利用是宿主机的内核,VM需要是Guest OS

image.png

所以说,新建一个容器的时候,docker不需要像vm一样重新加载一个OS,避免引导。vm是加载 Guest OS,分钟级别的,而Docker是利用宿主机的OS,省略了这个复制的过程