当前位置: 首页 > article >正文

写段代码教会你什么是HOOK技术?HOOK技术能干什么?荡

为 HagiCode 添加 GitHub Pages 自动部署支持本项目早期代号为 PCode现已正式更名为 HagiCode。本文记录了如何为项目引入自动化静态站点部署能力让内容发布像喝水一样简单。背景/引言在 HagiCode 的开发过程中我们遇到了一个很现实的问题随着文档和提案越来越多如何高效地管理和展示这些内容成了当务之急。我们决定引入 GitHub Pages 来托管我们的静态站点但是手动构建和部署实在是太麻烦了——每次改动都要本地构建、打包然后手动推送到 gh-pages 分支。这不仅效率低下还容易出错。为了解决这个问题主要是为了偷懒我们需要一套自动化的部署流程。本文将详细记录如何为 HagiCode 项目添加 GitHub Actions 自动部署支持让我们只需专注于内容创作剩下的交给自动化流程。关于 HagiCode嘿介绍一下我们正在做的东西我们正在开发 HagiCode——一款 AI 驱动的代码智能助手让开发体验变得更智能、更便捷、更有趣。智能——AI 全程辅助从想法到代码让编码效率提升数倍。便捷——多线程并发操作充分利用资源开发流程顺畅无阻。有趣——游戏化机制和成就系统让编码不再枯燥充满成就感。项目正在快速迭代中如果你对技术写作、知识管理或者 AI 辅助开发感兴趣欢迎来 GitHub 看看目标分析在动手之前我们得先明确这次任务到底要干啥。毕竟磨刀不误砍柴工嘛。核心需求自动化构建当代码推送到 main 分支时自动触发构建流程。自动部署构建成功后自动将生成的静态文件部署到 GitHub Pages。环境一致性确保 CI 环境和本地构建环境一致避免本地能跑线上报错的尴尬。技术选型考虑到 HagiCode 是基于 Docusaurus 构建的一种非常流行的 React 静态站点生成器我们可以利用 GitHub Actions 来实现这一目标。配置 GitHub Actions 工作流GitHub Actions 是 GitHub 提供的 CI/CD 服务。通过在代码仓库中定义 YAML 格式的工作流文件我们可以定制各种自动化任务。创建工作流文件我们需要在项目根目录下的 .github/workflows 文件夹中创建一个新的配置文件比如叫 deploy.yml。如果文件夹不存在记得先手动创建一下。这个配置文件的核心逻辑如下触发条件监听 main 分支的 push 事件。运行环境最新版的 Ubuntu。构建步骤检出代码安装 Node.js安装依赖 (npm install)构建静态文件 (npm run build)部署步骤使用官方提供的 action-gh-pages 将构建产物推送到 gh-pages 分支。关键配置代码以下是我们最终采用的配置模板name: Deploy to GitHub Pages# 触发条件当推送到 main 分支时on:push:branches:- main# 可以根据需要添加路径过滤比如只有文档变动才构建# paths:# - docs/**# - package.json# 设置权限这对于部署到 GitHub Pages 很重要permissions:contents: readpages: writeid-token: write# 并发控制取消同一分支的旧构建concurrency:group: pagescancel-in-progress: falsejobs:build:runs-on: ubuntu-lateststeps:- name: Checkoutuses: actions/checkoutv4# 注意必须设置 fetch-depth: 0否则可能导致构建版本号不准确with:fetch-depth: 0- name: Setup Nodeuses: actions/setup-nodev4with:node-version: 20 # 建议与本地开发环境保持一致cache: npm # 启用缓存可以加速构建过程- name: Install dependenciesrun: npm ci# 使用 npm ci 而不是 npm install因为它更快、更严格适合 CI 环境- name: Build websiterun: npm run buildenv:# 如果你的站点构建需要环境变量在这里配置# NODE_ENV: production# PUBLIC_URL: /your-repo-name- name: Upload artifactuses: actions/upload-pages-artifactv3with:path: ./build # Docusaurus 默认输出目录deploy:environment:name: github-pagesurl: ${{ steps.deployment.outputs.page_url }}runs-on: ubuntu-latestneeds: buildsteps:- name: Deploy to GitHub Pagesid: deploymentuses: actions/deploy-pagesv4实施过程中的坑点在实际操作中我们遇到了一些问题这里分享出来希望大家能避开或者提前准备好解决方案。1. GitHub Token 权限问题最开始配置的时候部署总是报错 403 (Forbidden)。查了好久才发现是因为 GitHub 默认的 GITHUB_TOKEN 并没有写入 Pages 的权限。解决方案在仓库的 Settings - Actions - General - Workflow permissions 中务必选择 Read and write permissions。2. 构建目录路径错误Docusaurus 默认把构建好的静态文件放在 build 目录。但是有些项目比如 Create React App 默认是 buildVite 默认是 dist可能配置不一样。如果在 Actions 中报错找不到文件记得去 docusaurus.config.js 里检查一下输出路径配置。3. 子路径问题如果你的仓库不是用户主页即不是 username.github.io而是项目主页比如 username.github.io/project-name你需要配置 baseUrl。在 docusaurus.config.js 中module.exports {// ...url: https://HagiCode-org.github.io, // 你的 GitHub URLbaseUrl: /site/, // 如果你的仓库叫 site这里就填 /site/// ...};这一点很容易被忽略配置不对会导致页面打开全是白屏因为资源路径加载不到。验证成果配置完所有东西并推送代码后我们就可以去 GitHub 仓库的 Actions 标签页看戏了。你会看到黄色的圆圈工作流正在运行变绿就代表成功啦如果变红了点击进去查看日志通常都能排查出问题大部分时候是拼写错误或者路径配置不对。构建成功后访问 https://你的用户名.github.io/仓库名/ 就能看到崭新的站点了。总结通过引入 GitHub Actions我们成功实现了 HagiCode 文档站的自动化部署。这不仅节省了手动操作的时间更重要的是保证了发布流程的标准化。现在不管是哪位小伙伴更新了文档只要合并到 main 分支几分钟后就能在线上看到最新的内容。核心收益效率提升从手动打包、手动上传变成代码即发布。降低错误消除了人为操作失误的可能性。体验优化让开发者更专注于内容质量而不是被繁琐的部署流程困扰。杏臣瞎缚

