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

注意
本文最后更新于 2022-07-01,文中内容可能已过时。

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快速入门

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

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 事件 - 分支匹配留空可监听所有分支。

https://cdn.ftls.xyz/images/2022/06/20220629135254.png
Push触发

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

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

https://cdn.ftls.xyz/images/2022/06/20220629140042.png
配置执行主机组和构建命令

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

1
2
3
4
5
6
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'

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

https://cdn.ftls.xyz/images/2022/06/20220629140400.png
成功

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

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

Dockerfile:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
FROM alpine as certs
RUN apk update && apk add ca-certificates

FROM busybox:glibc
COPY --from=certs /etc/ssl/certs /etc/ssl/certs

ENV OSSUTIL_VERSION 1.7.13

RUN mkdir -p /usr/local/bin \
    && wget http://gosspublic.alicdn.com/ossutil/${OSSUTIL_VERSION}/ossutil64 -O /usr/local/bin/ossutil \
    && chmod +x /usr/local/bin/ossutil

ENTRYPOINT ["/usr/local/bin/ossutil"]

原使用镜像: chuangbo/ossutil

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

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

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

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

https://cdn.ftls.xyz/images/2022/06/20220629133459.png
Gitee上添加凭证

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

ENDPOINT

ACCESS_KEY_ID

ACCESS_KEY_SECRET

BUCKET_NAME

https://cdn.ftls.xyz/images/2022/06/20220629181009.png
全局参数配置

在配置中引用

https://cdn.ftls.xyz/images/2022/06/20220629181205.png
流水线内参数引用

配置任务

https://cdn.ftls.xyz/images/2022/06/20220629181123.png
配置任务

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

构建命令

1
2
3
4
5
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 '完成推送'

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

选择一个小 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的安装和一些测试

构建命令填写

1
2
3
4
5
6
7
8
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 # 查看是否成功
https://cdn.ftls.xyz/images/2022/06/20220701120505.png
构建命令填写

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

https://cdn.ftls.xyz/images/2022/06/20220701120742.png
执行结果
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
[2022-07-01 04:05:13]  ##################################################################################
[2022-07-01 04:05:13]  #             ____________.    _       __                                        #
[2022-07-01 04:05:13]  #            / __________/    (*)  .__/ /_.   _________.   _________.            #
[2022-07-01 04:05:13]  #           / /   ________.  / /  /__  __/   / _____  /   / _____  /             #
[2022-07-01 04:05:13]  #          / /   /_____/ /  / /    / /      / /____/ /   / /____/ /              #
[2022-07-01 04:05:13]  #         / /________/ /   / /    / /__.   / /______.   / /______.               #
[2022-07-01 04:05:13]  #         \_____**____/   /_/    /_**_/    \__**___/    \__**___/                #
[2022-07-01 04:05:13]  #                                                                                #
[2022-07-01 04:05:13]  ################################################################################## 
[2022-07-01 04:05:13] 
[2022-07-01 04:05:13] 开始测试
[2022-07-01 04:05:13] fetch https://mirrors.aliyun.com/alpine/v3.16/main/x86_64/APKINDEX.tar.gz
[2022-07-01 04:05:16] fetch https://mirrors.aliyun.com/alpine/v3.16/community/x86_64/APKINDEX.tar.gz
[2022-07-01 04:05:19] (1/3) Installing libgcc (11.2.1_git20220219-r2)
[2022-07-01 04:05:19] (2/3) Installing libstdc++ (11.2.1_git20220219-r2)
[2022-07-01 04:05:20] (3/3) Installing hugo (0.99.1-r0)
[2022-07-01 04:05:56] Executing busybox-1.35.0-r13.trigger
[2022-07-01 04:05:56] OK: 61 MiB in 17 packages
[2022-07-01 04:05:56] hugo v0.99.1-57dae1c2a4fbd9563f9c1ebf4196b5c5de4d6878+extended linux/amd64 BuildDate=2022-05-18T16:48:40Z
[2022-07-01 04:05:56] Connecting to gosspublic.alicdn.com (140.249.40.227:443)
[2022-07-01 04:05:56] saving to 'ossutil64'
[2022-07-01 04:05:56] ossutil64            100% |********************************|  9.9M  0:00:00 ETA
[2022-07-01 04:05:56] 'ossutil64' saved
[2022-07-01 04:05:56] [Credentials]
[2022-07-01 04:05:56] language=CH
[2022-07-01 04:05:56] endpoint=******
[2022-07-01 04:05:56] accessKeyID=******
[2022-07-01 04:05:56] accessKeySecret=******

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

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