2.docker client

docker client

Docker Run

从镜像创建、执行一个容器

bash 复制代码
# docker run <image-name>
docker run hello-world

执行docker run的时候,docker会先去寻找image文件,然后执行run指令

Override默认指令

bash 复制代码
# docker run <image-name> <command>

docker run busybox echo hello
docker run busybox echo bye

查看busybox的文件系统快照

bash 复制代码
docker run busybox ls
# bin
# dev
# etc
# ...

busybox拥有相对完整的linux环境

bash 复制代码
docker run hello-world ls
docker run hello-world echo hello

hello-world没有额外的指令

![外链图片转存失败,源站可

docker ps

列出当前运行中的docker, 等价于docker container ls

bash 复制代码
docker ps

docker run busybox echo hello

docker ps

docker run busybox ping aws.com

在另一个窗口中

bash 复制代码
docker ps
# CONTAINER ID   IMAGE     COMMAND          CREATED          STATUS          PORTS     NAMES
# a4cd7f84a33f   busybox   "ping aws.com"   16 seconds ago   Up 14 seconds             sleepy_robinson

列出所有docker

bash 复制代码
docker ps --all

docker ps -a

生命周期 lifecycle

列出了已经结束的docker

bash 复制代码
docker ps --all

docker进程在何时结束?这就要说到docker的生命周期

bash 复制代码
# docker run = docker create + docker start

docker create hello-world
# container id
bash 复制代码
docker start -a ${container id}

-a 代表attach,将docker的输出打印到控制台

重启已经结束的docker

bash 复制代码
docker run busybox echo hello

docker ps -a

docker start -a ${container id}

第2步的docker start又执行了一次。

在此过程中,不能覆盖指令

bash 复制代码
docker ps -a

并无额外的docker创建

清除所有docker

bash 复制代码
docker system prune

获取docker的日志

bash 复制代码
docker create hello-world
# container id
docker start ${container id}
# container id
docker logs ${container id} / ${container}

终止docker

bash 复制代码
docker create busybox ping aws.com

docker start ${container id}

docker logs ${container id}

docker ps

终止docker

bash 复制代码
docker stop <container id>

docker kill <container id>

stop指令发送SIGTERM

kill指令发送SIGKILL

SIGTERM允许优雅退出,但是会有10s的timeout,10s之后docker会重新发送SIGKILL

bash 复制代码
docker ps

docker stop ${container id}

# after 10s...
docker ps -a

docker start ${container id} 

docker kill ${container id}
相关推荐
lpruoyu29 分钟前
【Docker进阶-06】docker-compose & docker swarm
运维·docker·容器
虾说羊1 小时前
docker容器化部署项目流程
运维·docker·容器
骇客野人2 小时前
通过脚本推送Docker镜像
java·docker·容器
liux35283 小时前
基于kubeadm部署Kubernetes 1.26.4 集群指南
云原生·容器·kubernetes
Zfox_3 小时前
CANN GE 深度解析:图编译器与执行引擎的后端优化策略、OM 文件结构与 Stream 调度机制
容器·节点小宝
人鱼传说6 小时前
docker desktop是一个好东西
运维·docker·容器
小章UPUP7 小时前
Kubernetes (K8s) 与 Podman 的比较
容器·kubernetes·podman
忆~遂愿7 小时前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
说实话起个名字真难啊8 小时前
用docker来安装openclaw
docker·ai·容器
恬静的小魔龙8 小时前
【群晖Nas】群晖Nas中实现SVN Server功能、Docker/ContainerManager等
docker·svn·容器