Back

Gitee借助 Gitee Go 将博客(文档知识库)上传至阿里云 OSS 中

本文借助Gitee Go实现上传博客到阿里云中,成品在 https://note.ftls.xyz 。有两种方法可以实现。

准备工作

  1. 博客本体,存储至 Gitee 中。并开通了 Gitee Go。
  2. 阿里云存储桶一个。准备存储桶参数 endpoint , bucketname。 并在基础设置中开启静态页面服务。
  3. 有存储桶写入权限的阿里云 AccessKey 。即 accessKeyID 和 accessKeySecret 。
  4. 服务器一台。不需要有公网ip,但是要有网。能被添加到 Gitee 主机组管理 即可。
  5. Docker软件 + Docker 仓库 + Gitee 凭证管理添加凭证 + Gitee 私人令牌

注意: 阿里OSS静态页面服务和阿里云CDN的OSS私有Bucket回源冲突! 原因及解决方案

注意: 4,5满足其中一个即可。

说明: 本文使用docsify作为博客网站生成渲染工具。docsify十分小巧。比起其他软件生成的一堆文件,docsify只需上传源文件。流量存储开销都很小。/root /home/kkbt

资料

命令行工具ossutil快速入门

步骤

方法一 Shell 脚本执行

该方法大约执行 3s .总文件大小不到 100k ,文件数不到 20.

在服务器上下载 git 和 ossutil

git clone 自己的项目,git 操作私有库可以使用 git config --global credential.helper store 存储密码。或者

git clone https://<用户名>:<私人令牌>@gitee.com/<用户名>/<项目名>/

ossutil 安装和使用见命令行工具ossutil快速入门

主机组管理添加

打开 Gitee 主机组管理

新建一组主机,添加主机。然后将命令复制到自己的服务器上(可以没有公网ip)。等待完成。

具体可见 https://gitee.com/help/categories/76

然后在 Gitee 新建一条流水线,触发事件选择 Push 事件 - 分支匹配留空可监听所有分支。

Push触发
Push触发

Gitee Go 任务编排-工具Shell 脚本执行: 在指定主机组执行Shell脚本,可完成测试、部署等任务。

选择 任务编排,添加一个新任务。在 工具- Shell 脚本执行 中配置执行主机组和构建命令。

配置执行主机组和构建命令
配置执行主机组和构建命令

构建命令就是会在自己服务器执行的脚本,可以参考

echo 'Start Push To OSS'
cd /home/kkbt/note
git pull
/home/kkbt/ossutil64 cp /home/kkbt/note/ oss://bucketname -rf --only-current-dir
/home/kkbt/ossutil64 cp /home/kkbt/note/text/ oss://bucketname/text -rf 
echo 'The End of Push'
bash

两条上传主要排除 .git 文件夹。主要因为里面文件很多,还没必要上传。这之后只要Push就会触发脚本上传。

成功
成功

方法二 Docker

该方法大约执行 30s .总文件大小不到 100k ,文件数不到 20. 可自行打包镜像,也可以使用 alpine 或 ubuntu 。

构建镜像

开源项目地址 https://github.com/chuangbo/docker-ossutil

Dockerfile:

原使用镜像: chuangbo/ossutil

我自己clone一个并更新了 1.7.13 版本 . 放在阿里云公开仓库了. 大约 15M 。地址:

registry.cn-hangzhou.aliyuncs.com/kkbt/ossutil:1.7.13
text

Docker仓库的配置

本文使用了阿里云容器镜像服务作为Docker私人镜像仓库。创建命名空间、创建镜像仓库。一个仓库可以存储不同版本的镜像。在容器镜像服务/实例列表/镜像仓库/基本信息中可以找到操作指南。

打开Gitee 凭证管理添加凭证。

Gitee上添加凭证
Gitee上添加凭证

配置流水线

在 Giee 流水线设置四个全局参数

ENDPOINT

ACCESS_KEY_ID

ACCESS_KEY_SECRET

BUCKET_NAME

全局参数配置
全局参数配置

在配置中引用

流水线内参数引用
流水线内参数引用

配置任务

配置任务
配置任务

镜像地址 registry.cn-hangzhou.aliyuncs.com/kkbt/ossutil:1.7.13

构建命令

echo '开始构建'
/usr/local/bin/ossutil config -e ${ENDPOINT} -i ${ACCESS_KEY_ID} -k ${ACCESS_KEY_SECRET} -L CH -c /root/.ossutilconfig # 生成配置文件
/usr/local/bin/ossutil cp . oss://${BUCKET_NAME} -rf --only-current-dir 
/usr/local/bin/ossutil cp ./text/ oss://${BUCKET_NAME}/text -rf 
echo '完成推送'
bash

我两条上传主要不上传 .git 文件夹。而阿里的 ossutil 不能排除文件夹,只能排除文件。至少 1.7.13 版本是这样。

需要使用 Hugo , Hexo 等需要构建的博客

选择一个小 Linux 镜像 alpine。拉取镜像地址。拉取镜像地址 docker.io/alpine:latest 。

基于镜像的脚本执行的镜像地址填写 docker.io/alpine:latest。需要什么就安装什么,如hugo,hexo,zola等。

hexo 需要先安装 npm ,再使用 npm install -g hexo-cli 安装。hugo , zola 都可以通过 apk 安装。目前 mdbook 没有编译好的包,需要安装 Rust 环境,编译安装。

下面是hugo的安装和一些测试

构建命令填写

echo '开始测试'
sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories # alpine 包管理 apk 换源
apk add hugo # apk 安装 hugo
hugo version # 测试 hugo
wget https://gosspublic.alicdn.com/ossutil/1.7.13/ossutil64 # 下载 ossutil64
chmod 755 ossutil64 # 赋予 ossutil64 执行权限
./ossutil64 config -e ${ENDPOINT} -i ${ACCESS_KEY_ID} -k ${ACCESS_KEY_SECRET} -L CH -c /root/.ossutilconfig # 生成配置文件
cat /root/.ossutilconfig # 查看是否成功
bash
构建命令填写
构建命令填写

构建详情-基于镜像的脚本执行-执行日志脚本执行结果

执行结果
执行结果

总结

配合 OSS 的 CDN 更新触发,很好的完成了网站的自动部署和更新。

两个方法都跟通用,第二个通过简单配置即可使用。

Gitee 借助 Gitee Go 将博客或文档知识库上传至阿里云 OSS 中
https://www.ftls.xyz/posts/gitee-oss/
Author 恐咖兵糖
Published at
Copyright CC BY-NC-SA 4.0