相关文章:

写段代码教会你什么是HOOK技术?HOOK技术能干什么?荡

为 HagiCode 添加 GitHub Pages 自动部署支持 本项目早期代号为 PCode,现已正式更名为 HagiCode。本文记录了如何为项目引入自动化静态站点部署能力,让内容发布像喝水一样简单。 背景/引言 在 HagiCode 的开发过程中,我们遇到了一个很现实的问…...

Baiduwp-PHP:3分钟搭建百度网盘高速下载解析服务

Baiduwp-PHP:3分钟搭建百度网盘高速下载解析服务 【免费下载链接】baiduwp-php A tool to get the download link of the Baidu netdisk / 一个获取百度网盘分享链接下载地址的工具 项目地址: https://gitcode.com/gh_mirrors/ba/baiduwp-php 还在为百度网盘…...

越用越强不是广告语:拆解 Hermes Agent 的三层学习机制

用 AI agent 有一段时间了,有个问题一直没解决:每次开新会话,它对我的项目和习惯还是一无所知。上下文配置文件里写了不少,但写进去的是静态的——它不会自己学,也不会根据我真实的操作习惯去调整。跑得熟不熟&#xf…...

CANKing隐藏功能大揭秘:用Traffic Generator做压力测试的5个实战技巧

CANKing隐藏功能大揭秘:用Traffic Generator做压力测试的5个实战技巧 在汽车电子控制系统开发中,CAN总线压力测试是验证ECU稳定性和可靠性的关键环节。许多工程师虽然熟悉CANKing的基础功能,却忽略了其内置的Traffic Generator工具在复杂场景…...

3分钟搞定!WinCDEmu免费虚拟光驱终极指南:告别实体光盘的时代

3分钟搞定!WinCDEmu免费虚拟光驱终极指南:告别实体光盘的时代 【免费下载链接】WinCDEmu 项目地址: https://gitcode.com/gh_mirrors/wi/WinCDEmu 还在为找不到光驱而烦恼吗?还在为ISO文件打不开而困扰吗?今天我要向你介绍…...

SolidWorks2020多版本共存攻略:如何在同一台电脑上安装多个版本

SolidWorks多版本共存实战指南:从安装到优化的完整方案 对于机械设计师、工程师和学生而言,有时需要在同一台计算机上运行多个版本的SolidWorks。可能是为了兼容不同客户的项目文件,或是测试新版本功能的同时保留稳定版本。本文将深入探讨如何…...

Agent之HarnessEngineering:从“先别用聊天机器人写代码”到“持续让 agent 在后台运行”:一位软件工程师的 AI 采用之路、任务拆分与自我复现实践、下班时段代理任务、外包高确

Agent之HarnessEngineering:从“先别用聊天机器人写代码”到“持续让 agent 在后台运行”:一位软件工程师的 AI 采用之路、任务拆分与自我复现实践、下班时段代理任务、外包高确定性工作、harness engineering 设计方法,以及如何把 AI 变成可…...

