部署到AWS S3与github同步

Md *_*lam 2 amazon-s3 amazon-web-services amazon-cloudfront webpack github-actions

我正在尝试使用 github 操作将静态站点部署到 AWS S3 和 Cloudfront。我的 Github Action 代码是:

name: deploy-container

on:
  push:
    branches:
      - master
    paths:
      - 'packages/container/**'

defaults:
  run:
    working-directory: packages/container

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v2
      - run: npm install
      - run: npm run build

      - uses: chrislennon/action-aws-cli@v1.1
      - run: aws s3 sync dist s3://${{secrets.AWS_S3_BUCKET_NAME}}/container/latest
        env:
          AWS_ACCESS_KEY_ID: ${{secrets.AWS_ACCESS_KEY_ID}}
          AWS_SECRET_ACCESS_KEY: ${{secrets.AWS_SECRET_ACCESS_KEY}}
Run Code Online (Sandbox Code Playgroud)

但是当我尝试构建时出现了这些错误

Github 操作 1 Github 操作 2

小智 8

仅当您对应用程序目录内的文件进行了一些更改时,GitHub 才会重新部署您的应用程序。我想您只更改了 yml 文件并尝试在 GitHub 上重新运行该作业。但从错误消息来看,这是使用标签ACTIONS_ALLOW_UNSECURE_COMMANDS的不安全方法。最好考虑使用官方 AWS for GitHub Actions,而不是使用 ACTIONS_ALLOW_UNSECURE_COMMANDS。

name: deploy-container

on:
  push:
    branches:
      - master
    paths:
      - 'packages/container/**'

defaults:
  run:
    working-directory: packages/container

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v2
      - run: npm install
      - run: npm run build

      - name: Configure AWS Credentials
        uses: aws-actions/configure-aws-credentials@v1
        with:
          aws-access-key-id: ${{ secrets. AWS_ACCESS_KEY_ID }}
          aws-secret-access-key: ${{ secrets. AWS_SECRET_ACCESS_KEY }}
          aws-region: us-west-1

      - name: Copy files to the s3 website content bucket
        run:
          aws s3 sync dist s3://${{ secrets.AWS_S3_BUCKET_NAME }}/container/latest
Run Code Online (Sandbox Code Playgroud)