将Hexo博客部署到云主机

简介: 摘要 在云主机上搭建一个git裸仓库,然后使用nginx作为网页服务器,就可以轻松将Hexo博客通过git部署到云主机上。这是一个忧伤的故事我的博客KiwenLau之前部署在Coding Pages上,挺不错的,还可以一键启用HTTPS。

摘要 在云主机上搭建一个git裸仓库,然后使用nginx作为网页服务器,就可以轻松将Hexo博客通过git部署到云主机上。

这是一个忧伤的故事

我的博客KiwenLau之前部署在Coding Pages上,挺不错的,还可以一键启用HTTPS。作为一个喜欢折腾的人,我突然打算使用CDN加速一下访问速度,然而,国内的CDN服务要求网站必须备案。特意邮件问了Coding的客服,看来他们近期是不打算支持备案的,于是我就不得不考虑弄个云主机来玩玩了。

后来,Coding Pages忽然添加了跳转页面,也就是说访问我的博客的话,会先弹出5秒钟的Coding广告页面。买个Coding年费199的会员就可以去掉,也不算贵,毕竟占着人家的资源。然而,我还琢磨着备案后用CND呢...

于是,我调研了一下各个云服务的价格,1核1G的云主机一年大概都是600+,比Coding会员贵了不少。不过腾讯云最近在搞采购节,1核1G的云主机一年只要238,果断买了!

然而,备案这事貌似要折腾很久......此处省略1万字。

0. 准备工作

我的云主机的操作系统是****Ubuntu Server 16.04.1 LTS 64****位********。不妨假设它的IP地址是****152.92.13.78****(我当然不会告诉你真实IP),你需要做的第一步就是配置SSH公钥登陆,这样Hexo通过git部署博客时就不需要输入密码了。

# SSH公钥登陆将不需要输入密码
ssh root@152.92.13.78

为了省事,我将直接使用root用户,这是********不符合安全规范********的。但是,一方面我只是为了部署博客,不担心黑客干坏事;另一方面,我也做了必要的安全防范,比如配置腾讯云安全组,禁止SSH密码登陆以及配置UFW防火墙。

这篇的博客参考了利用 GIT HOOKS 部署 HEXO 到 VPS,原文图文并茂。我做了一些优化,例如使用root用户,简化nginx配置文件,简化post-receive脚本,同时简单地介绍一下原理。

1. 安装git和nginx

apt-get update
apt-get install git-core nginx

2. 配置Nginx

****/var/www/blog****目录用于放置生成的静态文件

mkdir /var/www/blog

编写nginx配置文件

vim /etc/nginx/conf.d/blog.conf

由于我的备案还没弄好,还不能使用80端口,所以暂时使用8080端口部署博客。

server
{
    listen 8080;
    root /var/www/blog;
}

重启nginx

ubuntu 16.04的init系统换成了systemd,因此使用systemctl命令来重启nginx。

systemctl restart nginx

3. 配置Git Hooks

创建Git裸仓库

****blog.git****作为远程Git仓库,Hexo在本地生成的博客静态文件可以通过push与其同步。

mkdir ~/blog.git && cd ~/blog.git
git init --bare

配置Hooks脚本

****post-receive****脚本将在****blog.git****仓库接收到push时执行。

vim blog.git/hooks/post-receive

脚本非常简单,删除原有的****/var/www/blog****目录,然后从****blog.git****仓库clone新的博客静态文件。

#!/bin/bash

rm -rf /var/www/blog
git clone /root/blog.git /var/www/blog

给****post-receive****脚本执行权限

chmod +x blog.git/hooks/post-receive

4. 部署Hexo博客

修改_config.yml

deploy:
  type: git
  repo: root@152.92.13.78:blog.git

部署博客

hexo先生成新的博客静态文件,然后通过git将其同步到云主机的****blog.git****仓库。

hexo d

然后通过http://152.92.13.78:8080/即可访问博客。

备案之后,将ngnix端口改为80,把server_name设为域名,然后修改DNS解析到云主机就好了。

参考链接:

版权声明:
转载时请注明作者Fundebug以及本文地址:**
https://blog.fundebug.com/2017/05/18/deploy-hexo-on-cloud/**

目录
相关文章
|
域名解析 运维 JavaScript
只需5步!在轻量应用服务器部署Hexo博客
轻量应用服务器征文活动投稿教程帖,只需5步完成Hexo博客的部署实践,步骤完整,操作性强~
只需5步!在轻量应用服务器部署Hexo博客
|
7月前
|
Web App开发 域名解析 JavaScript
3分钟搭建个人Hexo博客
从账号的创建到一键部署,手把手教你零基础创建个人博客,后续可以继续根据网上的教程来修改代码对博客进行定制化的美化。
58 1
YI
|
9月前
|
Shell 开发工具 数据安全/隐私保护
Hexo博客搭建2
上一篇介绍了博客的本地环境搭建,但这只能本地访问自己的博客。如果想让自己的博客被互联网上的其他人访问,我们还需要将博客项目进行线上部署。本文我将介绍将博客部署到github上的方法。
YI
46 0
YI
|
9月前
|
Shell
Hexo博客搭建3
之前的文章介绍了博客的本地搭建和线上部署。因为hexo的内置主题不够好看,所以我们可以选择加载其他主题来美化我们的博客页面。本文我将介绍基于hexo框架搭建的博客如何修改主题。
YI
43 0
YI
|
9月前
|
JavaScript Shell Linux
Hexo博客搭建1
暑假在家学习时,突然感觉学过的知识忘记的很快,所以决定搭建个人博客来记录学习过程。经过前期了解后,决定采用Hexo框架来搭建个人博客。本文将记录博客搭建过程。
YI
70 0
|
10月前
|
JavaScript 搜索推荐 程序员
使用Hexo 搭建你的技术博客
使用Hexo 搭建你的技术博客
116 0
|
应用服务中间件 Shell 网络安全
Hexo博客迁移到云服务器
Hexo博客迁移到云服务器
256 0
|
JavaScript Shell Linux
使用Hexo搭建自己的博客
之前一直在用typecho来做自己的博客,因为他操作比较简单,但是前几日修改一些配置的时候,看着满屏的php代码实在有些头疼,在朋友的推荐下,我成功的入坑了hexo,下面分享一些自己搭建博客的过程,尽量让读者避开一些坑。
|
应用服务中间件 Shell 网络安全
服务器搭建Hexo博客流程
使用服务器部署hexo博客
202 0
服务器搭建Hexo博客流程
|
JavaScript 安全 应用服务中间件