Sorry, your browser cannot access this site
This page requires browser support (enable) JavaScript
Learn more >

1. 本网站的系统架构

  • 网站示例: sunlogging.com
  • 服务器: 阿里云ECS
  • 服务器系统: Ubuntu 24.04 LTS
  • 博客框架: Hexo
  • 网站主题: Volantis

2. 安装git

执行环境: ECS服务器 + 本地计算机

  1. 安装
1
sudo apt install -y git
  1. 验证
1
git --version

显示具体的版本号则说明安装成功。

3. 配置git用户

3.1. 为什么要创建git用户

为了实现博客的自动化部署,我们后面要使用公钥免密登录服务器。为了安全起见,最好不要使用root用户免密登录,我们创建一个受限的用户来进行免密登录。

3.2. 创建git用户

执行环境: ECS服务器

  1. 创建账户
1
adduser git
  1. 查看是否创建成功
1
2
3
cat /etc/passwd | grep git
# 或
id git
  1. 配置sudoers

将git用户添加到sudo的配置文件

1
2
3
4
5
6
7
# 切换到root用户
su -
# 编辑配置文件
vim /etc/sudoers
# 增加配置, 在打开的配置文件中,找到root ALL=(ALL) ALL, 在下面添加一行
# 其中git是你要加入的用户名称
git ALL=(ALL) ALL

3.3. 设置git用户的密码

执行环境: ECS服务器

  1. 设置密码
1
2
sudo passwd git
# shell提示符会提示输入新密码两次,输入完成后按回车。

设置完密码后,就可以用git用户远程登录ECS服务器了。

  1. 验证
1
2
ssh git@服务器IP
# 服务器IP是ECS服务器的公网IP

输入刚设置的密码进行登录,如果登录成功,这说明git用户密码的设置成功。

3.4. 创建公钥-私钥对

执行环境: 在本地计算机

前提条件: 已安装git和ssh客户端,如果未安装,请先安装。

1
2
3
4
5
6
# 进入~/.ssh,如果不存在该目录,可以手动创建一个
cd ~/.ssh

# 创建公钥-私钥对
ssh-keygen -t ed25519 -C "you_email@example.com"
# 邮箱使用你的git配置的邮箱

接下来,碰见系统询问就直接按回车键。此时便会在 ~/.ssh 目录创建两个文件,分别为: id_ed25519 (私钥) 和 id_ed25519.pub (公钥)。

3.5. 服务器配置公钥

执行环境: ECS服务器

前提条件: 已安装git,如果未安装,请先安装。

  1. 复制id_ed25519.pub

复制 4.4创建的 id_ed25519.pub 的内容。注意不要在命令行里选中复制,可以用VSCode等编辑器打开文件后,复制内容。

  1. 用git用户登录服务器
1
ssh git@服务器IP
  1. 创建authorized_keys文件
1
2
3
4
5
6
7
8
9
10
11
# 进入git用户的home目录
cd ~
# 创建.ssh目录
mkdir .ssh
cd .ssh/
# 创建id_ed25519.pub文件,并将已复制的内容粘贴进来
vim id_ed25519.pub
# 检查是否保存成功
cat ./id_ed25519.pub
# 将公钥文件拷贝一份并命名为:authorized_keys
cp ./id_ed25519.pub ./authorized_keys
  1. 验证

退出远程登录的服务器。再次通过ssh用git用户登录,这时应该不需要输入密码就能进正常登录了。

1
ssh git@服务器IP

4. hexo配置自动化部署

4.1. 配置Git仓库

执行环境: ECS服务器

前提条件: 已安装git,如果未安装,请先安装。

  1. 用git用户登录服务器
1
ssh git@服务器IP
  1. 创建git仓库
1
2
cd ~
git init --bare sunlogging_repo
  1. 创建 post-receive
1
2
3
4
5
6
7
cd hooks/
# 创建并编辑 post-receive 文件
vim ./post-receive
# 在vim内输入以下内容并保存:
git --work-tree=/home/www/sunlogging --git-dir=/home/git/sunlogging_repo checkout -f
# 给 ./post-receive 添加执行权限
chmod +x ./post-receive

post-receive文件内容的功能:
让钩子文件删除 /home/www/sunlogging 目录下原有的文件,然后从 /home/git/sunlogging_repo 仓库 clone 新的博客静态文件到 /home/www/sunlogging 目录下。

  • /home/www/sunlogging: 静态博客网站的根目录
  • /home/git/sunlogging_repo: 博客网站的git仓库目录
  1. 修改 /home/www/sunlogging 目录权限
1
2
3
cd /home/www/sunlogging
# 修改 sunlogging 目录的所属用户为git,这样git用户才有读写权限
chown -R git:root ./sunlogging/

4.2. hexo站点配置

执行环境: 在本地计算机

前提条件: 已安装 node.js、hexo、git等软件,如果未安装,请先安装。

  1. 安装hexo-deployer-git

hexo-deployer-git是hexo官方提供的部署插件,可以实现hexo站点自动部署到git仓库。

1
npm install hexo-deployer-git --save
  1. 修改 _config.yml 配置
1
2
3
4
deploy:
type: git
repo: git@your_pub_ip:/home/git/sunlogging_repo
branch: master

your_pub_ip为ECS服务器的公网IP,请替换为你的公网IP。仓库路径修改为你自己的仓库路径。

  1. 部署网站
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 1.生成静态页面
hexo generate
# 或
hexo g

# 2.部署静态页面
hexo deploy
# 或
hexo d

# 1+2 简写为
hexo g -d
# 或
hexo d -g
  1. 验证

通过浏览器访问 http://xxx.xxx.xxx.xxx:80/,就能查看刚部署的博客主页了。

推荐阅读
git配置3 - 一个git仓库同时push到多个代码托管平台 git配置3 - 一个git仓库同时push到多个代码托管平台 git配置2-不同的代码托管平台配置不同的ssh key git配置2-不同的代码托管平台配置不同的ssh key git配置1-不同的项目使用不同用户名或邮箱 git配置1-不同的项目使用不同用户名或邮箱

评论