您不能保存变量供以后在其他
Dockerfile命令中使用(如果您打算这样做)。这是因为每种
RUN情况都发生在新的外壳中。
但是,如果只想捕获输出,则
ls应该可以在一个
RUN复合命令中完成它。例如:
RUN file="$(ls -1 /tmp/dir)" && echo $file
或者只是使用subshell内联:
RUN echo $(ls -1 /tmp/dir)
希望这有助于您的理解。如果您要解决实际的错误或问题,我可以在此范围内进行扩展,而不是假设的答案。
一个完整的例子
Dockerfile证明了这一点:
FROM alpine:3.7RUN mkdir -p /tmp/dir && touch /tmp/dir/file1 /tmp//dir/file2RUN file="$(ls -1 /tmp/dir)" && echo $fileRUN echo $(ls -1 /tmp/dir)
当建立你应该看到步骤3和4输出的变量(它包含的列表
file1和
file2在步骤2中创建):
$ docker build --no-cache -t test .Sending build context to Docker daemon 2.048kBStep 1/4 : FROM alpine:3.7 ---> 3fd9065eaf02Step 2/4 : RUN mkdir -p /tmp/dir && touch /tmp/dir/file1 /tmp//dir/file2 ---> Running in abb2fe683e82Removing intermediate container abb2fe683e82 ---> 2f6dfca9385cStep 3/4 : RUN file="$(ls -1 /tmp/dir)" && echo $file ---> Running in 060a285e3d8afile1 file2Removing intermediate container 060a285e3d8a ---> 2e4cc2873b8cStep 4/4 : RUN echo $(ls -1 /tmp/dir) ---> Running in 528fc5d6c721file1 file2Removing intermediate container 528fc5d6c721 ---> 1be7c54e1f29Successfully built 1be7c54e1f29Successfully tagged test:latest
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)