Dockerfile" rm -Rf"失败

时间:2017-02-12 03:44:05

标签: docker

我有一个非常简单的dockerfile," rm -Rf"安装后删除安装文件,但我收到了一些错误:

Step 4/4 : RUN rm -Rf /INSTALLATION
 ---> Running in 19fe828f3c9d
rm: cannot remove '/INSTALLATION/Subsystems/Common': Directory not empty
rm: cannot remove '/INSTALLATION/Subsystems/EMS': Directory not empty

我用root用户运行。

我的dockerfile:

FROM centos
COPY INSTALLATION/ /INSTALLATION/ 
RUN  rm -Rf /INSTALLATION

我的操作系统是centos7,主机操作系统是RHLE 7.

Docker信息

[root@snap460c03 1]# docker info
Containers: 53
 Running: 27
 Paused: 0
 Stopped: 26
Images: 19
Server Version: 1.13.0
Storage Driver: overlay
 Backing Filesystem: xfs
 Supports d_type: false
Logging Driver: json-file
Cgroup Driver: cgroupfs
Plugins: 
 Volume: local
 Network: bridge host macvlan null overlay
Swarm: inactive
Runtimes: runc
Default Runtime: runc
Init Binary: docker-init
containerd version: 03e5862ec0d8d3b3f750e19fca3ee367e13c090e
runc version: 2f7393a47307a16f8cee44a37b262e8b81021e3e
init version: 949e6fa
Security Options:
 seccomp
  Profile: default
Kernel Version: 3.10.0-229.el7.x86_64
Operating System: Red Hat Enterprise Linux Server 7.1 (Maipo)
OSType: linux
Architecture: x86_64
CPUs: 24
Total Memory: 94.41 GiB
Name: snap460c03
ID: T3ST:6DXJ:SDST:3W3J:Z4NB:UXF7:HGSZ:A3WH:ELHX:GVZW:APTD:7ZEK
Docker Root Dir: /var/lib/docker
Debug Mode (client): false
Debug Mode (server): false
Http Proxy: http://16.85.88.10:8080/
No Proxy: docker-registry
Registry: https://index.docker.io/v1/
Experimental: false
Insecure Registries:
 docker-registry:5000
 127.0.0.0/8
Live Restore Enabled: false

我还尝试了新的容器并手动尝试,但结果也是错误的:

[root@devvm13 1]# docker run -it e20c9c5ffa8a /bin/bash

[root@f3efa193700d /]# rm -Rf /INSTALLATION/Subsystems/Common/*

[root@f3efa193700d /]# rm -Rf /INSTALLATION/Subsystems/Common 

rm: cannot remove '/INSTALLATION/Subsystems/Common': Directory not empty

你可以看到第二个rm失败,我试过rmdir,resule也是错误。

当我点击目录时,显示:

ls /INSTALLATION/Subsystems/Common
ls: cannot access /INSTALLATION/Subsystems/Common/eium-license.config: No such file or directory
ls: cannot access /INSTALLATION/Subsystems/Common/install_jdk.sh: No such file or directory
eium-license.config  install_jdk.sh

你可以说没有这样的文件,但跟着文件。

4 个答案:

答案 0 :(得分:3)

我有同样的问题,花了几个小时后才发现这个问题: - https://github.com/docker/docker/issues/27358

如此长的故事简短,这就是我修复它的方式。

当您执行泊坞窗信息时,在您的输出中有Storage Driver: overlay,我有相同的,我所做的是将叠加层更改为devicemapper。按照此处显示的说明进行操作 - https://docs.docker.com/engine/userguide/storagedriver/device-mapper-driver/#configure-docker-with-the-devicemapper-storage-driver

您还必须停止并启动泊坞窗服务。

注意: 更改后,您将丢失所有过去的图像,这意味着当您键入docker imagesdocker ps时,您将看不到任何图像/容器。他们将在fileSystem中,他们将占用磁盘空间。因此,您必须手动删除该目录,因此它将位于/var/lib/docker/overlay

答案 1 :(得分:1)

这是你的问题:

Supports d_type: false

你可能面对这个: https://github.com/moby/moby/issues/31283

您需要重新格式化xfs文件系统,如:

mkfs -t xfs -n ftype=1 -f /path/to/device

(我们需要以某种方式使用力量选项)。

更多信息: https://docs.docker.com/engine/userguide/storagedriver/overlayfs-driver/

https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/7.2_Release_Notes/technology-preview-file_systems.html

答案 2 :(得分:0)

哇,你解决了我的问题。

Removing intermediate container 7563494fcca4
 ---> c277a4f8cb76
Step 3/5 : RUN rm -rf /var/jenkins_home
 ---> Running in 09b23bc50939
rm: cannot remove '/var/jenkins_home': Permission denied
The command '/bin/sh -c rm -rf /var/jenkins_home' returned a non-zero code: 1

然后

Step 3/5 : RUN rm -rf /var/jenkins_home/*
 ---> Using cache
 ---> fda46f6a9d2e

答案 3 :(得分:-2)

我相信这是docker的一个已知问题。

您可以尝试以下方法作为解决方法:

RUN  rm -Rf /INSTALLATION/*