RevokeMsgPatcher防撤回工具:5个简单步骤解决微信3.9.10.19版本兼容性问题

RevokeMsgPatcher防撤回工具:5个简单步骤解决微信3.9.10.19版本兼容性问题 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址:…...

15分钟搞定黑苹果:OpCore Simplify三步自动化配置指南

15分钟搞定黑苹果:OpCore Simplify三步自动化配置指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 你是否曾经被黑苹果复杂的配置过程吓…...

从 MVVMLight 到 CommunityToolkit.Mvvm:MVVM 框架的现代化演进与全面对比

本文围绕 MVVMLight 与 CommunityToolkit.Mvvm 的演进脉络、核心对比、实操差异及迁移指南 展开,帮助开发者快速完成技术选型与项目升级。在 WPF、UWP、MAUI、WinUI 3 等 XAML 技术体系中,MVVM 是实现界面与业务逻辑解耦的核心架构模式。 提到 MVVM 框架…...

Aeneas终极指南:3步搞定音频文本自动对齐,准确率超95% [特殊字符]

Aeneas终极指南:3步搞定音频文本自动对齐,准确率超95% 🔊 【免费下载链接】aeneas aeneas is a Python/C library and a set of tools to automagically synchronize audio and text (aka forced alignment) 项目地址: https://gitcode.com…...

测试数据管理:AI解决方案大比拼

在数字化转型的浪潮中,软件测试从业者面临的核心挑战之一是高效管理测试数据。测试数据作为质量保障的基石,直接影响缺陷检出率、测试覆盖度和发布周期。传统方法依赖手动生成和脱敏,不仅耗时耗力,还常因数据多样性不足、安全风险…...

Python的__complex__方法支持复数的实部虚部访问与运算重载

Python作为一门功能强大的编程语言,其面向对象特性允许开发者通过特殊方法自定义类的行为。其中,__complex__方法为复数运算提供了灵活的支持,使得开发者能够轻松实现复数的实部虚部访问与运算重载。复数在科学计算、信号处理等领域有着广泛应…...

终极魔兽世界字体解决方案:智能合并与字符集补全工具

终极魔兽世界字体解决方案:智能合并与字符集补全工具 【免费下载链接】Warcraft-Font-Merger Warcraft Font Merger,魔兽世界字体合并/补全工具。 项目地址: https://gitcode.com/gh_mirrors/wa/Warcraft-Font-Merger 在魔兽世界等大型多人在线游…...

达梦数据库归档日志配置与优化实战指南

1. 达梦数据库归档日志基础认知 第一次接触达梦数据库的归档日志时,我完全被各种专业术语搞懵了。后来在实际项目中踩过几次坑才明白,归档日志其实就是数据库的"时光机"。想象一下,你正在玩一个闯关游戏,归档日志就是游…...

​[特殊字符]1 概述无线可充电传感器网络(WRSN)中公交网络辅助的无人机调度研究摘要:无线可充电传感器网络(WRSN)被广泛应用于环境和交通监测、视频监控和医疗护理等领域,有助于提高城市生活质

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

ESP32驱动GC9A01圆形屏:从图片数据到240x240全屏显示的实战解析

1. 硬件准备与连线指南 第一次拿到GC9A01圆形屏时,我对着密密麻麻的引脚有点懵——这玩意儿该怎么接ESP32?后来发现其实只要搞清楚几个关键引脚就能搞定。这块240x240的圆形屏通常有8个引脚,但实际必须接的只有6根线。我用的这块屏背面丝印很…...

鲲鹏麒麟服务器离线安装MySQL5.7全流程(含密码修改与远程访问配置)

鲲鹏麒麟服务器离线安装MySQL5.7全流程指南 在国产化技术快速发展的背景下,基于鲲鹏920处理器的麒麟服务器正逐渐成为企业级应用的新选择。这类服务器通常运行Kylin Linux Advanced Server V10操作系统,专为高性能计算和安全敏感场景设计。由于安全合规要…...

Java解析大疆无人机照片元数据:从EXIF到XMP的实战指南

1. 为什么需要解析大疆无人机照片元数据 当你用大疆无人机拍摄照片时,相机不仅记录了画面本身,还悄悄存储了大量"幕后花絮"。这些隐藏在照片里的元数据(Metadata)就像飞行黑匣子,包含了GPS坐标、飞行高度、相…...

Z-Image-GGUF助力游戏开发:快速生成概念原画与道具图标

