mirror of
https://gitee.com/jack_whh/SFTP-Deploy-Action.git
synced 2026-03-10 07:22:54 +08:00
Compare commits
21 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
dcd5527d19 | ||
|
|
9e32c074c6 | ||
|
|
527eabc0b7 | ||
|
|
90843aab03 | ||
|
|
6009d21da7 | ||
|
|
6ed6f6ca38 | ||
|
|
34d9c5f647 | ||
|
|
89e97d73f9 | ||
|
|
675755b272 | ||
|
|
067de34294 | ||
|
|
834e1ad841 | ||
|
|
259119b427 | ||
|
|
f944ea4c67 | ||
|
|
7589349f24 | ||
|
|
da88a4dbe9 | ||
|
|
e57406ff6c | ||
|
|
6596a6c48c | ||
|
|
33436f92f1 | ||
|
|
3586e619fa | ||
|
|
8392b571c7 | ||
|
|
00c712f732 |
23
.github/workflows/main.yml
vendored
Normal file
23
.github/workflows/main.yml
vendored
Normal file
@@ -0,0 +1,23 @@
|
||||
name: Continuous Deploy
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: sftp
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
|
||||
- name: deploy file to server
|
||||
uses: ./ # Uses an action in the root directory
|
||||
with:
|
||||
username: 'wl'
|
||||
server: '${{ secrets.MAC_IP }}'
|
||||
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
local_path: './*'
|
||||
remote_path: '/Users/wl/Downloads/t/a'
|
||||
sftpArgs: '-o ConnectTimeout=5'
|
||||
# sftp_only: true
|
||||
password: ${{secrets.SSH_PASSWORD}}
|
||||
# delete_remote_files: true
|
||||
@@ -1,5 +1,8 @@
|
||||
# Container image that runs your code
|
||||
FROM alpine:3.10
|
||||
FROM alpine:3.13
|
||||
|
||||
RUN echo "http://mirrors.aliyun.com/alpine/v3.13/main" > /etc/apk/repositories
|
||||
RUN echo "http://mirrors.aliyun.com/alpine/v3.13/community" >> /etc/apk/repositories
|
||||
|
||||
# Copies your code file from your action repository to the filesystem path `/` of the container
|
||||
COPY entrypoint.sh /entrypoint.sh
|
||||
@@ -12,4 +15,4 @@ RUN apk add --no-cache openssh
|
||||
|
||||
|
||||
# Code file to execute when the docker container starts up (`entrypoint.sh`)
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
|
||||
221
README.md
221
README.md
@@ -2,136 +2,113 @@
|
||||
|
||||
> Use this action to deploy your files to server using `SSH Private Key`
|
||||
|
||||
> 使用此`action`部署你的项目到服务器上,`仅支持密钥对连接`
|
||||
> 使用此`action`部署你的项目到服务器上,中文介绍链接:[使用Github Action 部署项目到云服务器](https://zhuanlan.zhihu.com/p/107545396)
|
||||
|
||||
> [使用Github Action 部署项目到云服务器](https://zhuanlan.zhihu.com/p/107545396)
|
||||
## 1. Inputs
|
||||
|
||||
| Name | Required | Default | Description |
|
||||
|------------------------|----------------------|---------|-----------------------------------------------|
|
||||
`username` | yes| | SSH username
|
||||
`server` | yes| | Remote host
|
||||
`port`| yes | 22 | Remote host port
|
||||
`ssh_private_key`| no| | You can copy private key from your `ssh_private_key` file, and save to`repo/settings/secrets`
|
||||
`local_path`| yes| ./* | `local_path` of you project, if you want put single file:use path like `./myfile`, if you want put directory: use path like `./static/*`, it will put all files under `static` directory. Default to `./*`(will put all files in your repo).
|
||||
`remote_path`|yes|| Remote path
|
||||
`sftp_only`| no| | If your port only accepts the sftp protocol, set this option to `true`. However, please note that when this option is set to `true`, the remote folder will not be created automatically.
|
||||
<strike>args</strike> `sftpArgs` | no| | other args yor want to use of sftp, E.g.`-o ConnectTimeout=5`
|
||||
`delete_remote_files` | no | false | Set to `true` will delete remote path folder and all files in it.
|
||||
`password`| no| | SSH passsword,If a password is set, `ssh_private_key` is ignored. `for @v1.2.4 and greater`
|
||||
|
||||
> **Warning**
|
||||
|
||||
> Be careful when use `delete_remote_files`, This will delete remote path folder and all files in it
|
||||
|
||||
-----
|
||||
|
||||
## 2.Action Examples
|
||||
|
||||
```yaml
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: deploy
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: deploy file
|
||||
uses: wlixcc/SFTP-Deploy-Action@v1.2.4
|
||||
with:
|
||||
username: 'root'
|
||||
server: 'your server ip'
|
||||
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
local_path: './static/*'
|
||||
remote_path: '/var/www/app'
|
||||
sftpArgs: '-o ConnectTimeout=5'
|
||||
```
|
||||
|
||||
```yaml
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: deploy
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: Deploy file
|
||||
uses: wlixcc/SFTP-Deploy-Action@v1.2.4
|
||||
with:
|
||||
username: ${{ secrets.FTP_USERNAME }}
|
||||
server: ${{ secrets.FTP_SERVER }}
|
||||
port: ${{ secrets.FTP_PORT }}
|
||||
local_path: './static/*'
|
||||
remote_path: '/var/www/app'
|
||||
sftp_only: true
|
||||
password: ${{ secrets.FTP_PASSWORD }}
|
||||
```
|
||||
|
||||
## 3. [Deploy React App Example](https://github.com/wlixcc/React-Deploy)
|
||||
|
||||
|
||||
## Inputs
|
||||
```yaml
|
||||
on: [push]
|
||||
|
||||
### `username`
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: build&deploy
|
||||
steps:
|
||||
# To use this repository's private action, you must check out the repository
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
|
||||
**Required** sftp username.
|
||||
- name: Install Dependencies
|
||||
run: yarn
|
||||
- name: Build
|
||||
run: yarn build
|
||||
|
||||
### `server`
|
||||
- name: deploy file to server
|
||||
uses: wlixcc/SFTP-Deploy-Action@v1.2.4
|
||||
with:
|
||||
username: 'root'
|
||||
server: '${{ secrets.SERVER_IP }}'
|
||||
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
local_path: './build/*'
|
||||
remote_path: '/var/www/react-app'
|
||||
sftpArgs: '-o ConnectTimeout=5'
|
||||
```
|
||||
|
||||
**Required** sftp server address.
|
||||
|
||||
### `port`
|
||||
|
||||
sftp srever port , default `22`
|
||||
|
||||
### `ssh_private_key`
|
||||
|
||||
**Required** you can copy private_key from your `ssh_private_key.pem file`, keep format, and save at`repo/settings/secrets`
|
||||
|
||||
|
||||

|
||||
|
||||
### `local_path`
|
||||
|
||||
**Required** `local_path` of you project, if you want put single file:use path like `./myfile`, if you want put directory: use path like `./static/*`, it will put all files under `static` directory. Default to `./*`(will put all files in your repo).
|
||||
|
||||
### `remote_path`
|
||||
|
||||
**Required** remote_path
|
||||
|
||||
### `sftp_only`
|
||||
|
||||
connection via sftp protocol only, the default value is `false`. If your port only accepts the sftp protocol, set this option to `true`. However, please note that when this option is set to `true`, the remote folder will not be created automatically.
|
||||
|
||||
### `args`
|
||||
args of sftp cmd, E.g.`-o ConnectTimeout=5`
|
||||
|
||||
|
||||
## Action Example
|
||||
|
||||
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: deploy
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: deploy file
|
||||
uses: wlixcc/SFTP-Deploy-Action@v1.0
|
||||
with:
|
||||
username: 'root'
|
||||
server: 'your server ip'
|
||||
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
local_path: './static/*'
|
||||
remote_path: '/var/www/app'
|
||||
args: '-o ConnectTimeout=5'
|
||||
|
||||
## 1. [Deploy React App Example](https://github.com/wlixcc/React-Deploy)
|
||||
|
||||
> If you use nginx, all you need to do is upload the static files to the server after the project is built
|
||||
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: build&deploy
|
||||
steps:
|
||||
# To use this repository's private action, you must check out the repository
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
|
||||
- name: Install Dependencies
|
||||
run: yarn
|
||||
- name: Build
|
||||
run: yarn build
|
||||
|
||||
- name: deploy file to server
|
||||
uses: wlixcc/SFTP-Deploy-Action@v1.0
|
||||
with:
|
||||
username: 'root'
|
||||
server: '${{ secrets.SERVER_IP }}'
|
||||
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
local_path: './build/*'
|
||||
remote_path: '/var/www/react-app'
|
||||
args: '-o ConnectTimeout=5'
|
||||
|
||||

|
||||
|
||||
## 2.Deploy Umi App Example (Ant Design Pro)
|
||||
--------
|
||||
|
||||
name: continuous deployment
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
deploy_job:
|
||||
runs-on: ubuntu-latest
|
||||
name: build&deploy
|
||||
steps:
|
||||
# To use this repository's private action, you must check out the repository
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
|
||||
- name: Install umi
|
||||
run: yarn global add umi
|
||||
|
||||
- name: Install Dependencies
|
||||
run: yarn
|
||||
- name: Build
|
||||
run: yarn build
|
||||
|
||||
- name: deploy file to server
|
||||
uses: wlixcc/SFTP-Deploy-Action@v1.0
|
||||
with:
|
||||
username: 'root'
|
||||
server: '${{ secrets.SERVER_IP }}'
|
||||
ssh_private_key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
local_path: './dist/*'
|
||||
remote_path: '/var/www/umiapp'
|
||||
args: '-o ConnectTimeout=5'
|
||||

|
||||
|
||||
## 4.Invalid format? You need keep format
|
||||
|
||||
|
||||
|
||||
|
||||
If you use the Ed25519 algorithm to generate an SSH key pair `ssh-keygen -t ed25519 -C "your_email@example.com"`,
|
||||
you need to note that the last line of the private key is a blank line. You need to keep this line when adding Repository secrets, otherwise it may lead to an `invalid format` error.
|
||||

|
||||
|
||||
|
||||
15
action.yml
15
action.yml
@@ -22,15 +22,20 @@ inputs:
|
||||
remote_path:
|
||||
description: 'files will copy to under remote_path'
|
||||
required: true
|
||||
default: /
|
||||
sftp_only:
|
||||
description: 'connection via sftp protocol only'
|
||||
required: false
|
||||
default: false
|
||||
|
||||
args:
|
||||
sftpArgs:
|
||||
description: 'sftp args'
|
||||
required: false
|
||||
delete_remote_files:
|
||||
description: 'This operation will delete all files in the remote path before upload. Please be careful set this to true'
|
||||
required: false
|
||||
default: false
|
||||
password:
|
||||
description: "SSH passsword,If a password is set, the secret key pair is ignored"
|
||||
required: false
|
||||
|
||||
|
||||
runs:
|
||||
@@ -44,7 +49,9 @@ runs:
|
||||
- ${{ inputs.local_path }}
|
||||
- ${{ inputs.remote_path }}
|
||||
- ${{ inputs.sftp_only }}
|
||||
- ${{ inputs.args }}
|
||||
- ${{ inputs.sftpArgs }}
|
||||
- ${{ inputs.delete_remote_files }}
|
||||
- ${{ inputs.password }}
|
||||
|
||||
branding:
|
||||
icon: 'upload-cloud'
|
||||
|
||||
@@ -3,29 +3,67 @@
|
||||
#set -e at the top of your script will make the script exit with an error whenever an error occurs (and is not explicitly handled)
|
||||
set -eu
|
||||
|
||||
|
||||
TEMP_SSH_PRIVATE_KEY_FILE='../private_key.pem'
|
||||
TEMP_SSH_PRIVATE_KEY_FILE='../private_wdhcr.pem'
|
||||
TEMP_SFTP_FILE='../sftp'
|
||||
|
||||
# make sure remote path is not empty
|
||||
if [ -z "$6" ]; then
|
||||
echo 'remote_path is empty'
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# use password
|
||||
if [ -z != ${10} ]; then
|
||||
echo 'use sshpass'
|
||||
apk add sshpass
|
||||
|
||||
if test $9 == "true";then
|
||||
echo 'Start delete remote files'
|
||||
sshpass -p ${10} ssh -o StrictHostKeyChecking=no -p $3 $1@$2 rm -rf $6
|
||||
fi
|
||||
if test $7 = "true"; then
|
||||
echo "Connection via sftp protocol only, skip the command to create a directory"
|
||||
else
|
||||
echo 'Create directory if needed'
|
||||
sshpass -p ${10} ssh -o StrictHostKeyChecking=no -p $3 $1@$2 mkdir -p $6
|
||||
fi
|
||||
|
||||
echo 'SFTP Start'
|
||||
# create a temporary file containing sftp commands
|
||||
printf "%s" "put -r $5 $6" >$TEMP_SFTP_FILE
|
||||
#-o StrictHostKeyChecking=no avoid Host key verification failed.
|
||||
SSHPASS=${10} sshpass -e sftp -oBatchMode=no -b $TEMP_SFTP_FILE -P $3 $8 -o StrictHostKeyChecking=no $1@$2
|
||||
|
||||
echo 'Deploy Success'
|
||||
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# keep string format
|
||||
printf "%s" "$4" >$TEMP_SSH_PRIVATE_KEY_FILE
|
||||
echo "-------"
|
||||
cat $TEMP_SSH_PRIVATE_KEY_FILE
|
||||
# avoid Permissions too open
|
||||
chmod 600 $TEMP_SSH_PRIVATE_KEY_FILE
|
||||
|
||||
# delete remote files if needed
|
||||
if test $9 == "true";then
|
||||
echo 'Start delete remote files'
|
||||
ssh -o StrictHostKeyChecking=no -p $3 -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2 rm -rf $6
|
||||
fi
|
||||
|
||||
if test $7 = "true"; then
|
||||
echo "Connection via sftp protocol only, skip the command to create a directory"
|
||||
else
|
||||
echo 'ssh start'
|
||||
|
||||
echo 'Create directory if needed'
|
||||
ssh -o StrictHostKeyChecking=no -p $3 -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2 mkdir -p $6
|
||||
fi
|
||||
|
||||
echo 'sftp start'
|
||||
echo 'SFTP Start'
|
||||
# create a temporary file containing sftp commands
|
||||
printf "%s" "put -r $5 $6" >$TEMP_SFTP_FILE
|
||||
#-o StrictHostKeyChecking=no avoid Host key verification failed.
|
||||
sftp -b $TEMP_SFTP_FILE -P $3 $8 -o StrictHostKeyChecking=no -i $TEMP_SSH_PRIVATE_KEY_FILE $1@$2
|
||||
|
||||
echo 'deploy success'
|
||||
echo 'Deploy Success'
|
||||
exit 0
|
||||
|
||||
|
||||
BIN
resource/keepformat.jpg
Normal file
BIN
resource/keepformat.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 54 KiB |
Reference in New Issue
Block a user