Docker 基本操作总结

Docker 基本操作总结

一、Docker的基本组成

① 镜像(image)

​ Docker 镜像(Image)就是一个只读的模板。镜像可以用来创建 Docker 容器,一个镜像可以创建很多容器。

image-20201125102603152

② 容器(container)

  • Docker 利用容器(Container)独立运行的一个或一组应用。容器是用镜像创建的运行实例。

  • 它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。

  • 可以把容器看做是一个简易版的 Linux 环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。

  • 容器的定义和镜像几乎一模一样,也是一堆层的统一视角,唯一区别在于容器的最上面那一层是可读可写的。

③ 仓库(repository)

  • 仓库(Repository)是集中存放镜像文件的场所。

  • 仓库(Repository)和仓库注册服务器(Registry)是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签(tag)。

  • 仓库分为公开仓库(Public)和私有仓库(Private)两种形式。

  • 最大的公开仓库是 Docker Hub(https://hub.docker.com/),存放了数量庞大的镜像供用户下载。国内的公开仓库包括阿里云 、网易云 等

④ Docker的架构图

image-20201125103156718

二、安装步骤

请参考:https://docs.docker.com/engine/install/centos/

① CentOS7安装Docker

​ 官网中文安装参考手册:https://docs.docker-cn.com/engine/installation/linux/docker-ce/centos/#prerequisites

  1. 确定CentOS7 版本

    cat /etc/redhat-release
    

    image-20201125103806151

  2. yum安装gcc相关

yum -y install gcc
yum -y install gcc-c++
  1. 卸载旧版本(根据自己的情况选择)
yum -y remove docker docker-common docker-selinux docker-engine
  1. 安装需要的软件包
yum install -y yum-utils device-mapper-persistent-data lvm2yum install -y yum-utils device-mapper-persistent-data lvm2
  1. 设置stable镜像仓库
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  1. 更新yum软件包索引
yum makecache fast
  1. 安装DOCKER CE
yum -y install docker-ce
  1. 启动docker
systemctl start docker

9.测试

docker version

image-20201125105132518

docker run hello-world

image-20201125105448967

  1. 卸载
systemctl stop docker 
yum -y remove docker-ce
rm -rf /var/lib/docker

② 修改镜像加速源

本篇博客采用的是 阿里云镜像源加速

可以先参考了解一下:https://dev.aliyun.com/search.html

  1. 注册一个属于自己的阿里云账户(可复用淘宝账号)

  2. 获得加速器地址连接

  • 登陆阿里云开发者平台

image-20201125110242402

  • 获取加速器地址

image-20201125110315122

③ 配置本机Docker运行镜像加速器

配置镜像加速CentOS7版本

  • mkdir -p /etc/docker
  • vim /etc/docker/daemon.json
 #阿里云
{
  "registry-mirrors": ["https://{自已的编码}.mirror.aliyuncs.com"]
}

image-20201125110559470

  • systemctl daemon-reload
  • systemctl restart docker

④ 底层原理

  1. Docker工作机制

    Docker是一个Client-Server结构的系统,Docker守护进程运行在主机上, 然后通过Socket连接从客户端访问,守护进程从客户端接受命令并管理运行在主机上的容器。 容器,是一个运行时环境,就是我们前面说到的集装箱。

image-20201125110849091

三、Docker常用命令

① 帮助命令

  • docker version
  • docker info
  • docker info

② 镜像命令

1、docker images
  • 查看本地镜像仓库镜像源

image-20201125111311989

各个选项说明:

选项说明
REPOSITORY表示镜像的仓库源
TAG镜像的标签
IMAGE ID镜像ID
CREATED镜像创建时间
SIZE镜像大小

​ 同一仓库源可以有多个 TAG,代表这个仓库源的不同个版本,我们使用 REPOSITORY:TAG 来定义不同的镜像。如果你不指定一个镜像的版本标签,例如你只使用 ubuntu,docker 将默认使用 ubuntu:latest 镜像。

OPTIONS说明:

参数说明
-a列出本地所有的镜像(含中间映像层)
-q只显示镜像ID。
–digests显示镜像的摘要信息
–no-trunc显示完整的镜像信息
2、docker search
  • 查询镜像源

docker search [OPTIONS] 镜像名字

OPTIONS说明:

参数说明
–no-trunc显示完整的镜像描述
-s列出收藏数不小于指定值的镜像。
–automated只列出 automated build类型的镜像
3、docker pull
  • 拉取镜像源

docker pull 镜像名字[:TAG]

4、docker rmi
  • 删除镜像源

  • 删除单个

docker rmi  -f 镜像ID
  • 删除多个
docker rmi -f 镜像名1:TAG 镜像名2:TAG 
  • 删除全部
docker rmi -f $(docker images -qa)

③ 容器命令

有镜像才能创建容器,这是根本前提(下载一个CentOS镜像演示)

docker pull centos

新建并启动容器

  • docker run [OPTIONS] IMAGE [COMMAND] [ARG…]

OPTIONS说明

参数说明
-d后台运行容器,并返回容器ID,也即启动守护式容器
-i以交互模式运行容器,通常与 -t 同时使用
-t为容器重新分配一个伪输入终端,通常与 -i 同时使用
-P随机端口映射
-p指定端口映射,有以下四种格式:
ip:hostPort:containerPort
ip::containerPort
hostPort:containerPort
containerPort

列出当前所有正在运行的容器

  • docker ps [OPTIONS]

OPTIONS说明

参数说明
-a列出当前所有正在运行的容器+历史上运行过的
-l显示最近创建的容器。
-n显示最近n个创建的容器。 docker ps -n 3
-q静默模式,只显示容器编号
–no-trunc不截断输出

image-20201125164206636

退出容器

  • exit: 容器停止退出
  • ctrl+P+Q: 容器不停止退出

启动容器

docker start  容器ID或者容器名

image-20201125164628315

重启容器

docker restart 容器ID或者容器名

停止容器

docker stop 容器ID或者容器名

强制停止容器

docker kill 容器ID或者容器名

删除已停止的容器

docker rm 容器ID

一次性删除多个容器

  • docker rm -f $(docker ps -a -q)
  • docker ps -a -q | xargs docker rm

④ 核心命令

1、启动守护式容器
  • 启动守护式容器
docker run -d 容器名

示例:使用镜像centos:latest以后台模式启动一个容器

docker run -d centos

问题:然后docker ps -a 进行查看, 会发现容器已经退出,很重要的要说明的一点: Docker容器后台运行,就必须有一个前台进程.
容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail)
,就是会自动退出的。

