在我的Dockerfile我有:

ADD ../../myapp.war /opt/tomcat7/webapps/

该文件以ls ../../myapp的形式存在。war返回我正确的文件,但当我执行sudo docker构建-t myapp。我有:

Step 1 : ADD ../../myapp.war /opt/tomcat7/webapps/
2014/07/02 19:18:09 ../../myapp.war: no such file or directory

有人知道为什么和如何正确地做吗?


当前回答

如果你正在使用skaffold,使用'context:'为每个图像指定上下文位置dockerfile - context: ../../../

            apiVersion: skaffold/v2beta4
            kind: Config
            metadata:
                name: frontend
            build:
                artifacts:
                    - image: nginx-angular-ui
                      context: ../../../
                      sync:
                          # A local build will update dist and sync it to the container
                          manual:
                              - src: './dist/apps'
                                dest: '/usr/share/nginx/html'
                      docker:
                          dockerfile: ./tools/pipelines/dockerfile/nginx.dev.dockerfile
                    - image: webapi/image
                      context: ../../../../api/
                      docker:
                          dockerfile: ./dockerfile
            deploy:
                kubectl:
                    manifests:
                        - ./.k8s/*.yml

运行-f ./ Skaffold .yaml

其他回答

让设置上下文:../..docker-compose.yml父文件夹中的/ 例:

app:
    build:
      context: ../../
      dockerfile: ./source/docker/dockerfile/Dockerfile

如果你正在使用skaffold,使用'context:'为每个图像指定上下文位置dockerfile - context: ../../../

            apiVersion: skaffold/v2beta4
            kind: Config
            metadata:
                name: frontend
            build:
                artifacts:
                    - image: nginx-angular-ui
                      context: ../../../
                      sync:
                          # A local build will update dist and sync it to the container
                          manual:
                              - src: './dist/apps'
                                dest: '/usr/share/nginx/html'
                      docker:
                          dockerfile: ./tools/pipelines/dockerfile/nginx.dev.dockerfile
                    - image: webapi/image
                      context: ../../../../api/
                      docker:
                          dockerfile: ./dockerfile
            deploy:
                kubectl:
                    manifests:
                        - ./.k8s/*.yml

运行-f ./ Skaffold .yaml

给定以下设置:

+ parent
    + service1
        - some_file.json
    + service2
        - Dockerfile

如果你在service2中有一个Dockerfile,想要复制some_file。你可以在service2目录中运行这个:

Docker build -t my_image ../——file Dockerfile

这将把目标上下文设置在更高的级别上。这里棘手的部分是,目标Dockerfile是显式设置的(因为它不在目标上下文中)。

在service2/Dockerfile中,你必须发出COPY命令,就好像这个文件在上面一个级别:

service1 / some_file副本。json /目标/位置/ some_file.json

而不是

. . / service1 / some_file副本。json /目标/位置/ some_file。Json #将不能工作

从上目录构建img 命名为img 启用适当的卷共享 查看上面链接中的Makefile,了解如何启动容器… Docker构建。-t proj-devops-img——no-cache——build-arg UID=$(shell id -u)——build-arg GID=$(shell id -g) -f src/docker/devops/Dockerfile . t

对于那些使用composer的人来说,解决方案是使用指向父文件夹的卷:

#docker-composer.yml

foo:
  build: foo
  volumes:
    - ./:/src/:ro

但是我很确定可以在Dockerfile中处理卷。