Git :使用 actions/checkout@v2 而不是 appleboy/ssh-action@master 将存储库克隆到服务器

Git : Using actions/checkout@v2 instead of appleboy/ssh-action@master to clone repository to a server

我正在尝试将存储库从 GitHub 克隆到远程服务器。

我使用 appleboy/ssh-action GitHub 操作的解决方案有效,但我被告知可以使用 actions/checkout@v2 GitHub 行动。 我试图将 - uses: 值更改为 actions/checkout@V2` 但是代码不起作用。

我找不到任何关于如何使用 actions/checkout@v2 进行操作的模板。任何建议将不胜感激。

name: deploy to a server on push

on:
  push:
    branches: [ master ]

jobs:
  deploy-to-server:
    runs-on: ubuntu-latest
    steps:

  - uses: appleboy/ssh-action@master 
    with:
      host: 123.132.123.132
      username: tomas
      key: ${{ secrets.PRIVATE_KEY }}
      port: 59666
      script:
        git clone https://github.com/Tomas-R/website.git

正如 actions/checkout@v2 的文档所述

This action checks-out your repository under $GITHUB_WORKSPACE, so your workflow can access it.

   steps:
      - name: Checkout the repo
        uses: actions/checkout@v2
        with: 
          # This will create a directory named `my-repo` and copy the repo contents to it
          # so that you can easily upload it to your remote server
          path: my-repo

要将这个签出的 repo 复制到远程服务器,您可以使用 scp 命令如下。

   # Runs a set of commands using the runners shell
     - name: Upload repo to remote server
       env:
           SSH_AUTH_SOCK: /tmp/ssh_agent.sock
       run: |
         ssh-agent -a $SSH_AUTH_SOCK > /dev/null
         ssh-add - <<< "${{ secrets.PRIVATE_KEY }}"
         scp -o StrictHostKeyChecking=no -r -P 59666 my-repo tomas@123.132.123.132:/target/directory

通过使用上述命令,我们

  • 启动 ssh-agent 并将其绑定到已知位置。
  • 将私钥从 secret 导入到 ssh-agent。
  • 将内容从 my-repo 复制到远程服务器上的目标目录。

这样,私钥永​​远不会写入磁盘/被暴露。

还有另一种更简单的方法 运行 scp 使用 Copy via ssh GitHub 操作。

   - name: Copy folder content recursively to remote
     uses: garygrossgarten/github-action-scp@release
     with:
       local: my-repo
       remote: ~/target/directory
       host: 123.132.123.132
       port: 59666
       username: tomas
       privateKey: ${{secrets.PRIVATE_KEY}}