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}}
我正在尝试将存储库从 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}}