使用GitHub Actions实现Git推送自动部署到服务器

devtools/2025/3/19 22:54:14/
将网站一键部署到服务器的方案很多,比如纯Shell脚本结合SSH、Jenkins等工具。本文将介绍如何利用GitHub Actions这一免费且轻量的CI/CD工具,实现代码推送后自动部署到云服务器

image-20250314144041545

之前一直在使用github>github的工作流,确实是一个比较好用的工具。

我之前用来构建公开静态文件仓库,让vercel来管理静态网站,这次我把所有的服务都迁移到了云服务器,所以所有的部署都需要重新调整一下。

还是老样子,先介绍一下我的场景和配置。

前置条件

  • 项目类型: 静态网站(示例使用Hexo)

  • 服务器环境: Linux系统(示例为Ubuntu)

服务器配置

1. 创建专用部署用户
# 创建新用户
sudo adduser git --disabled-password
​
# 切换到该用户
sudo su - git
​
# 创建.ssh目录
mkdir -p ~/.ssh && chmod 700 ~/.ssh
2. 生成 SSH 密钥对
# 在服务器生成密钥(也可本地生成后传公钥)
sudo ssh-keygen -t ed25519 -C "github>github-actions-deploy-key" -f ~/.ssh/github>github_actions
3. 配置授权公钥
# 将公钥加入授权列表
sudo sh -c 'cat /home/git/.ssh/github>github_actions.pub >> /home/git/.ssh/authorized_keys'
​
# 设置权限
sudo chmod 600 ~/.ssh/authorized_keys
sudo chmod 644 ~/.ssh/github>github_actions.pub
4. 目标目录权限
# 假设部署目录为 /var/www/blog
sudo mkdir -p /var/www/blog
sudo chown -R deployer:deployer /var/www/blog
5.获取private key
sudo cat ~/.ssh/github>github_actions

正常情况会返回这样的文本:

-----BEGIN OPENSSH PRIVATE KEY-----
-----END OPENSSH PRIVATE KEY-----
6.调整ssh配置
/etc/ssh/sshd_config
# 启用密钥认证
PubkeyAuthentication yes      
# 禁用密码登录
PasswordAuthentication no      
# 允许部署用户
AllowUsers deployer            
sudo systemctl restart ssh
如果遇到权限问题
# 切换到root再执行
chmod 700 ~git/.ssh
chmod 600 ~git/.ssh/authorized_keys
chown -R git:git ~git/.ssh
​
# 最后的路径调整成静态文件路径
sudo chown -R git:git /www/wwwroot
​
sudo setfacl -R -m u:git:rwx /www/wwwroot
sudo setfacl -Rd -m u:git:rwx /www/wwwroot

Github仓库配置

1. 添加仓库密钥

  1. 访问仓库 Settings > Secrets > Actions

  2. 点击 New repository secret

  3. 输入名称 SERVER_SSH_KEY,值粘贴前文获取的私钥内容

2. 配置工作流文件

创建 .github>github/workflows/deploy.yml 内容如下:

name: Deploy Blog  # 工作流名称,显示在Actions面板on: [push]  # 触发条件:任何git push操作jobs:build:   # 任务ID,可自定义runs-on: ubuntu-latest  # 使用GitHub托管的Ubuntu运行器steps:- name: Checkout code  # 步骤1:拉取仓库代码uses: actions/checkout@v4  # 官方检出插件- name: Install and Build  # 步骤2:安装依赖并构建run: |                   # 多行命令执行器npm installnpm run build- name: Deploy to Server  # 步骤3:部署到服务器uses: easingthemes/ssh-deploy@main  # 第三方SSH部署插件env:SSH_PRIVATE_KEY: ${{ secrets.SERVER_SSH_KEY }}  # 从仓库密钥读取私钥REMOTE_HOST: ""  # 服务器公网IP或域名REMOTE_USER: "git"  # 步骤1创建的用户SOURCE: "public/"  # 本地构建输出目录TARGET: "/www/wwwroot/guoshunfa.com"  # 服务器目标目录ARGS: "-avz --chown=git:git"  # rsync参数:归档模式/压缩/删除多余文件

到这所有的配置就结束了。

验证效果

  1. 本地修改后执行Git推送:

    git add .
    git commit -m "触发自动部署"
    git push origin main
  2. 登录GitHub仓库,进入 Actions 标签页查看执行状态

  3. 成功完成后,访问服务器目标目录确认文件更新


http://www.ppmy.cn/devtools/168466.html

相关文章

STM32配套程序接线图

1 工程模板 2 LED闪烁 3LED流水灯 4蜂鸣器 5按键控制LED 6光敏传感器控制蜂鸣器 7OLED显示屏 8对射式红外传感器计次 9旋转编码器计次 10 定时器定时中断 11定时器外部时钟 12PWM驱动LED呼吸灯 13 PWM驱动舵机 14 PWM驱动直流电机 15输入捕获模式测频率 16PWMI模式测频率占空…

《保险科技》

自己在保险行业工作很多年,只是接触了一些数据的内容,对于保险业务的知识了解的很少,想通过这本书补充一下,但是发现这本书就是一些知识的拼接。 先将保险的历史,后讲保险的定义,然后就是吹嘘保险行业和互联…

深入理解Spring Boot:快速构建现代化的Java应用

大家好!今天我们来聊聊Java开发中最流行的框架之一——Spring Boot。Spring Boot是Spring生态系统中的一个重要模块,它旨在简化Spring应用的开发和部署。通过Spring Boot,开发者可以快速构建独立、生产级的应用程序,而无需繁琐的配…

DeepSeek + 药物研发:解决药物研发周期长、成本高-降低80%、失败率高-减少40%

DeepSeek 药物研发:解决药物研发周期长、成本高-降低80%、失败率高-减少40% 论文大纲1. WHY —— 研究背景与现实问题1.1 研究要解决的现实问题与提出背景1.2 研究所要解决的问题类别1.3 正反例对比关联:和前人的工作有什么关系? 3. &#x…

洛谷 P3986 斐波那契数列

P3986 斐波那契数列 题目描述 定义一个数列: f ( 0 ) a , f ( 1 ) b , f ( n ) f ( n − 1 ) f ( n − 2 ) f(0) a, f(1) b, f(n) f(n - 1) f(n - 2) f(0)a,f(1)b,f(n)f(n−1)f(n−2) 其中 a, b 均为正整数,n ≥ 2。 问有多少种 (a, b)&…

基于消失点标定前视相机外参

1. 消失点 艺术家&工程师在纸上表现立体图时,常用一种透视法,这种方法源于人们的视觉经验:近大远小,且平行的直线都消失于无穷远处同一个点。就像我们观察两条平行的铁轨时会觉得他们相交于远处的一点,我们把这个点称为消失点。 图1 铁轨组成的消失点 2. 在标定中的应…

卷积神经网络 - 卷积的互相关

一、卷积核翻转 一句话直击本质 卷积核翻转就是把卷积核(比如[1,2,3])倒过来变成[3,2,1]后再滑动计算,这是严格数学定义的要求,但深度学习中的卷积实际上跳过了这一步。 直观理解步骤分解 场景设定 假设我们要用卷积核检测心…

华为重拳出击!华为重拳出击!华为重拳出击!

大家好,我是小程程。 华为出了一个大瓜哦! 华为多名产品线负责人被开除 据财新网 3 月 10 日报道,华为最近发了一则内部通报: 华为称,经审计发现,(ICT 产品与解决方案,半导体业务部、…