摘要: 在云主机上搭建一个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

这篇的博客参考了利用 GIT HOOKS 部署 HEXO 到 VPS,原文图文并茂。我做了一些优化,例如使用root用户,简化nginx配置文件,简化post-receive脚本,同时简单地介绍一下原理。为了省事,我将直接使用root用户,这是不符合安全规范的。但是,一方面我只是为了部署博客,不担心黑客干坏事;另一方面,我也做了必要的安全防范,比如配置腾讯云安全组,禁止SSH密码登陆以及配置UFW防火墙。

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;
}

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

systemctl restart nginx

3. 配置Git Hooks

创建Git裸仓库

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

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

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

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仓库。部署博客

备案之后,将ngnix端口改为80,把server_name设为域名,然后修改DNS解析到云主机就好了。然后通过http://152.92.13.78:8080/即可访问博客。

hexo d

  

参考链接:

关于Fundebug

Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java实时BUG监控。
自从2016年双十一正式上线,Fundebug累计处理了6亿+错误事件,得到了Google、360、金山软件等众多知名用户的认可。欢迎免费试用!

版权声明:

转载时请注明作者Fundebug以及本文地址:

https://blog.fundebug.com/2017/05/18/deploy-hexo-on-cloud/

将Hexo博客部署到云主机的更多相关文章

  1. 搭建自己的技术博客系列(二)把 Hexo 博客部署到 GitHub 上

    1.在GitHub上建一个新仓库

  2. Hexo博客部署到腾讯云服务器全过程(Nginx,证书,HTTPS),你要的这里都有

    背景 说来也惭愧,博客已经搭建很久了,一直免费的部署在 Coding 和 Github Pages 上,前者迁移到腾讯云 Serverless,导致原有的配置始终有问题,没时间仔细研究,刚好腾讯服务器 ...

  3. 【hexo博客搭建】将搭建好的hexo博客部署到阿里云服务器上面(下)

    一.部署到阿里云服务器 既然博客也已经成功在本地部署,然后主题也成功安装,接下来就可以部署到服务器上面了,如果你也想要魔改matery主题,可以去各种博客上面找一找大佬的教程,或者联系我,也可以让你少 ...

  4. Hexo 博客部署到 GitHub

    本文简单记录了一下把 Hexo 部署到 GitHub 上的过程,也是搭建静态博客最常用的一种方式. 前面写了关于如何把 Hexo 安装在树莓派上的教程,但树莓派毕竟是连着自己的家的路由器,万一哪天网断 ...

  5. Hexo博客部署到远程仓库(Conding、Gitee、Github)

    一.本地环境搭建 1.安装Git Git可以有效.高速的处理各种项目版本管理.也就是用来管理你的hexo博客文章,上传到GitHub的工具. Git下载地址 安装好了之后使用git -version查 ...

  6. Hexo博客部署

    前些天使用wordpress程序搭建了个人网站,但感觉太重比较适合个人空间,所以这次介绍Hexo搭建免费博客,先提供官网给大家英文版的请点击这里,中文版的请点击这里,在安装一个Git,再是github ...

  7. Hexo博客部署-使用github作为保存中转仓库

    本篇是在VPS上搭建Hexo静态博客的第一篇博文,写本篇的目的一是纪念一下,二是作为一个部署文档保留. 博客地址 相关描述 VPS环境是在搬瓦工上安装的centos6(x86),1核,512MB,10 ...

  8. Hexo博客部署到个人服务器

    本文跳过阿里云创建git仓库.hexo部署到github的步骤,有需要的可以移步下面博客地址查看: 在阿里云服务器上创建git远程仓库 使用Hexo建立博客 一.服务器相关配置 本文使用hexo在本地 ...

  9. hexo博客部署到github无法上传的问题

    博客生成之后,按照网上别人的教程,讲项目部署到github上,修改_config.yaml中的deploy部分如下所示: deploy: type: git repository: https://g ...

随机推荐

  1. 目标检测算法(1)目标检测中的问题描述和R-CNN算法

    目标检测(object detection)是计算机视觉中非常具有挑战性的一项工作,一方面它是其他很多后续视觉任务的基础,另一方面目标检测不仅需要预测区域,还要进行分类,因此问题更加复杂.最近的5年使 ...

  2. 简单 v.s. 基础

    无论做平面设计还是做摄影创作,其基础都是一些比较粗浅的看似毫无用处的简单技能.例如画直线.拍挂在墙上的电视机,不一而足. 同样的现象还能在web的前端设计中看到.一堆类似小孩学绘画的标签,几个可以更改 ...

  3. Python selenium webdriver设置加载页面超时

    1.  pageLoadTimeout: pageLoadTimeout方法用来设置页面完全加载的超时时间,完全加载即页面全部渲染,异步同步脚本都执行完成.没有设置超时时间默认是等待页面全部加载完成才 ...

  4. 51nod OJ P1000 A+B

    P1000 A+B OJ:51Nod 链接:"http://www.51nod.com/Challenge/Problem.html#!#problemId=1000" 题目描述: ...

  5. JavaScript大厦之JS运算符

    运算符用于执行程序代码运算,会针对一个及以上操作数项目来进行运算.2+3,其操作数是2和3,而运算符则是“+”.上一篇我们说过变量用来存储数据,而同一个变量中的数据在不同的时刻可以不同,在程序的运行过 ...

  6. IM群聊消息的已读回执功能该怎么实现?

    本文引用了架构师之路公众号作者沈剑的文章,内容有改动,感谢原作者. 1.前言 我们平时在使用即时通讯应用时候,每当发出一条聊天消息,都希望对方尽快看到,并尽快回复,但对方到底有没有真的看到?我却并不知 ...

  7. SpringMVC 使用 MultipartFile 实现文件上传

    该代码实现了文件上传和文本字段同时传递到后台进行处理的功能. 直接贴代码,中间涉及到的实体类就不贴了,和功能没啥关系的. Controller /** * 添加活动 * * @param req * ...

  8. 第46节:Java当中的常量池

    Java当中的常量池 在Java虚拟机jvm中,内存分布为:虚拟机堆,程序计数器,本地方法栈,虚拟机栈,方法区. 程序计数器是jvm执行程序的流水线,是用来存放一些指令的,本地方法栈是jvm操作系统方 ...

  9. iframe简单框架

    <iframe width='738' height='523' class='preview-iframe' scrolling='no' frameborder='0' src='http: ...

  10. 你不知道的Node.js性能优化,读了之后水平直线上升

    本文由云+社区发表 "当我第一次知道要这篇文章的时候,其实我是拒绝的,因为我觉得,你不能叫我写马上就写,我要有干货才行,写一些老生常谈的然后加上好多特技,那个 Node.js 性能啊好像 D ...