使用 Hexo 搭建个人博客并部署到云服务器
目前搭建博客的主流框架有 WordPress、VuePress、Hugo、Hexo 等等,我主要是感觉 Hexo 好看的主题比较多,所以就来折腾一下这个博客框架
1 整体流程
- 在本地运行 hexo deploy 命令,Hexo 会将生成的静态文件(hexo generate)推送到远程的 Git 仓库
- 在 Git 仓库中,配置一个钩子脚本,它会在接收到推送后执行——将最新的静态文件强制覆盖到指定的工作目录
- 在 Nginx 服务器中,配置访问根路径的请求指向该工作目录
2. 本地环境准备
2.1 安装 Node.js 和 Git
这两个我是很早就安装好了,网上也有大量的资料,我就不重复了,这里主要记录 Hexo 相关笔记
(1) 验证 Node.js是否安装成功,打开 cmd 输入node -v
,出现版本信息,则 ok
C:\Users\gzl>node -v
v18.16.1
(2) 验证 Git 是否安装成功,打开 cmd 输入git --version
,出现版本信息,则 ok
C:\Users\gzl>git --version
git version 2.39.0.windows.2
同时在文件夹中点击右键会出现 Git Bash Here
2.2 安装 Hexo
(1) 新建一个文件夹用来存储个人博客:E:\MyBlog
进入该文件夹,进入 Git Bash,输入npm install -g hexo-cli
将 Hexo 命令行工具安装到系统的全局环境中
gzl@gzl MINGW64 /e/MyBlog
$ npm install -g hexo-cli
(2) 待安装完毕,输入以下指令,将会新建一个 myblogs 文件夹,并且安装 Hexo 项目所需的依赖项
# 创建一个新的 Hexo 项目
$ hexo init myblogs
$ cd myblogs
# 安装 Hexo 项目所需的依赖项
$ npm install
最后,会在 myblogs 文件中生成如下文件:
(3) 继续在 Git Bash 中执行指令hexo server
$ hexo server
执行完毕后,打开本地浏览器,访问http://localhost:4000/
,出现以下界面,说明第一步成功了
3. 服务端环境准备
3.1 Nginx 环境配置
3.1.1 安装 Nginx
依次执行以下指令
# 安装 nginx 依赖环境,遇到 yes 选 yes
yum install gcc-c++
yum install -y pcre pcre-devel
yum install -y zlib zlib-devel
yum install -y openssl openssl-devel
# 下载并解压 nginx 安装包
wget -c https://nginx.org/download/nginx-1.10.1.tar.gz
tar -xvf nginx-1.10.1.tar.gz -C /usr/local
# 执行配置文件
cd /usr/local/nginx-1.10.1
./configure
# 编译并安装 nginx
make
make install
# 开放 80 端口
cd /usr/local/nginx
/sbin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT
# 启动 nginx
cd sbin
./nginx
没有任何消息,代表启动成功,在浏览器访问公网ip:80
就可以进入 nginx 页面了
如果需要停止 nginx 服务,执行./nginx -s stop
3.1.2 更改 Nginx 配置文件
需要将 Nginx 的配置文件中网站的根目录(root)指向 hexo 的部署目录,以及修改域名(server_name)为自己已备案的域名,如果没有,则填公网ip
所以,首先创建一个文件用来存放 hexo 的部署文件
mkdir -p /data/hexo
然后修改 nginx 配置文件
cd /usr/local/nginx/conf
vim nginx.conf
# 进入后,按 i 键进入编辑模式
修改server_name
和root
即可
server {
listen 80;
server_name www.cheyaoyao.cn;
location / {
root /data/hexo;
}
...
}
修改完毕后按 Esc 键进入命令模式,再输入 :wq 保存并退出
3.2 Node.js 环境配置
安装 node.js,依次执行以下命令:
# 切换到根目录,安装 node.js
cd ~
curl -sL https://rpm.nodesource.com/setup_10.x | bash -
yum install -y nodejs
# 查看安装结果,打印对应版本号则安装成功
node -v
npm -v
3.3 Git 环境配置
3.3.1 安装 Git
依次执行以下命令:
# 安装,遇到 yes 选 yes
yum install git
# 查看版本号
git --version
3.3.2 创建 Git 用户
依次执行以下指令:
# 创建git用户
adduser git
# 修改git用户的权限
chmod 740 /etc/sudoers
# 进入 sudo 命令文件
vim /etc/sudoers
找到root ALL=(ALL) ALL
,在下面添加git ALL=(ALL) ALL
继续执行以下指令
# 修改文件权限
chmod 400 /etc/sudoers
# 设置 git 用户的密码
sudo passwd git
3.3.3 配置 SSH 免密登录
由于是将本地的静态文件推送到服务器的 Git 仓库中,所以要配置 ssh 免密登录服务器
(1) 在服务端,依次执行以下指令:
# 切换到 git 用户
su git
# 在根目录创建.ssh文件夹,存放公钥
cd ~
mkdir .ssh
(2) 在本地计算机打开 Git Bash,执行以下指令
# 在本地生成公钥/私钥对
$ cd ~
$ cd .ssh
$ ssh-keygen
遇到系统询问,就按回车键。最后生成的公钥和秘钥会自动保存在C:\Users\gzl\.ssh
目录下
(3) 给私钥设置权限,执行以下指令:
$ chmod 700 ~/.ssh
$ chmod 600 ~/.ssh/id_rsa
(4) 将本地的公钥(id_rsa.pub)上传到服务器的/home/git/.ssh
目录下
(5) 新建authorized_keys
文件,并拷贝公钥的内容到该文件中,依次执行以下指令:
cd ~/.ssh
cp id_rsa.pub authorized_keys
cat id_rsa.pub >> ~/.ssh/authorized_keys
# 设置权限
chmod 600 ~/.ssh/authorized_keys
chmod 700 ~/.ssh
# 确保 SSH 相关的文件和目录具有正确的 SELinux 安全标签
restorecon -Rv ~/.ssh
(6) 测试本地免密登录服务器
进入本地计算机的 Git Bash,输入:
$ ssh -v git@xxx.xxx.xxx.xxx(公网IP)
最后面会出现:
3.3.4 配置 Git 仓库
(1) 在服务器新建一个 Git 仓库,同时新建一个钩子文件
cd ~
git init --bare hexo.git
vi ~/hexo.git/hooks/post-receive
输入git --work-tree=/home/www/hexo --git-dir=/home/git/hexo.git checkout -f
,保存并退出
(2) 授予钩子文件可执行权限
chmod +x ~/hexo.git/hooks/post-receive
cd ~
sudo chmod -R 777 /data/hexo
重启 ECS 实例,服务端配置完成
4. 部署 Hexo 博客到服务端 Git 仓库
(1) 在本地计算机打开 Hexo 项目,我用的 vscode,修改_config.yml
文件中的deploy
:
deploy:
type: git
repo: git@公网ip:/home/git/hexo.git
branch: master
(2) 安装插件,hexo-deployer-git 和 hexo-server
# 用于将 Hexo 生成的静态文件推送到指定的 Git 仓库
npm install hexo-deployer-git --save
# 用于在本地启动一个 Hexo 服务器,方便在本地预览博客
npm install hexo-server
(3) 配置 Git 全局变量
回到 Git Bash,输入:
# email 和 name 随便填一个也可以
$ git config --global user.email "xxxxxxxxxx@xx.com"
$ git config --global user.name "xxx"
(4) 生成静态文件和发布博客
在 vscode 的终端中输入:
# 清除之前生成的静态文件
hexo clean
# 生成静态文件
hexo generate
# 部署到 Git 仓库
hexo deploy
至此,已经全部配置完毕了
如果在 nginx 中配置了域名的话,可以通过域名访问博客了,没配置也可以用公网ip访问
下一篇就研究怎么美化博客吧
5. Hexo 写作新文章并发布
(1) 在 vscode 中打开 Hexo 项目,打开终端,使用如下命令创建新文章
hexo new "title"
执行该命令,Hexo 会在/source/_posts
目录下创建一篇新的文章
(2) Front-matter
Hexo 创建的文件中开头有一段配置信息:
这个叫做Front-matter
,即前置信息,用于给 Hexo 渲染该 md 文档
配置项 | 意义 |
---|---|
title | 网页文章标题 |
date | 文章创建如期 |
tags | 文章标签 |
(3) 发布文章
随便编写点内容
在终端依次输入:
# 清除之前生成的静态文件
hexo clean
# 生成静态文件,hexo generate 的简写
hexo g
# 本地启动,hexo server 的简写
hexo s
可以在本地预览文章
最后部署到远程的 Git 仓库中
# 部署到 Git 仓库,hexo deploy 的简写
hexo d
稍微等一下,在浏览器访问域名,就可以看到了
使用 Hexo 搭建个人博客并部署到云服务器的更多相关文章
- Linux下使用 github+hexo 搭建个人博客02-hexo部署到Github Pages
之前的这篇文章<Linux下使用 github+hexo 搭建个人博客01-hexo搭建>,相信大家都知道怎么搭建 hexo ,怎么切换主题,并且完成了一篇博文的创建,以及 MarkDow ...
- 使用Hexo搭建个人博客并部署到GitHub或码云上全过程
一.前言 如上图所示:GitHub有Github Pages,而码云也有码云 Pages 1.Github Pages或Gitee Pages是什么呢? Github Pages或者Gitee Pag ...
- Linux下使用 github+hexo 搭建个人博客07-next主题接入搜索和站点管理
这是搭建个人博客系统系列文章的最后一篇,如果你是从第一篇一路跟下来的,那么恭喜你,即将完成整个博客网站的搭建.OK,话不多说,开始我们的收官之战. 不知你想过没有,如果我们的文章少,一眼看完整个目录, ...
- Linux下使用 github+hexo 搭建个人博客06-next主题接入数据统计
之前说了 next 主题的优化和接入评论系统.让我们完成了自己所需的页面风格和排版,也可让访问用户在每篇博文评论,完成博主和访问用户的交互. 本章我们继续讲解其他重要功能. 既然是一个网站,那么我们就 ...
- Linux下使用 github+hexo 搭建个人博客05-next主题接入评论系统
静态站点拥有一定的局限性,因此我们需要借助于第三方服务来扩展我们站点的功能. 而评论系统是最常用于和网站用户交流的,因此本章讲解在 next 主题,如何接入评论系统. 参考网站:Next 使用文档,第 ...
- Linux下使用 github+hexo 搭建个人博客04-next主题优化
上篇我们说了 hexo 的优化,针对的站点的优化. 本篇讲解 next 主题的优化,包括:使用语言.前端页面显示宽度.菜单.侧栏.头像.添加或取消动画效果.打赏功能等等. 让页面排版更符合我们所要的功 ...
- Linux下使用 github+hexo 搭建个人博客03-hexo配置优化
上两张文章,我们说了 hexo 部署.主题的切换.博文的创建.MarkDown 简单使用和 hexo 部署到 GitHub Pages. 也说了我们会使用 next 主题做为我们后期博客的使用和维护. ...
- Linux下使用 github+hexo 搭建个人博客01-hexo搭建
为什么要搭建自己的博客系统? 原因有好几个吧,归类如下:1.自己搭建博客系统很有成就感,可以自己选定页面风格和页面排版: 2.自己搭建博客系统可以根据自己的需要添加各种插件功能,因此整体上比网上的第三 ...
- 使用Hexo快速搭建一个博客,并部署到github
本文旨在记录一下我在通过hexo搭建一个博客,并将其部署在github上面的过程,也供我自己在以后的使用过程中能够快速学习和参考.需要看更详细或者官方文档的可以点击Hexo官方文档进行查看. 安装前提 ...
- 利用Hexo搭建个人博客-博客发布篇
通过 <利用Hexo搭建个人博客-环境搭建篇> 以及 <利用Hexo搭建个人博客-博客初始化篇>,我们了解到了利用Hexo搭建个人博客需要的环境以及配置,下面这篇文章将会介绍如 ...
随机推荐
- 介绍Centos7启用过程中用到的rpm软件包、及其作用
序号 包名 作用 1 udev 系统设备管理器,用于管理设备驱动程序和设备的元数据. 2 lvm2 Logical Volume Manager 2(LVM2)是一个用于管理和分配存储设备的工具,允许 ...
- js闭包的一些笔记
闭包 闭包是一个可以访问外部作用域的内部函数,即使这个外部作用域已经执行结束 作用域 作用域决定这个变量的生命周期及其可见性.当我们创建一个函数,就会生成一个新的作用域. 通过var创建的变量只有函数 ...
- redis 中的 set
set是String中的无序集合 底层是 是 value为null 的hash表 时间复杂化是o(1): sadd k1 v1 v2 v3 set中添加数据 smembers k1 取出set ...
- Pytorch 最全入门介绍,Pytorch入门看这一篇就够了
本文通过详细且实践性的方式介绍了 PyTorch 的使用,包括环境安装.基础知识.张量操作.自动求导机制.神经网络创建.数据处理.模型训练.测试以及模型的保存和加载. 1. Pytorch简介 在这一 ...
- composer 的使用和常用命令大全
composer 常用命令 1.composer初始化 init 如何手动创建 composer.json 文件.实际上还有一个 init 命令可以更容易的做到这一点. 查看当前版本composer ...
- next.js 源码解析 - getStaticProps、getStaticPaths 篇
好久前写了关于 getStaticProps 和 getStaticPaths 的内容,然而半年过去了源码解析就一直忘记了,不久前有人提醒才想起来,补下坑. 本文主要是解读下 getStaticPro ...
- 原神盲盒风格:AI绘画Stable Diffusion原神人物公仔实操:核心tag+lora模型汇总
本教程收集于:AIGC从入门到精通教程汇总 在这篇文章中,我们将深入探讨原神盲盒的艺术风格,以及如何运用AI绘画技术(Stable Diffusion)--来创造原神角色公仔.我们将通过实践操作让读者 ...
- QA|外部调用类方法总报错missing 1 required positional argument:'self'|UI自动化
外部调用类方法总报错missing 1 required positional argument:'self' 原因:实例化这个类 实例化错了,少了括号() 解决:改成如下就可以了 参考学习:调用类方 ...
- 面试官:说一下 MyBatis 缓存机制?
MyBatis 的缓存机制属于本地缓存,适用于单机系统,它的作用是减少数据库的查询次数,提高系统性能. MyBaits 中包含两级本地缓存: 一级缓存:SqlSession 级别的,是 MyBatis ...
- 利用python将数据写入CSV文件中
利用python将数据写入CSV文件中 全部代码如下: import csv # 1.创建文件对象 f = open('cav_file.csv', 'w', encoding='utf-8', ne ...