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}
相关推荐
微刻时光9 分钟前
Docker部署Nginx
运维·nginx·docker·容器·经验
小安运维日记24 分钟前
CKA认证 | Day3 K8s管理应用生命周期(上)
运维·云原生·容器·kubernetes·云计算·k8s
陈小肚31 分钟前
k8s 1.28.2 集群部署 docker registry 接入 MinIO 存储
docker·容器·kubernetes
A陈雷1 小时前
springboot整合elasticsearch,并使用docker desktop运行elasticsearch镜像容器遇到的问题。
spring boot·elasticsearch·docker
小扳1 小时前
Docker 篇-Docker 详细安装、了解和使用 Docker 核心功能(数据卷、自定义镜像 Dockerfile、网络)
运维·spring boot·后端·mysql·spring cloud·docker·容器
politeboy2 小时前
关于k8s中镜像的服务端口被拒绝的问题
云原生·容器·kubernetes
weixin_438197382 小时前
K8S创建云主机配置docker仓库
linux·云原生·容器·eureka·kubernetes
南猿北者9 小时前
docker Network(网络)
网络·docker·容器
sam-12311 小时前
k8s上部署redis高可用集群
redis·docker·k8s
Fanstay98511 小时前
在Linux中使用Nginx和Docker进行项目部署
linux·nginx·docker