自动化部署练习 github actions
[1.下载练习用的代码](https://gitee.com/lagoufed/fed-e-questions/raw/master/part3/realworld-nuxtjs.zip
2.验证项目代码正常可用
data:image/s3,"s3://crabby-images/7c99c/7c99cbca8b5b91642b8569f1b27269adaed00a04" alt=""
data:image/s3,"s3://crabby-images/bd32b/bd32b78a9312733b40a09fbee823b08844db77b4" alt=""
data:image/s3,"s3://crabby-images/8451d/8451d4aec87d18cadbb07f919561a26a91c7ff74" alt=""
3.生成本地仓库
确认有「.gitignore」文件, 并且 push 时会忽略「node_modules」和「.nuxt」目录
data:image/s3,"s3://crabby-images/50b85/50b85579eff67f47be2687845b1f8ce8864d6141" alt=""
初始化仓库,修改当前分支名称,并生成一个commit提交
data:image/s3,"s3://crabby-images/30c3d/30c3d5122fbc480f7ae7018e22f554a8ab8ceb33" alt=""
git init
git add . && git commit -m "init"
git branch -M main
4.创建 github 仓库, 关联本地库
data:image/s3,"s3://crabby-images/96754/967541c801ed5675879a486b874872ff0e74c5b5" alt=""
data:image/s3,"s3://crabby-images/7dedb/7dedb6429eeb35626c03497da78f8bd6dbf38bac" alt=""
data:image/s3,"s3://crabby-images/8c094/8c094ceee55cd1a3e98811c5672597780d610ac9" alt=""
data:image/s3,"s3://crabby-images/1bc8a/1bc8a5caa789d669a56ad1f00ac844ada31fd906" alt=""
# 关联远程代码库
git remote add origin https://github.com/你账号/realworld-nuxtjs.git
# 查看关联情况
git remote -v
# 把当前代码先推一波. 证明没问题
git push origin main
data:image/s3,"s3://crabby-images/1083e/1083e611e905f782af55de54885d8efe6d488f05" alt=""
5.配置 github actions 信息
data:image/s3,"s3://crabby-images/663f9/663f9b1b8ec1aee557351c56ac1a8fa810ecf13c" alt=""
data:image/s3,"s3://crabby-images/d23c7/d23c7ad3cd12b101854b35af6a189f5bf8b5edc7" alt=""
data:image/s3,"s3://crabby-images/3c3a5/3c3a5ac0db1331aa9337989b6c3049d4cc7b94cc" alt=""
data:image/s3,"s3://crabby-images/ce69a/ce69a65451348ec4f750b53b97428f828184dacb" alt=""
data:image/s3,"s3://crabby-images/141e4/141e48dcb3d7eafcf83d916422004ffc375fe1dd" alt=""
data:image/s3,"s3://crabby-images/07c28/07c28a16f11e3f8252b8b4e74c04d4e0ba1523de" alt=""
data:image/s3,"s3://crabby-images/49f83/49f835bcef30807758555f0fda668c5f4c48b42b" alt=""
data:image/s3,"s3://crabby-images/a405d/a405d5f1d516f9f0b9320f4a823926ec4936346d" alt=""
data:image/s3,"s3://crabby-images/fdaca/fdacadc2c2d498758caf2c6f38d02497f018a0cc" alt=""
data:image/s3,"s3://crabby-images/53533/53533d6779141554becc16a8bd1c1a6f75e856a1" alt=""
data:image/s3,"s3://crabby-images/1dfae/1dfaeaa35d173a2145c5974e41a0cc0b731367d3" alt=""
data:image/s3,"s3://crabby-images/ea354/ea35406d0a3535040adac1e361dd04e66b33f035" alt=""
data:image/s3,"s3://crabby-images/c2d2c/c2d2c62e310b8b74189a5c191a586ad28301e2d5" alt=""
data:image/s3,"s3://crabby-images/3f0f3/3f0f3f96c918b06d49f4c9adcc92453aff3581f5" alt=""
data:image/s3,"s3://crabby-images/4b11a/4b11a80f0efabe72ef84422fad7ae26a71032222" alt=""
6.编辑 workflows 脚本
打开项目根目录 .github / workflows / main.yml 文件
data:image/s3,"s3://crabby-images/30d00/30d0029982b6c5296ca1edf78d7b31c7579a6164" alt=""
(以下是 main.yml参考内容)
name: Publish And Deploy Demo
on:
push:
tags:
- 'v*'
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
# 下载源码
- name: Checkout
uses: actions/checkout@master
# 打包构建
- name: Build
uses: actions/setup-node@master
- run: npm install
- run: npm run build
- run: tar -zcvf release.tgz .nuxt static nuxt.config.js package.json package-lock.json pm2.config.json
# 发布 Release
- name: Create Release
id: create_release
uses: actions/create-release@master
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
with:
tag_name: ${{ github.ref }}
release_name: Release ${{ github.ref }}
draft: false
prerelease: false
# 上传构建结果到 Release
- name: Upload Release Asset
id: upload-release-asset
uses: actions/upload-release-asset@master
env:
GITHUB_TOKEN: ${{ secrets.TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./release.tgz
asset_name: release.tgz
asset_content_type: application/x-tgz
# 部署到服务器
- name: Deploy
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
password: ${{ secrets.PASSWORD }}
port: ${{ secrets.PORT }}
script: |
cd /usr/local/xlf-realworld-nuxtjs
wget https://github.com/xionglaifu/xlf-realworld-nuxtjs/releases/latest/download/release.tgz -O release.tgz
tar zxvf release.tgz
npm install --production
pm2 reload pm2.config.json
『一定要修改 倒数第4行 仓库地址』
编辑 PM2 配置文件
pm2.config.json (练习中已包含该文件)
{
"apps": [
{
"name": "RealWorld",
"script": "npm",
"args": "start"
}
]
}
注意:
- 不要少写 s
- 少数命令可以不写 run, 多数命令都是 npm run xxxx
7.完成测试
data:image/s3,"s3://crabby-images/f6043/f6043fa8c9be748f097c9eb5229b019e6dd872fc" alt=""
data:image/s3,"s3://crabby-images/6bbe9/6bbe96df96d9d3778c8bc682c8475580dd2bd8e1" alt=""
git add .
git commit -m "发布部署-测试"
git tag v0.1.0
git tag
git push origin v0.1.0
data:image/s3,"s3://crabby-images/bb333/bb33384717adc2e407fef75e0083497809331b97" alt=""
data:image/s3,"s3://crabby-images/28e85/28e85e91c8f6e0edbaa660141019a8fd06376dda" alt=""
data:image/s3,"s3://crabby-images/2e37f/2e37faf42ed46da8cdd65484b1f8d0d1119ae9b4" alt=""
( 打完收工 )
网友评论