这个开源工具,为我省下了大量的时间!

简介: 此前,我维护的多个 GitHub 项目都需要同时部署 GitHub Pages 和 Gitee Pages 国内镜像站点。

此前,我维护的多个 GitHub 项目都需要同时部署 GitHub Pages 和 Gitee Pages 国内镜像站点。


对于 GitHub,当我们将项目的变更 push 到 GitHub 远程仓库时,会触发 GitHub Pages 的自动化部署,将项目的最新内容更新到 GitHub Pages 站点。如下图所示:


12.png


然而,对于 Gitee,一个头疼的问题是,虽然我们可以利用一些镜像同步脚本或工具(如:git-mirror-action)将 GitHub 项目同步至 Gitee 仓库,但我们却无法自动化部署 Gitee Pages,而必须手动登录 Gitee,并且手动点击更新


为什么呢??因为,Gitee Pages 自动化部署要收费!99 块钱一年!!如果我们想要在不交钱的情况下实现 Gitee Pages 自动化部署(白嫖?),那么按照此前,只能努力让我们的 Gitee 开源项目变得足够好,得到官方的推荐后,会显示“您的项目为推荐项目,已自动为您开通 Gitee Pages Pro”,这样就可以自动化了。


13.png


插播一个码云官方最新消息,“因业务调整,Gitee Pages Pro 暂时关闭个人用户购买入口,已开通用户的仓库不受影响。GVP 项目和付费企业使用不受影响。” 也就是说,现在想花钱图个省事都不行了。。


然而,对于很多私人博客,或者说开源项目刚创建不久的,通常来说这种项目 stars 数很少,想得到官方的推荐,呵呵,不可能!所以我开发了 Gitee Pages Action 工具,无须人工,即可实现 Gitee Pages 的自动化部署!只需要在我们的 GitHub 项目 Settings 页面下配置 keys,然后在 .github/workflows/ 下创建一个工作流,引入一些配置参数即可。


抛一下开源工具的地址,点击阅读也能直达,这个开源工具将会持续维护,欢迎关注!

https://github.com/yanglbme/gitee-pages-action


下面我为大家详细讲一下工具的入参,以及具体如何使用,若有使用上的问题,也欢迎随时反馈。


入参


参数 描述 是否必传 默认值
gitee-username Gitee 用户名 -
gitee-password Gitee 密码 -
gitee-repo Gitee 仓库(严格区分大小写) -
branch 要部署的分支 master
directory 要部署的分支上的目录 ''
https 是否强制使用 HTTPS true


示例


以下是一个完整的使用示例。


在你的 GitHub 仓库 .github/workflows/ 文件夹下创建一个 sync.yml 文件,内容如下:


name: Syncon:  push:    branches: [ master ]jobs:  build:    runs-on: ubuntu-latest    steps:    - name: Sync to Gitee      uses: wearerequired/git-mirror-action@master      env:          # 注意在 Settings->Secrets 配置 GITEE_RSA_PRIVATE_KEY          SSH_PRIVATE_KEY: ${{ secrets.GITEE_RSA_PRIVATE_KEY }}      with:          # 注意替换为你的 GitHub 源仓库地址          source-repo: "git@github.com:doocs/advanced-java.git"          # 注意替换为你的 Gitee 目标仓库地址          destination-repo: "git@gitee.com:Doocs/advanced-java.git"    - name: Build Gitee Pages      uses: yanglbme/gitee-pages-action@master      with:          # 注意替换为你的 Gitee 用户名          gitee-username: yanglbme          # 注意在 Settings->Secrets 配置 GITEE_PASSWORD          gitee-password: ${{ secrets.GITEE_PASSWORD }}          # 注意替换为你的 Gitee 仓库,仓库名严格区分大小写,请准确填写,否则会出错          gitee-repo: doocs/advanced-java


先使用 wearerequired/git-mirror-action 将 GitHub 仓库同步到 Gitee 仓库,再使用 yanglbme/gitee-pages-action 实现 Gitee Pages 的自动部署。


请确保在 GitHub 项目的 Settings -> Secrets 路径下配置好 GITEE_RSA_PRIVATE_KEY 以及 GITEE_PASSWORD 两个密钥。其中:


GITEE_RSA_PRIVATE_KEY: 存放你的 id_rsa 私钥。

GITEE_PASSWORD: 存放你的 Gitee 账户密码。


如果一切配置正常,并成功触发 Gitee Pages Action ,我们可能会收到一封来自 Gitee 的告警邮件/站内信。放心,这是 GitHub Action 程序帮我们登录到 Gitee 官网,并为我们点击了项目的部署按钮。


FAQ


问题 1:遇到短信验证码导致无法自动部署,怎么解决?


因为 Gitee Pages Action 使用的是 GitHub 自家的服务器(美国),在这种情况下,当 Action 自动帮我们登录 Gitee 的时候,会触发 Gitee 帐号异常登录告警,提示用户在非正常的 IP 地址登录了 Gitee,需要输入验证码。