这个是docker的机制问题,比如你的web容器,我们以nginx为例,正常情况下,我们配置启动服务只需要启动响应的service即可。例如 service nginx start 但是,这样做,nginx为后台进程模式运行,就导致docker前台没有运行的应用,这样的容器后台启动后,会立即自杀因为他觉得他没事可做了所以,最佳的解决方案是,将你要运行的程序以前台进程的形式运行。

  • 从Hub上下载tomcat镜像到本地并成功运行
docker run -it -p 8080:8080 tomcat
参数说明
-p主机端口:docker容器端口
-P随机分配端口
i交互
t终端

image-20201125170050572

  • 查看容器日志
docker logs -f -t --tail 容器ID
docker run -d centos /bin/sh -c "while true;do echo hello zzyy;sleep 2;done"

image-20201125170253224

参数说明
-t是加入时间戳
-f跟随最新的日志打印
–tail数字 显示最后多少条

image-20201125170447540

  • 查看容器内运行的进程
docker top 容器ID

image-20201125170714558

  • 进入正在运行的容器并以命令行交互
docker exec -it 容器ID bashShell

image-20201125170820560

其他:

docker exec -it 容器ID ls -l /tmp
  • 重新进入docker attach 容器ID

image-20201125171522193

上述两个区别

  • attach 直接进入容器启动命令的终端,不会启动新的进程
  • exec 是在容器中打开新的终端,并且可以启动新的进程

四、小总结

常用命令:

image-20201125171745545

Docker 命令总结:

指令英文说明
attachAttach to a running container当前 shell 下 attach 连接指定运行镜像
buildBuild an image from a Dockerfile通过 Dockerfile 定制镜像
commitCreate a new image from a container changes提交当前容器为新的镜像
cpCopy files/folders from the containers filesystem to the host path从容器中拷贝指定文件或者目录到宿主机中
createCreate a new container创建一个新的容器,同 run,但不启动容器
diffInspect changes on a container’s filesystem查看 docker 容器变化
eventsGet real time events from the server从 docker 服务获取容器实时事件
execRun a command in an existing container在已存在的容器上运行命令
exportStream the contents of a container as a tar archive导出容器的内容流作为一个 tar 归档文件[对应 import ]
historyShow the history of an image展示一个镜像形成历史
imagesList images列出系统当前镜像
importCreate a new filesystem image from the contents of a tarball从tar包中的内容创建一个新的文件系统映像[对应export]
infoDisplay system-wide information显示系统相关信息
inspectReturn low-level information on a container查看容器详细信息
killKill a running containerkill 指定 docker 容器
loadLoad an image from a tar archive从一个 tar 包中加载一个镜像[对应 save]
loginRegister or Login to the docker registry server注册或者登陆一个 docker 源服务器
logoutLog out from a Docker registry server从当前 Docker registry 退出
logsFetch the logs of a container输出当前容器日志信息
portLookup the public-facing port which is NAT-ed to PRIVATE_PORT查看映射端口对应的容器内部源端口
pausePause all processes within a container暂停容器
psList containers列出容器列表
pullPull an image or a repository from the docker registry server从docker镜像源服务器拉取指定镜像或者库镜像
pushPush an image or a repository to the docker registry server推送指定镜像或者库镜像至docker源服务器
restartRestart a running container重启运行的容器
rmRemove one or more containers移除一个或者多个容器
rmiRemove one or more images移除一个或多个镜像[无容器使用该镜像才可删除,否则需删除相关容器才可继续或 -f 强制删除]
runRun a command in a new container创建一个新的容器并运行一个命令
saveSave an image to a tar archive保存一个镜像为一个 tar 包[对应 load]
searchSearch for an image on the Docker Hub在 docker hub 中搜索镜像
startStart a stopped containers启动容器
stopStop a running containers停止容器
tagTag an image into a repository给源中镜像打标签
topLookup the running processes of a container查看容器中运行的进程信息
unpauseUnpause a paused container取消暂停容器
versionShow the docker version information查看 docker 版本号
waitBlock until a container stops, then print its exit code截取容器停止时的退出状态值

更详细请参考:springboot之docker 博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值