docker 介绍及安装操作

 

1、docker概述

2、docker安装及操作

 

 

1、docker概述:

Docker是一个开源的应用容器引擎,基于go语言开发并遵循了apache2.0协议开源

是在Linux容器里运行应用的开源工具

是一种轻量级的“虚拟机”

Docker的容器技术可以在一台主机上轻松为任何应用创建一个轻量级的、可移植的、自给自足的容器。

 

核心概念:

镜像、容器、仓库

镜像:运行容器的基础,包含运行应用程序所需的所有内容

容器:是从镜像创建的运行实例

仓库:集中保存镜像的地方(公有仓库docker hub、私有仓库 harhor)

 

总结:容器:提供在多台主机上运行应用程序相同的运行环境

docker 是开源的容器 引擎,go语言开发的,是容器里运行应用的工具,是一个轻量级的虚拟机,

        可以利用docker在多台主机上轻松的创建并运行容器

docker 容器可以被看作 运行在宿主机上的一个进程,容器共享主机的内核,容器间,是通过namespace(命名空间)

    隔离资源,通过cgroups(资源配额)去限制资源

 

Docker是容器管理工具,容器由镜像创建而来,镜像从仓库中获取而来,仓库分为公有、私有。

 

 

docker与虚拟机区别:

特性 Docker容器 虚拟机
启动速度 秒级 分钟级
计算能力损耗 几乎无 损耗50%左右
性能 接近原生 弱于
系统支持量(单机) 上千个 几十个
隔离性 资源隔离/限制 完全隔离

 

 

namespace的六项隔离:

namespace 系统调用参数 隔离内容
UTS CLONE_NEWUTS 主机名与域名
IPC CLONE_NEWWIPC 信号量、消息队列和共享内存
PID CLONE_NEWPID 进程编号
NETWORK CLONE_NEWNET 网络设备,网络栈,端口等
MOUNT CLONE_NEWNS 挂载点(文件系统)
USER CLONE_NEWUSER 用户和用户组(3.8以后的内核才支持)

 

 

容器化越来越受欢迎的原因是:

  • 灵活:即便是最复杂的应用也可以集装箱化
  • 轻量级:容器利用并共享主机内核
  • 可互换:可以及时部署更新和升级
  • 便携式:可以在本地构建,部署到云,并在任何地方运行
  • 可扩展:可以增加并自动分发容器副本
  • 可堆叠:可以垂直和及时堆叠服务

 

 

2、docker安装及操作:

目前 Docker 只能支持 64 位系统。

systemctl stop firewalld.service
setenforce 0

#安装依赖包
yum install -y yum-utils device-mapper-persistent-data lvm2 
--------------------------------------------------------------------------------------------
yum-utils:提供了 yum-config-manager 工具。
device mapper: 是Linux内核中支持逻辑卷管理的通用设备映射机制,
			    它为实现用于存储资源管理的块设备驱动提供了一个高度模块化的内核架构。
device mapper存储驱动程序需要 device-mapper-persistent-data 和 lvm2。
--------------------------------------------------------------------------------------------

#设置阿里云镜像源
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 

#安装 Docker-CE并设置为开机自动启动
yum install -y docker-ce

systemctl start docker.service
systemctl enable docker.service 

#查看 docker 版本信息
docker version

docker 介绍及安装操作_唯一标识

 

docker 介绍及安装操作_唯一标识_02

 

docker 介绍及安装操作_docker_03

 

docker 介绍及安装操作_nginx_04

 

  

 

 

 

-----------------docker镜像操作----------------

搜索镜像:
格式:docker search 关键字
docker search nginx


获取镜像:
格式:docker pull 仓库名称[:标签]
#如果下载镜像时不指定标签,则默认会下载仓库中最新版本的镜像,即选择标签为 latest 标签。
docker pull nginx


镜像下载加速:
浏览器访问 https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors 获取镜像加速器配置

mkdir -p /etc/docker
tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://6ijb8ubo.mirror.aliyuncs.com"]
}
EOF
systemctl daemon-reload
systemctl restart docker



查看镜像信息:
镜像下载后存放在 /var/lib/docker 

#查看下载的镜像文件信息
cat /var/lib/docker/image/overlay2/repositories.json

#查看下载到本地的所有镜像
docker images


REPOSITORY   TAG       IMAGE ID       CREATED      SIZE
nginx        latest    ae2feff98a0c   9 days ago   133MB
--------------------------------------------------------------------------------------------
REPOSITORY:镜像属于的仓库;
TAG:镜像的标签信息,标记同一个仓库中的不同镜像;
IMAGE ID:镜像的唯一ID 号,唯一标识一个镜像;
CREATED:镜像创建时间;
VIRTUAL SIZE:镜像大小;
--------------------------------------------------------------------------------------------

#根据镜像的唯一标识 ID 号,获取镜像详细信息
格式:docker inspect 镜像ID号
docker inspect ae2feff98a0c



为本地添加新的标签:
格式:docker tag 名称:[标签] 新名称:[新标签]
docker tag nginx:latest nginx:web

docker images | grep nginx




删除镜像:
格式:
docker rmi 仓库名称:标签				#当一个镜像有多个标签时,只是删除其中指定的标签
或者
docker rmi 镜像ID号						#会彻底删除该镜像

注意:如果该镜像已经被容器使用,正确的做法是先删除依赖该镜像的所有容器,再去删除镜像。普通删除无法删除时,可以加-f选项强制删除。

docker rmi nginx:web



存出镜像:将镜像保存为本地文件:
格式:docker save -o 存储文件名 存储的镜像
docker save -o nginx nginx:latest			#存出镜像命名为nginx存在当前目录下
ls -lh



载入镜像:将镜像文件导入镜像库中:
格式:
docker load < 存出的文件
或者
docker load -i 存出的文件

docker load < nginx



上传镜像:
默认上传到 docker Hub 官方公共仓库,需要注册使用公共仓库的账号。
可以使用 docker login 命令来输入用户名、密码和邮箱来完成注册和登录。
在上传镜像之前,还需要先对本地镜像添加新的标签,然后再使用 docker push 命令进行上传。

docker tag nginx:latest nginx:web		#添加新的标签
docker login								#登录公共仓库
Username:
password:
docker push wl/nginx:web					#上传镜像

docker 介绍及安装操作_nginx_05

 

docker 介绍及安装操作_唯一标识_06

 

docker 介绍及安装操作_唯一标识_07

 

docker 介绍及安装操作_linux_08

 

docker 介绍及安装操作_唯一标识_09

 

docker 介绍及安装操作_linux_10

 

docker 介绍及安装操作_docker_11

 

docker 介绍及安装操作_nginx_12

 

docker 介绍及安装操作_docker_13

 

  

 

自古英雄多磨难