解决方案是:关注「码云 Gitee」 微信公众号,绑定个人微信到码云帐号。这样 Action 在登录的过程中,Gitee 就不会下发短信验证码,而是通过「码云 Gitee」公众号给我们发送一个登录通知,Action 就能成功登录了。


14.png


问题 2:报 deploy error occurred, message: 'NoneType' object has no attribute 'group' 错误,怎么办?


报了这个错误,说明 Action 已经成功帮我们登录 Gitee 帐号了,但在访问 Gitee Repo 的过程中出现问题。


这种情况,一般是 Gitee Pages Action 的参数配置错误导致,请仔细检查你的配置信息。


注意:gitee-repo 参数严格区分大小写,请准确填写,比如 doocs/advanced-java,当你写成 doocs/Advanced-java 的时候,是访问不到的,不信你可以试试访问:https://gitee.com/Doocs/Advanced-java


谁在使用?


目前,蚂蚁金服数据可视化团队有赞技术团队、还有 Doocs 开源社区等多个开源项目都在使用 Gitee Pages Action,所以,我也把它推荐给你。感兴趣的朋友,也可以 star 关注一波!


15.png

目录
相关文章
|
1月前
|
Prometheus 监控 Cloud Native
【揭秘可观测性】构建完美参考框架,打造系统监控的瑞士军刀!
【8月更文挑战第25天】在现代软件设计中,可观测性是确保系统稳定性和效率的关键因素。它主要由日志、指标及链路追踪(统称LMx)三大核心组件构成。本文详细介绍了构建高效可观测性框架的六个步骤:需求分析、工具选择、数据收集策略设计、实施集成、数据可视化及持续优化。并通过一个Spring Boot应用集成Prometheus和Micrometer收集指标的示例,展示了具体实践方法。合理构建可观测性框架能显著提升团队对软件系统的管理和监控能力,进而增强系统整体性能和可靠性。
53 2
|
2月前
|
API 运维
开发与运维数据问题之LangChain帮助处理长篇报告如何解决
开发与运维数据问题之LangChain帮助处理长篇报告如何解决
50 1
|
4月前
|
程序员 流计算 Docker
Flink程序员开发利器本地化WebUI生成
Flink程序员开发利器本地化WebUI生成
66 0
|
前端开发 小程序 测试技术
靠谱:开源IM项目OpenIM压测程序介绍-自己动手测试性能和稳定性
靠谱:开源IM项目OpenIM压测程序介绍-自己动手测试性能和稳定性
682 0
|
监控 Java 测试技术
阿里巴巴在开源压测工具 JMeter 上的实践和优化
Apache JMeter 是 Apach 旗下的开源压测工具,创建于 1999 年初,迄今已有超过 20 年历史。JMeter 功能丰富,社区(用户群体)庞大,是主流开源压测工具之一。
阿里巴巴在开源压测工具 JMeter 上的实践和优化
|
运维 Oracle 关系型数据库
[自制工具]简便易用的ADDM报告生成工具
Oracle数据库自带的ADDM报告生成工具有一些依赖条件,使用比较繁琐,而且报告名字不易于区分、分发。 所以一直想写一个简单、易用的ADDM报告工具,今天终于把这个工具编写、调试完毕,现正式发布,也同时发布在GitHub。
378 0
|
固态存储 架构师 测试技术
【资源分享】esrally:Elasticsearch 官方压测工具测试数据共享(国内)
自从上篇发布的关于“【最佳实践】esrally:Elasticsearch 官方压测工具及运用详解”后,不停有同学询问使用中遇到的问题,尤其是测试数据存储在国外 aws 上,导致下载极慢的情况出现。为了让大家快速上手使用 esrally,我 build 了一个可用的 docker 镜像,将 13GB 的测试数据拉取到国内的存储上,通过百度网盘的方式分享给大家。大家只要按照下面简单的几步操作就可以顺畅地使用 esrally 来进行相关测试了。
3535 0
【资源分享】esrally:Elasticsearch 官方压测工具测试数据共享(国内)
小工具发布:车辆违章查询 v1.0.0.1
Vista/Win7的桌面小工具 目前支持的地区:辽宁(辽阳K) 已经发布到Microsoft的百宝箱   下载地址:http://gallery.live.com/LiveItemDetail.
1071 0
|
Web App开发 Windows
迁云工具1.5.1.5版本发布
信息摘要: 提供多项优化并修复了已知问题。适用客户: 适用于从物理机环境、其他云平台和各类私有云环境迁移服务器至阿里云的用户。版本/规格功能: 1. 增加中转磁盘自动扩容功能; 2. 优化Windows还原检查功能; 3. 增加显示详细传输模式--verbose; 4. 其他已知问题修复。
1021 0