Hexo 博客终极玩法:云端写作,自动部署

32次阅读

共计 4263 个字符,预计需要花费 11 分钟才能阅读完成。

Hexo + Github + 语雀 + yuque-hexo +travis-ci+severless 打造全自动持续集成个人博客,云端写作,自动部署,完美体验~
一、Hexo+Github 的痛点
1. 为啥要用 hexo+github?
作为一个程序猿,博客肯定是必须要有的拉,github 也是必须要混的拉~ 所以:
hexo + github = 高大上

2. 蛋疼的写作体验
使用 hexo,会面临如下问题:

博客源码怎么管理?
图片存在哪?
如何编写 markdown 文件?

相信很多人都在使用本地编辑器来写博客,那体验,真心蛋疼,比如说 vscode,可视化插件一般般,图片还不能复制黏贴,想插入个图片还要先保存成文件放在本地,然后再引用,啥?你说七牛云存储?哪有复制黏贴爽呀~ 当然,博客源码可以使用 travis-ci 来做持续集成,想写博客或者换个电脑,clone 一下源仓库,写完 push 一下,就可以不用管了。but,比起独立站点的博客,如 wordpress,还是觉得写作体验有点不爽。
3. 脑洞大开:
偶然间,朋友安利了语雀这个文档写作平台,觉得这就是完美的写作体验,各种 UI 和编辑器都很舒服~ 秀个图:
markdown 编辑器也是巨爽:
于是乎,就在想能不能在语雀里写作,写完之后自动同步到 Github 的博客呢?年轻就要有激情,说干就干,花了一天时间,结合了 severless、yuque-hexo、travis-ci 之后,终于跑通了整个写作、发布、自动部署的流程~
二、具体方案
整体流程:

语雀发布一篇文章
webhook 调用 serverless 函数
serverless 发起请求 trigger 一个 build 任务
travis-ci 同步语雀文章并构建 hexo
github 生成静态页面展示

1. hexo+github+triavs-ci
hexo 如何部署,如何集成 travis-ci,等等,我就不再讲了,网上类似的文章灰常多~ 比如:

使用 Hexo+Github+TravisCI 搭建自动发布的静态博客系统
GitHub pages + Hexo 搭建自己的个人博客

那么如何同步语雀的文章呢?答案就是:
yuque-hexo
这是一个开源库:https://github.com/x-cold/yuque-hexo 用法也很简单:1) 修改 package.json,增加配置:
“yuqueConfig”: {
“baseUrl”: “https://www.yuque.com/api/v2”,
“login”: “u46795”,
“repo”: “blog”,
“mdNameFormat”: “title”,
“postPath”: “source/_posts/yuque”
},
2)增加命令:
“scripts”: {
“sync”: “yuque-hexo sync”,
“clean:yuque”: “yuque-hexo clean”,
“deploy”: “npm run sync && hexo clean && hexo g -d”,
},
附上我的 package.json 文件。
2. serverless
目前阿里云和腾讯云都有 serverless 服务,免费的额度完全够用了,下面介绍一下如何配置:
1)创建函数

2)serverless 函数示例:
<?php
function main_handler($event, $context) {
// 解析语雀 post 的数据
$update_title = ”;
if($event->body){
$yuque_data= json_decode($event->body);
$update_title .= $yuque_data->data->title;
}
// default params
$repos = ‘xxxx’; // 你的仓库 id 或 slug
$token = ‘xxxxxx’; // 你的登录 token
$message = date(“Y/m/d”).’:yuque update:’.$update_title;
$branch = ‘master’;
// post params
$queryString = $event->queryString;
$q_token = $queryString->token ? $queryString->token : $token;
$q_repos = $queryString->repos ? $queryString->repos : $repos;
$q_message = $queryString->message ? $queryString->message : $message;
$q_branch = $queryString->branch ? $queryString->branch : ‘master’;
echo($q_token);
echo(‘===’);
echo ($q_repos);
echo (‘===’);
echo ($q_message);
echo (‘===’);
echo ($q_branch);
echo (‘===’);
//request travis ci
$res_info = triggerTravisCI($q_repos, $q_token, $q_message, $q_branch);

$res_code = 0;
$res_message = ‘ 未知 ’;
if($res_info[‘http_code’]){
$res_code = $res_info[‘http_code’];
switch($res_info[‘http_code’]){
case 200:
case 202:
$res_message = ‘success’;
break;
default:
$res_message = ‘faild’;
break;
}
}
$res = array(
‘status’=>$res_code,
‘message’=>$res_message
);
return $res;
}

/*
* @description travis api , trigger a build
* @param $repos string 仓库 ID、slug
* @param $token string 登录验证 token
* @param $message string 触发信息
* @param $branch string 分支
* @return $info array 回包信息
*/
function triggerTravisCI ($repos, $token, $message=’yuque update’, $branch=’master’) {
// 初始化
$curl = curl_init();
// 设置抓取的 url
curl_setopt($curl, CURLOPT_URL, ‘https://api.travis-ci.org/repo/’.$repos.’/requests’);
// 设置获取的信息以文件流的形式返回,而不是直接输出。
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
// 设置 post 方式提交
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, “POST”);
// 设置 post 数据
$post_data = json_encode(array(
“request”=> array(
“message”=>$message,
“branch”=>$branch
)
));
$header = array(
‘Content-Type: application/json’,
‘Travis-API-Version: 3’,
‘Authorization:token ‘.$token,
‘Content-Length:’ . strlen($post_data)
);
curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data);
// 执行命令
$data = curl_exec($curl);
$info = curl_getinfo($curl);
// 关闭 URL 请求
curl_close($curl);
return $info;
}
?>

这里有几个需要获取的参数:
travis 登录 token,在 travis-ci.org 中设置界面获取:

仓库 ID 或 扩展名,
使用 findder 或者 postman 发起一个请求:https://api.travis-ci.org/owner/Ghostdar/repos
回包中可以获取到 ID 和 slug。
3)配置触发方式

一般会得到这么个 api:https://service-s08f6nvk-1251…
3. 语雀配置
配置一个仓库的 webhook:
可以选择所有更新触发或者主动触发,主动触发的意思即发布需要勾选一个选项才会触发 webhook。具体可参见语雀文档:https://www.yuque.com/yuque/developer/doc-webhook;将 serverless 生成的 api 填入, 可以在链接后面带参数:
token 登录 token
repos 仓库 id
message 提交信息
branch 分支

示例:
https://service-s08f6nvk-1251833201.ap-guangzhou.apigateway.myqcloud.com/release/xxx?repos=xxx&token=xxx&message=xxx&branch=xxx

如果不在链接带参数则写在 serverless 函数内。
4. 开始发布或更新一篇文章
发布或者更新一篇文章后,我们前往 travis-ci, 可以看到已经触发了一次构建请求:
构建完成后,咱们的博客上已经妥妥的展示出来拉~
附上博客地址:https://ghostdar.github.io/,羞耻的求个 star~

三、其他的思路
1. github api 
可以使用 github 的 api,每当更新文章,自动生成一个 commit,触发 travis-ci 构建,但是感觉工作量很大,就放弃了~
2. 有待挖掘的 travis-ci 
目前我使用的方法是 trigger a build,其实可以做到更多的 自定义配置~ 为啥不研究?主要是我懒~ 当然,如果有更好的方案也欢迎交流~
最后:
再次感谢语雀开发 webhook,以及 @尹挚 大神的 yuque-hexo 插件~ 附上地址:

yuque-hexo: https://github.com/x-cold/yuque-hexo

yuque-blog: https://github.com/x-cold/yuque-blog

正文完
 0