将Hexo博客部署到云主机
摘要: 在云主机上搭建一个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博客部署到云主机的更多相关文章
- 搭建自己的技术博客系列(二)把 Hexo 博客部署到 GitHub 上
1.在GitHub上建一个新仓库
- Hexo博客部署到腾讯云服务器全过程(Nginx,证书,HTTPS),你要的这里都有
背景 说来也惭愧,博客已经搭建很久了,一直免费的部署在 Coding 和 Github Pages 上,前者迁移到腾讯云 Serverless,导致原有的配置始终有问题,没时间仔细研究,刚好腾讯服务器 ...
- 【hexo博客搭建】将搭建好的hexo博客部署到阿里云服务器上面(下)
一.部署到阿里云服务器 既然博客也已经成功在本地部署,然后主题也成功安装,接下来就可以部署到服务器上面了,如果你也想要魔改matery主题,可以去各种博客上面找一找大佬的教程,或者联系我,也可以让你少 ...
- Hexo 博客部署到 GitHub
本文简单记录了一下把 Hexo 部署到 GitHub 上的过程,也是搭建静态博客最常用的一种方式. 前面写了关于如何把 Hexo 安装在树莓派上的教程,但树莓派毕竟是连着自己的家的路由器,万一哪天网断 ...
- Hexo博客部署到远程仓库(Conding、Gitee、Github)
一.本地环境搭建 1.安装Git Git可以有效.高速的处理各种项目版本管理.也就是用来管理你的hexo博客文章,上传到GitHub的工具. Git下载地址 安装好了之后使用git -version查 ...
- Hexo博客部署
前些天使用wordpress程序搭建了个人网站,但感觉太重比较适合个人空间,所以这次介绍Hexo搭建免费博客,先提供官网给大家英文版的请点击这里,中文版的请点击这里,在安装一个Git,再是github ...
- Hexo博客部署-使用github作为保存中转仓库
本篇是在VPS上搭建Hexo静态博客的第一篇博文,写本篇的目的一是纪念一下,二是作为一个部署文档保留. 博客地址 相关描述 VPS环境是在搬瓦工上安装的centos6(x86),1核,512MB,10 ...
- Hexo博客部署到个人服务器
本文跳过阿里云创建git仓库.hexo部署到github的步骤,有需要的可以移步下面博客地址查看: 在阿里云服务器上创建git远程仓库 使用Hexo建立博客 一.服务器相关配置 本文使用hexo在本地 ...
- hexo博客部署到github无法上传的问题
博客生成之后,按照网上别人的教程,讲项目部署到github上,修改_config.yaml中的deploy部分如下所示: deploy: type: git repository: https://g ...
随机推荐
- HBase体系架构和集群安装
大家好,今天分享的是HBase体系架构和HBase集群安装.承接上两篇文章<HBase简介>和<HBase数据模型>,点击回顾这2篇文章,有助于更好地理解本文. 一.HBase ...
- 腾讯技术分享:微信小程序音视频技术背后的故事
1.引言 微信小程序自2017年1月9日正式对外公布以来,越来越受到关注和重视,小程序上的各种技术体验也越来越丰富.而音视频作为高速移动网络时代下增长最快的应用形式之一,在微信小程序中也当然不能错过. ...
- 迷宫-BFS
迷宫问题 Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit Status Descript ...
- 微信小程序实现标签页滑块效果
微信小程序实现标签页滑块效果 小程序完整代码: wxml: <view class="swiper-tab"> <view class="swiper- ...
- [Postman]历史(8)
邮递员将您发送的所有请求存储在左侧边栏的“历史记录”视图中.您可以使用历史记录快速尝试各种请求,而不必浪费时间从头开始构建请求.您还可以通过单击请求名称来加载先前的请求. 如果您创建了一个帐户并登录P ...
- MQTT入门篇
物联网(Internet of Things,IoT)最近曝光率越来越高.虽然HTTP是网页的事实标准,不过机器之间(Machine-to-Machine,M2M)的大规模沟通需要不同的模式:之前的请 ...
- 封装手风琴!使用jQuery!
//封装手风琴 /** * * * */ $.fn.accordion = function (colors, width) { var width=width||0; var colors= col ...
- hbaes之createTable执行流程
hbase的客户端代码并不想hive一样用java编写,shell调用,而是使用ruby编写. 在admin.rb文件中方法create,其中接受两个参数,其中第二个参数类型为变长参数. 而在crea ...
- kindeditor扩展粘贴截图功能&修改图片上传路径并通过webapi上传图片到图片服务器
前言 kindeditor是一个非常好用的富文本编辑器,它的简单使用我就不再介绍了. 而kindeditor却对图片的处理不够理想. 本篇博文需要解决的问题有两个: kindeditor扩展粘贴图片功 ...
- CentOS7+Mono5.2.0.224 +Jexus5.8.3.0 布署 Asp.Net MVC (vs2017)
背景: 比起大神我们只是差远了,只知道一味的找找看,找的资料不少,但真不知道哪一个是正确的. 之前一个文章也写了怎么安装 Jexus 但始终只有是html的静态页面可以asp.net 都不行(http ...