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}
相关推荐
容器魔方2 天前
Bloomberg 正式加入 Karmada 用户组!
云原生·容器·云计算
muyun28002 天前
Docker 下部署 Elasticsearch 8 并集成 Kibana 和 IK 分词器
elasticsearch·docker·容器
Nazi62 天前
k8s的dashboard
云原生·容器·kubernetes
傻傻虎虎2 天前
【Docker】常用帮忙、镜像、容器、其他命令合集(2)
运维·docker·容器
是小崔啊2 天前
叩丁狼K8s - 概念篇
云原生·容器·kubernetes
2401_897930063 天前
使用Docker轻松部署Neo4j图数据库
数据库·docker·neo4j
LeeZhao@3 天前
【AI推理部署】Docker篇04—Docker自动构建镜像
人工智能·docker·容器
程思扬3 天前
利用JSONCrack与cpolar提升数据可视化及跨团队协作效率
网络·人工智能·经验分享·docker·信息可视化·容器·架构
落日漫游3 天前
dockercompose和k8s区别
docker·kubernetes
lllsure3 天前
【Docker】存储卷
运维·docker·容器