版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/tang_jin2015/article/details/78898780
因为尝试使用新的镜像,对原来的镜像进行删除,报错如下:
Error response from daemon: conflict: unable to delete 037c233c605c (must be forced) - image is being used by stopped container 65e94723f0ed
意思就是在删除镜像之前,要先删除对应的docker.因为该image被对应的container引用,所以image删除失败。
[root@vm000949 redis]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mia/redis v2 a061cf8c12b8 48 minutes ago 210.7 MB
037c233c605c 2 days ago 203.5 MB
主要希删除这两个imgae,根据image的id到container中找
[root@vm000949 redis]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
1be364973e1d a061cf8c12b8 "/bin/bash" 42 minutes ago Exited (137) 5 minutes ago thirsty_einstein
65e94723f0ed 037c233c605c "/bin/sh -c 'yum -y u" 2 days ago Exited (1) 2 days ago gloomy_mestorf
Ok.删除它们
[root@vm000949 redis]# docker rm 65e94723f0ed
65e94723f0ed
[root@vm000949 redis]# docker rm 1be364973e1d
1be364973e1d
再删除镜像,好的,成功啦。
[root@vm000949 redis]# docker rmi a061cf8c12b8
Untagged: mia/redis:v2
Deleted: sha256:a061cf8c12b8a23ea9fe85ebcfc32615f8e9a38dd95961b0dd80ceae658cdc5a
Deleted: sha256:f80464ae70055852f02c7763858dd97121c0e3d77430cb4df2dc70aec1c19678
Deleted: sha256:cdcbccf2d746d094040b8383868120d6d73327827b6ee83a8989baab9bf5fa42
[root@vm000949 redis]# docker rmi 037c233c605c
Deleted: sha256:037c233c605c5b4266ef6cc208d6c1a07b01fab77e848ec0bbb3bb01bdb3fda1
Deleted: sha256:7e07f5920a8cef8dbc5a5a663b14dc37d1112b259d93629aa8ded32f0ea0a6ae
也可以根据提示来的,加-f强制删除镜像。
顺便提一下,docker命令:
1.docker rm <容器ID或容器名>
2.docker stop<容器ID或容器名>
引申:1.如何删除所有容器;2.如何删除所有容器镜像,3.在创建镜像时会产生很多的中间镜像,这部分镜像是一起删除的吗?none镜像?
1.首先,解决第一点
docker rm $(docker ps -aq)
这里docker ps 的命令包括:
1)-a 列出所有容器
2)-l 列出最新创建容器
3)-n=2 列出最近创建的2个容器
4)-q 仅列出容器ID
5)-s 显示容器大小
所以docker ps -aq 相当于列出所有的容器ID,然后docker rm它们
但是要注意的是,如果容器正在运行是无法删除,需要先停止:
Docker stop $(docker ps -aq)
2.类似的docker image呢?
镜像删除语法为:
docker rmi [OPTIONS] [IMAGEID]
OPTIONS 的参数包括:-f 强制删除,–no-prune:不移除镜像产生的过程镜像。默认为移除。
比如:
Docker rmi $(docker ps -aq)
这里的-aq显示的是image的ID
3.如果想要删除没有打tag的none镜像:
Docker rmi $(docker images -a|grep none|awk '{print $3}')
也可以写成:
docker ps -a |grep none }awk '{print $1}'|xargs docker rmi
通过xagrs传入参数
有些什么情况会产生none的镜像?
1)在镜像创建过程中创建失败,会产生无效的none镜像
2)pull镜像。镜像的垂直父子关系
3)使用dockerfile文件创建镜像,重新生成,新的镜像名赋给后者,前面的镜像名字为none
参考资料:
[1]docker强制批量删除none的image镜像
[2]Docker中images中none的镜像是否可以删除
应用场景:某个相关的业务需要重启,容器太多了,一个一个通过命令行来关闭太麻烦了,直接一条命令直接搞定。
命令如下:
$ docker ps // 查看所有正在运行容器 $ docker stop containerId // containerId 是容器的ID $ docker ps -a // 查看所有容器 $ docker ps -a -q // 查看所有容器ID $ docker stop $(docker ps -a -q) // stop停止所有容器 $ docker rm $(docker ps -a -q) // remove删除所有容器
1、容器是独立运行的一个或一组应用,及他们的运行环境。容器是Docker中的一个重要的概念。
2、docker容器的启动有三种方式
a.交互方式,基于镜像新建容器并启动
例如我们可以启动一个容器,打印出当前的日历表
[root@rocketmq-nameserver4 ~]# docker run my/python:v1 cal ##my/python:v1为镜像名和标签
我们还可以通过指定参数,启动一个bash交互终端。
[root@rocketmq-nameserver4 ~]# docker run -it my/python:v1 /bin/bash
参数-t让Docker分配一个伪终端并绑定在容器的标准输入上,-i让容器的标准输入保持打开。
使用docker run命令来启动容器,docker在后台运行的标准操作包括
1.检查本地是否存在指定的镜像,不存在则从公有仓库下载
2.使用镜像创建并启动容器
3.分配一个文件系统,并在只读的镜像层外面挂载一层可读可写层
4.从宿主主机配置的网桥接口中桥接一个虚拟接口道容器中去
5.从地址池分配一个ip地址给容器
6.执行用户指定的应用程序
7.执行完毕之后容器被终止
my/sinatra:v2基于training/sinatra镜像进行修改后的镜像,training/sinatra为公有仓库上的镜像。
b、短暂方式,直接将一个已经终止的容器启动运行起来
可以使用docker start命令,直接将一个已经终止的容器启动运行起来。
[root@rocketmq-nameserver4 ~]# docker run my/python:v1 /bin/echo hello test
hello test
命令执行完,控制台会打印"hello test",container就终止了,不过并没有消失,
可以用"docker ps -n 5 "看一下最新前5个的container,第一个就是刚刚执行过的container,可以再次执行一遍:docker start container_id
不过这次控制台看不到”hello test”了,只能看到ID,用logs命令才能看得到:docker logs container_id。
可以看到两个”hello test”了,因为这个container运行了两次。
c、daemon方式,守护态运行
即让软件作为长时间服务运行,这就是SAAS啊!
例如我们启动centos后台容器,每隔一秒打印当天的日历。
$ docker run -d centos /bin/sh -c "while true;do echo hello docker;sleep 1;done"
启动之后,我们使用docker ps -n 5查看容器的信息
要查看启动的centos容器中的输出,可以使用如下方式:
$ docker logs $CONTAINER_ID ##在container外面查看它的输出
$ docker attach $CONTAINER_ID ##连接上容器实时查看:
3、终止容器
使用docker stop $CONTAINER_ID来终止一个运行中的容器。并且可以使用docker ps -a来看终止状态的容器。
终止状态的容器,可以使用docker start来重新启动。
分类 Docker系列教程