将Hexo博客部署到云主机

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

这是一个忧伤的故事

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

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

于是,我调研了一下各个云服务的价格,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 [email protected]

为了省事,我将直接使用 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 ./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 ./hooks/post-receive

4. 部署 Hexo 博客

修改_config.yml

deploy:
    type: git
    repo: [email protected]:blog.git

部署博客

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

hexo d

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

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

参考链接:

关于Fundebug

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

版权声明

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

原文地址:http://blog.51cto.com/13957060/2318679

时间: 2024-11-02 15:36:41

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

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

1.在GitHub上建一个新仓库 ? 2.配置Git的SSH KEY 生成SSH添加到GitHub 回到你的git bash中, git config --global user.name "yourname" git config --global user.email "youremail" 这里的yourname输入你的GitHub用户名,youremail输入你GitHub的邮箱.这样GitHub才能知道你是不是对应它的账户. 可以用以下两条,检查一下你有没

Hexo博客部署codingNet静态资源无法加载

用Hexo搭建的个人博客,部署到github的pages的话,好像百度搜索不到.所以在国内的codingNet的pages服务也一起部署一下,这样方便国内国外搜索引擎收录进来.具体部署教程我是参考这里但是今天部署到codingNet的pages服务的时候,发现静态资源都加载不到,后来网上搜索了半天,才发现原来你要打算用codingNet的pages服务部署你的博客的话,你创建项目的名字必须和用户名保持一致,不能自己随便自定义.我重新创建了一个和用户名一致的项目,部署到他的pages服务,访问正常

Hexo 博客 之 腾讯云部署过程

写在前面 Hexo 博客搭好了有差不多两周时间了,这期间走了很多弯路,跳了很多坑.一些坑自己 bing 到了答案,找到了解决方法,一些坑则是自己摸索出来的解决方法.现在准备写几篇关于搭建流程.搭建过程中遇到的问题和解决方法.俗话说得好,好记性不如烂键盘嘛. 暂时准备写三篇关于 Hexo 博客搭建的博文: 关于 Hexo 博客 腾讯云部署过程 关于 Hexo 博客 NexT 主题的美化插件设置 点击这里 关于 Hexo 博客 添加域名映射和 https 点击这里 本文介绍 本博客是关于 Hexo

码云上部署hexo博客框架

title: 码云上部署hexo博客框架 Hexo框架在码云上实现个人博客 本文受 https://www.jianshu.com/p/84ae2ba1c133 启发编写 本地调试 安装完Node.js https://nodejs.org/en/ 安装git bash工具 https://gitforwindows.org/ 在目录下建立博客文件夹,同时cd进目录 右键 git bash here 输入命令 npm install -g hexo-cli 查看是否安装成功,输入命令 hexo

U盘便携式hexo&博客搭建&极速纯净低bug主题推荐&部署到coding&SEO优化搜索

指南:U盘便携式hexo&博客搭建&极速纯净低bug主题推荐&部署到coding&SEO优化搜索 U盘便携式hexo随处写博客 简述:在任意一台联网的电脑上续写hexo博客,一个U盘+几个网站即可搞定.便携式hexo,其免去Nodejs 和 Git 的安装和配置还包含了配置和懒人脚本.好处就是省事.简单.方便 便携式hexo下载及使用方法,由 HEXO Portable | 比特萌信息技术 免费提供服务.(这里使用的版本是1.0.3) 几个网站: 折腾选用:hexo中文文档

腾讯云搭建hexo博客

腾讯云搭建hexo博客 hexo腾讯云 1. 腾讯云 学生认证购买 重置密码和网络备案 2. hexo博客搭建 2.1 Node.js环境准备 2.2安装git 2.3安装hexo 切换淘宝源 安装hexo 新建一个博客文件夹并初始化 启动 2.4 nginx部署 2.4域名DNS配置 3. 本地搭建hexo,git推送到腾讯云自动部署 4. 小结 1. 腾讯云 学生认证购买 在阿里云和华为云购买失败的前提下,最终找到了腾讯云的购买,学生认证后价格只要10块一月,域名16一年,价格真香,我选择

将hexo博客同时部署发布托管到github和coding

title: 将hexo博客同时部署发布托管到github和coding date: 2018-08-30 00:12:11 tags: - 博客 - git - coding - hexo - 博客优化 categories: 搭建博客 --- 前言 之前我们把hexo托管在github,但是毕竟github是国外的,访问速度上还是有点慢,所以想也部署一套在国内的托管平台,之前查资料听说gitcafe,但是听说gitcafe已经被coding收购了,所以就决定部署到coding. 查询了多方资

利用Travis IC实现Hexo博客自动化部署

1.Hexo博客的利与弊 Hexo中文 我就默认为看到这篇文章的人都比较了解Hexo博客,也都能够成功手动部署吧.所以第一部分推荐两篇文章一笔带过,让我们快速进入本文的重点内容.实在不知道也不要方先看一看下面推荐的这两篇文章. 手把手教你使用Hexo + Github Pages搭建个人独立博客--令狐葱 Hexo + github 打造个人博客--zdy0_2004 还有一个专栏: Hexo / 总共13篇--水寒 感谢以上文章原创作者的分享,推荐纯属自来水.看完这两篇文章后有没有觉得自己手里

在Github上搭建个人的Hexo博客,并绑定域名及Https访问

Hexo是一个很简约的博客程序,可将其安装到Github上并使用Git二级域名进行访问,即是为咱们节流了服务器和域名本钱,同时还可以绑定伏笔VPS的域名访问,这里就说下详细搭建教程. 简介 Hexo是一个快速.简约且高效的博客框架.Hexo使用Markdown(或其他衬着引擎)解析文章,在几秒内,便可使用靓丽的正题天生动态网页. 搭建 1.建立Github账户阅读器进入https://github.com,注册一个账号,再openhttps://github.com/new建立一个项目.称号填G