$ docker build -t testx /home/nick/hc
docker 客户端会把上下文中的所有文件发送给 docker daemon。考虑 docker 客户端和 docker daemon 不在同一台机器上的情况,build 命令只能从上下文中获取文件。如果我们在 Dockerfile 的 COPY 和 ADD 命令中引用了上下文中没有的文件,就会收到类似下面的错误:
WORKDIR /
COPY check* /testdir/?.log /testdir/ # ? 是单个字符的占位符,比如匹配文件 check1.log
只复制目录中的内容而不包含目录自身。比如我们在 Dockerfile 中添加下面的命令:
WORKDIR /
WORKDIR /./nickdir
COPY 命令区别于 ADD 命令的一个用法是在 multistage 场景下。关于 multistage 的介绍和用法请参考笔者的《》一文。在 multistage 的用法中,可以使用 COPY 命令把前一阶段构建的产物拷贝到另一个镜像中,比如:
FROM golang:./go/src/github.com/sparkdevo/href-counter/-d -v golang.org/x/net/= GOOS=linux go build -a -installsuffix cgo -FROM alpine:latest
RUN apk --no-cache add ca-<span style="color: #000000">certificates
WORKDIR /root/<span style="color: #ff0000">
COPY --from=0 /go/src/github.com/sparkdevo/href-counter/<span style="color: #000000"><span style="color: #ff0000">app .
CMD [<span style="color: #800000">"<span style="color: #800000">./app<span style="color: #800000">"]
RUN apk --no-cache add ca-<span style="color: #000000">certificates
WORKDIR /root/<span style="color: #ff0000">
COPY --from=0 /go/src/github.com/sparkdevo/href-counter/<span style="color: #000000"><span style="color: #ff0000">app .
CMD [<span style="color: #800000">"<span style="color: #800000">./app<span style="color: #800000">"]
》一文,其中的 COPY 命令通过指定 --from=0 参数,把前一阶段构建的产物拷贝到了当前的镜像中。
WORKDIR /.gz .
中却强烈建议不要这么用!!docker 官方建议我们当需要从远程复制文件时,最好使用 curl 或 wget 命令来代替 ADD 命令。原因是,当使用 ADD 命令时,会创建更多的镜像层,当然镜像的 size 也会更大(下面的两段代码来自 docker 官方文档):
ADD http:
RUN -xJf /usr/src/things/big..xz -C /usr/src/ -C /usr/src/things all
RUN -p /usr/src/&& curl -SL http:
| -xJC /usr/src/&& -C /usr/src/things all
WORKDIR /* ./