ssh/README.md

129 lines
2.8 KiB
Markdown
Raw Normal View History

# 🚀 SSH for GitHub Actions
2019-05-14 18:31:53 +02:00
[GitHub Action](https://developer.github.com/actions/) for executing remote ssh commands.
2019-09-29 05:09:26 +02:00
![ssh workflow](./images/ssh-workflow.png)
[![Actions Status](https://github.com/appleboy/ssh-action/workflows/remote%20ssh%20command/badge.svg)](https://github.com/appleboy/ssh-action/actions)
## Usage
Executing remote ssh commands.
2019-09-29 05:09:26 +02:00
```yaml
- name: executing remote ssh commands using password
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
password: ${{ secrets.PASSWORD }}
port: ${{ secrets.PORT }}
script: whoami
```
2019-09-29 05:09:26 +02:00
output:
```sh
======CMD======
whoami
======END======
out: ***
==========================================
Successfully executed commands to all host.
==========================================
```
2019-09-29 05:09:26 +02:00
## Input variables
2019-09-29 05:09:26 +02:00
see the [action.yml](./action.yml) file for more detail imformation.
2019-05-15 00:47:53 +02:00
2019-09-29 05:09:26 +02:00
* host - scp remote host
* port - scp remote port
* username - scp username
* password - scp password
* timeout - timeout for ssh to remote host, default is `30s`
* command_timeout - timeout for scp command, default is `1m`
* key - content of ssh private key. ex raw content of ~/.ssh/id_rsa
* key_path - path of ssh private key
* script - execute commands
* script_stop - stop script after first failure
* envs - pass environment variable to shell script
* debug - enable debug mode
2019-05-15 00:47:53 +02:00
2019-09-29 05:09:26 +02:00
### Example
2019-05-15 00:47:53 +02:00
2019-09-29 05:09:26 +02:00
Executing remote ssh commands using password.
```yaml
- name: executing remote ssh commands using password
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
password: ${{ secrets.PASSWORD }}
port: ${{ secrets.PORT }}
2019-09-29 05:45:42 +02:00
script: whoami
2019-05-15 00:47:53 +02:00
```
Using private key
2019-09-29 05:09:26 +02:00
```yaml
- name: executing remote ssh commands using ssh key
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
key: ${{ secrets.KEY }}
port: ${{ secrets.PORT }}
script: whoami
2019-05-15 00:47:53 +02:00
```
2019-05-15 00:52:59 +02:00
Multiple Commands
2019-09-29 05:09:26 +02:00
```yaml
- name: multiple command
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
key: ${{ secrets.KEY }}
port: ${{ secrets.PORT }}
script: |
whoami
ls -al
2019-05-15 00:52:59 +02:00
```
2019-09-29 05:09:26 +02:00
![result](./images/output-result.png)
2019-05-15 00:59:18 +02:00
2019-05-15 01:13:49 +02:00
Multiple Hosts
2019-09-29 05:09:26 +02:00
```diff
uses: appleboy/ssh-action@master
with:
- host: "foo.com"
+ host: "foo.com,bar.com"
username: ${{ secrets.USERNAME }}
key: ${{ secrets.KEY }}
port: ${{ secrets.PORT }}
script: |
whoami
ls -al
2019-05-15 01:13:49 +02:00
```
Pass environment variable to shell script
```diff
uses: appleboy/ssh-action@master
+ env:
+ FOO: "BAR"
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
key: ${{ secrets.KEY }}
port: ${{ secrets.PORT }}
+ envs: FOO
script: |
echo "I am $FOO"
echo "I am $BAR"
```