嵌套文件夹中带有 cloudbuild.yaml 的 Cloud Build - 构建失败

Cloud Build w/ cloudbuild.yaml in nested folder - build fails

我正在尝试将项目的一部分自动化,我会理想地部署并忘记这些部分。该项目由一个 XML 解析器和一个小型 Flask 网站组成。目前文件夹结构如下所示:

.
├── init.sql
└── parser
    ├── cloudbuild.yaml
    ├── cloud_func
    │   └── main.py
    ├── Dockerfile
    ├── feed_parse.py
    ├── get_so.py
    ├── requirements.txt
    └── utils.py

现在,我可以正确设置触发器来查看 /parser/cloudbuild.yaml,但是使用以下命令构建图像会引发错误:

build . --build-arg "CLIENT_CERT=$CSQL_CERT CLIENT_KEY=$CSQL_KEY SERVER_CA=$CSQL_CA SERVER_PW=$CSQL_PW SERVER_HOST=$CSQL_IP" -t gcr.io/and-reporting/appengine/so-parser:latest
BUILD
Already have image (with digest): gcr.io/cloud-builders/docker
unable to prepare context: unable to evaluate symlinks in Dockerfile path: lstat /workspace/Dockerfile: no such file or directory
ERROR
ERROR: build step 0 "gcr.io/cloud-builders/docker" failed: exit status 1

在我看来,gcp 无法找到我的 Dockerfile,它位于 cloudbuild.yaml 所在的同一文件夹中。
我错过了什么?

为了完整起见,Dockerfile 如下所示:

FROM python:3.7-alpine

RUN apk update \
  && apk add gcc python3-dev musl-dev libffi-dev \
  && apk del libressl-dev \
  && apk add openssl-dev

COPY requirements.txt /
RUN pip install --upgrade pip
RUN pip install --no-cache-dir -r requirements.txt

ADD . /parser
WORKDIR /parser/
RUN mkdir -p certs

# Set env variables from secrets 
ARG CLIENT_CERT
ENV CSQL_CERT=${CLIENT_CERT}

ARG CLIENT_KEY
ENV CSQL_KEY=${CLIENT_KEY}

ARG SERVER_CA
ENV CSQL_CA=${SERVER_CA}

ARG SERVER_PW
ENV CSQL_PW=${SERVER_PW}

ARG SERVER_HOST
ENV CSQL_IP=${SERVER_HOST}

# Get ssl certs in files
RUN echo $CLIENT_CERT > ./certs/ssl_cert.pem \
  && echo $CLIENT_KEY > ./certs/ssl_key.pem \
  && echo $SERVER_CA > ./certs/ssl_ca.pem

CMD python get_so.py

编辑:以及我用于构建的cloudbuild.yaml

steps:

# Building image
- name: 'gcr.io/cloud-builders/docker'
  args: [
     'build',
     '-f',
     'Dockerfile',
     '--build-arg',
     'CLIENT_CERT=$$CSQL_CERT CLIENT_KEY=$$CSQL_KEY SERVER_CA=$$CSQL_CA SERVER_PW=$$CSQL_PW SERVER_HOST=$$CSQL_IP',
     '-t',
     'gcr.io/$PROJECT_ID/appengine/so-parser:latest',
     '.'
  ]
  secretEnv: ['CSQL_CERT', 'CSQL_KEY', 'CSQL_CA', 'CSQL_PW', 'CSQL_IP']     

# Push Images       
# - name: 'gcr.io/cloud-builders/docker'
#   args: ['push', 'gcr.io/$PROJECT_ID/appengine/so-parser:latest']

secrets:
- kmsKeyName: projects/myproject/locations/global/keyRings/so-jobs/cryptoKeys/board
  secretEnv:
   CSQL_CERT: [base64 string] 
   CSQL_KEY: [base64 string] 
   CSQL_CA: [base64 string] 
   CSQL_PW: [base64 string] 
   CSQL_IP: [base64 string] 

由于 cloudbuild.yaml 文件中的点,docker 无法找到 parser 目录中的 Dockerfile

steps:

- name: "gcr.io/cloud-builders/docker"

  args: ["build", "-t", "gcr.io/$PROJECT_ID/mynodejs:$SHORT_SHA", "./parser"]

如果要提及dockerfile名称: 步骤:

- name: "gcr.io/cloud-builders/docker"

  args: ["build", "-t", "gcr.io/$PROJECT_ID/mynodejs:$SHORT_SHA", "-f", "./parser/your-dockerfile"]