Z-Image-GGUF助力游戏开发:快速生成概念原画与道具图标 做游戏,最让人头疼的环节之一,可能就是美术资源了。尤其是项目初期,策划脑子里天马行空的想法,要变成一张张看得见摸得着的概念图、道具图标,这个过…...

【咸鱼之王】H5修复版:从零到一,宝塔面板+Nginx+Mysql一站式部署实战

1. 环境准备与宝塔面板安装 第一次接触H5游戏服务端搭建的朋友可能会觉得无从下手,但其实只要跟着步骤走,用宝塔面板可以省去80%的配置工作。我去年帮朋友部署过三个类似的H5游戏,实测宝塔面板是最适合新手的方案。 先确认你的CentOS 7.6系统…...

SpringBoot项目容器化后,FFmpeg命令怎么调用宿主机?SSH免密登录实战避坑指南

SpringBoot容器化项目中安全调用宿主机FFmpeg的工程实践 在视频处理类项目的容器化部署过程中,一个常见的架构难题是如何在容器内高效调用宿主机的FFmpeg等多媒体处理工具。传统做法是在每个容器内部安装FFmpeg,但这会导致镜像体积膨胀、硬件加速配置复杂…...

【ABAP】-TSV_TNEW_PAGE_ALLOC_FAILED:从ADRV冗余数据膨胀到BP维护性能危机的深度剖析与根治

1. 问题现象与业务影响 那天下午三点,采购部门的Lisa正在维护一个关键供应商的BP主数据。突然,她的SAP界面卡住了,紧接着弹出一个红色错误框:"TSV_TNEW_PAGE_ALLOC_FAILED - 内存分配失败"。这个看似简单的错误背后&…...

Text-to-CAD UI:重构机械设计流程的数字化转型方案

Text-to-CAD UI:重构机械设计流程的数字化转型方案 【免费下载链接】text-to-cad-ui A lightweight UI for interfacing with the Zoo text-to-cad API, built with SvelteKit. 项目地址: https://gitcode.com/gh_mirrors/te/text-to-cad-ui 在工程制造领域&…...

终极Transformer部署指南:从训练到生产环境的完整流程

终极Transformer部署指南:从训练到生产环境的完整流程 【免费下载链接】transformer A TensorFlow Implementation of the Transformer: Attention Is All You Need 项目地址: https://gitcode.com/gh_mirrors/tr/transformer Transformer作为"Attentio…...

【AIAgent记忆可靠性白皮书】:IEEE标准级记忆校验协议、CRDT同步算法落地实践,及3类高危记忆漂移预警阈值

第一章:AIAgent架构中的记忆机制设计 2026奇点智能技术大会(https://ml-summit.org) AI Agent 的长期有效性高度依赖其记忆机制——它不仅是信息暂存的“缓存区”,更是支撑推理连贯性、上下文感知与个性化行为演化的认知基座。现代 AIAgent 架构中&…...

终极Android适配器自定义指南:轻松打造专属baseAdapter组件

终极Android适配器自定义指南:轻松打造专属baseAdapter组件 【免费下载链接】baseAdapter Android 万能的Adapter for ListView,RecyclerView,GridView等,支持多种Item类型的情况。 项目地址: https://gitcode.com/gh_mirrors/ba/baseAdapter bas…...

DeepSeek-OCR:视觉压缩如何重塑长文本处理?解析DeepEncoder的架构设计与效率突破

1. DeepSeek-OCR的视觉压缩革命:为什么长文本处理需要新思路? 想象一下你要把一本300页的小说塞进一个只能装30页的信封里。传统方法可能是把字体缩小到几乎看不见,或者撕掉270页——这两种方案显然都不理想。这正是当前大语言模型&#xff0…...

终极指南:DeepSeek-OCR如何通过SAM+CLIP双编码器实现高精度文档识别

终极指南:DeepSeek-OCR如何通过SAMCLIP双编码器实现高精度文档识别 【免费下载链接】DeepSeek-OCR Contexts Optical Compression 项目地址: https://gitcode.com/gh_mirrors/de/DeepSeek-OCR DeepSeek-OCR是一款基于SAM(Segment Anything Model&…...

如何在6GB显存下解锁专业级AI图像生成?FLUX.1-dev FP8量化模型实战指南

如何在6GB显存下解锁专业级AI图像生成?FLUX.1-dev FP8量化模型实战指南 【免费下载链接】flux1-dev 项目地址: https://ai.gitcode.com/hf_mirrors/Comfy-Org/flux1-dev 你是否曾因显存不足而放弃使用高质量的AI图像生成模型?当大多数先进模型需…...