gpt4 book ai didi

image - Docker 构建在 mkdir 上失败

转载 作者:行者123 更新时间:2023-12-02 18:04:05 26 4
gpt4 key购买 nike

我使用 Dockerfile 创建 apache2 ubuntu 镜像。当它必须创建目录时,它会说其中一些目录已经存在,但实际上根本不存在。
Dockerfile:

FROM ubuntu:latest
MAINTAINER Bernard Tapis
RUN apt-get -yqq update && apt-get install -yqq apache2

WORKDIR /var/www/html

ENV APACHE_RUN_USER www-data
ENV APACHE_RUN_GROUP www-data
ENV APACHE_LOG_DIR /var/log/apache2
ENV APACHE_PID_FILE /var/run/apache2.pid
ENV APACHE_RUN_DIR /var/run/apache2
ENV APACHE_LOCK_DIR /var/lock/apache2
RUN mkdir p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIR

ENTRYPOINT ["/usr/sbin/apache2"]
CMD ["-D", "FOREGROUND"]
EXPOSE 80

执行 docker image build -t quentinneves/apache . 时出现的错误
Step 11/14 : RUN mkdir p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIR
---> Running in 1d72a8fd64c0
mkdir: cannot create directory '/var/log/apache2': File exists
The command '/bin/sh -c mkdir p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIR' returned a non-zero code: 1

但是当我使用 ls -lsa /var/log/ :
root@VIR1-DOCKER:~/Docker/Apache# ls -lsa /var/log/
total 1576
4 drwxr-xr-x 5 root root 4096 Jun 1 13:42 .
4 drwxr-xr-x 11 root root 4096 Jun 1 13:35 ..
16 -rw-r--r-- 1 root root 13515 Jun 13 07:33 alternatives.log
4 drwxr-xr-x 2 root root 4096 Jun 13 07:33 apt
12 -rw-r----- 1 root adm 8773 Jun 6 15:17 auth.log
4 -rw------- 1 root utmp 768 Jun 6 07:06 btmp
76 -rw-r----- 1 root adm 70771 Jun 13 08:05 daemon.log
108 -rw-r----- 1 root adm 107936 Jun 6 07:05 debug
268 -rw-r--r-- 1 root root 269141 Jun 13 07:33 dpkg.log
8 -rw-r--r-- 1 root root 32032 Jun 6 07:05 faillog
4 drwxr-xr-x 3 root root 4096 Jun 1 13:39 installer
356 -rw-r----- 1 root adm 363005 Jun 13 08:05 kern.log
12 -rw-rw-r-- 1 root utmp 292292 Jun 6 15:09 lastlog
252 -rw-r----- 1 root adm 255033 Jun 13 08:05 messages
428 -rw-r----- 1 root adm 435499 Jun 13 08:05 syslog
4 drwxr-x--- 2 root adm 4096 Jun 6 07:01 unattended-upgrades
16 -rw-rw-r-- 1 root utmp 15744 Jun 6 15:10 wtmp

惊讶它不在那里!在此之前是 /var/lock/apache2这导致了这个问题,但它以某种方式通过了,现在 /var/log/apache2只是不会被创建。

如果我删除此文件夹创建并手动创建它,它是否适用于为 docker 创建新图像?你知道为什么它认为已经有一个这样的文件夹吗?

最佳答案

您的问题是您正在创建目录而没有保护它们已经存在。

你已经定义了 APACHE_LOG_DIR = APACHE_RUN_DIR,所以,你的 RUN mkdir p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIR命令尝试创建它两次,但它失败了。

当您检查目录是否存在时,您可能正在访问从另一个图像启动的容器,而不是您尝试使用此 docker 构建的图像。

为了保护它,添加 exit 0RUN mkdir 结尾,或更改一个 ENV:

ENV APACHE_LOG_DIR /var/log/apache2
ENV APACHE_PID_FILE /var/run/apache2.pid
ENV APACHE_RUN_DIR /var/run/apache2 <--- the same than APACHE_LOG_DIR
ENV APACHE_LOCK_DIR /var/lock/apache2
RUN mkdir p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIR; exit 0

关于image - Docker 构建在 mkdir 上失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50831244/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com