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}
相关推荐
皮皮冰燃6 小时前
docker-18-WSL中安装docker并部署flask服务
docker·容器·flask
少年白char6 小时前
整理上万首音乐后的完整工作流:下载、刮削、播放与避坑指南
docker·nas·musictag·音乐刮削·音乐标签
木雷坞12 小时前
K8s GPU 推理服务 ImagePullBackOff 排查与预热
云原生·容器·kubernetes·gpu算力
萧行之13 小时前
Docker部署Loki+Grafana+Vector实现全服务器日志监控(含N8N/SSH/Fail2ban监控)
服务器·docker·grafana
人工智能培训14 小时前
工程科研中的AI应用:结构力学分析技巧
人工智能·深度学习·机器学习·docker·容器
计算机安禾15 小时前
【Linux从入门到精通】第35篇:容器化技术预备——Docker安装与基本概念
linux·运维·docker
子木HAPPY阳VIP15 小时前
信创UOS,Docker 完整操作部署(Dockerfile部署方式)&排错整合
linux·运维·redis·nginx·docker·容器·tomcat
AOwhisky15 小时前
Kubernetes调度与服务暴露:从“定时任务”到“服务发现”的完全指南
linux·运维·云原生·容器·kubernetes·服务发现
Cyber4K16 小时前
【Kubernetes专项】温故而知新,重温技术原理(6)
云原生·容器·kubernetes
AI服务老曹16 小时前
架构实战:基于 GB28181 与 RTSP 的异构设备统一接入方案,深度解析 Docker 化 AI 视频管理平台
人工智能·docker·架构