繁体   English   中英

GitHub -> GCP,在 shell 脚本中使用 gcloud 命令

[英]GitHub -> GCP, use gcloud commands inside shell script

我在 GitHub 中有一个工作流,它将执行 shell 脚本,在这个脚本中我需要使用 gsutil

在我的工作流程 yml 文件中,我有以下步骤:

name: Dummy Script
on:
  workflow_dispatch:

jobs:
  build:
    runs-on: ubuntu-latest
    environment: alfa    
    env:
      _PROJECT_ID: my-project
    steps:
    - uses: actions/checkout@v2
    - name: Set up Cloud SDK for ${{env._PROJECT_ID}}
      uses: google-github-actions/setup-gcloud@master
      with:
        project_id: ${{env._PROJECT_ID}}
        service_account_key: ${{ secrets.SA_ALFA }}
        export_default_credentials: true
    - run: gcloud projects list
    - name: Run script.sh
      run: |
        path="${GITHUB_WORKSPACE}/script.sh"
        chmod +x $path
        sudo $path 
      shell: bash

脚本如下所示:

#!/bin/bash
apt-get update -y
gcloud projects list

yml 中的第二步(运行:gcloud 项目列表)按预期工作,列出 SA_USER 有权访问的项目。

但是在步骤 3 中运行脚本时,我得到以下 output:

WARNING: Could not open the configuration file: [/root/.config/gcloud/configurations/config_default].
ERROR: (gcloud.projects.list) You do not currently have an active account selected.
Please run:

  $ gcloud auth login

to obtain new credentials.

If you have already logged in with a different account:

    $ gcloud config set account ACCOUNT

to select an already authenticated account to use.
Error: Process completed with exit code 1.

所以我的问题是:如何运行 shell 脚本文件并传递我对服务帐户的身份验证,以便我可以从脚本文件运行 gcloud 命令?

由于某些原因,要求脚本文件应该能够在开发人员计算机上本地运行,并且来自 GitHub。

问题似乎是使用sudo运行时没有继承环境变量。 有很多方法可以解决这个问题,但我能够确认它可以使用sudo -E运行。 当然,如果你不需要运行sudo ,你应该删除它,但我想这是必要的。

在此处输入图像描述

(复制代码对我来说很容易复制。谢谢)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM