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

Git技巧:Git Hook,自动触发,含实战分享

Git技巧:Git Hook,自动触发,含实战分享

最近项目需要1个git合入时触发脚本的功能,使用Git Hook功能实现,总结如下:

Git项目在路径:repo\.git\hooks下有很多文件,这些文件就是本地钩子。

概念

Git Hook(Git 钩子)是 Git 提供的生命周期事件回调机制,允许在 Git 操作的关键阶段(如提交、推送、合并等)自动执行自定义脚本(Shell/Python/Node.js 等)。根据作用范围,可分为客户端钩子(本地开发流程)和服务端钩子(远程仓库权限控制)。以下是最常见的 Git Hook 功能场景及典型用途:

我们可以通过钩子在某一时刻,触发想做的事情,例如:

  1. 提交前检查
  2. 提交信息校验
  3. 推送前验证
  4. 提交后自动化

分类:

  • 客户端钩子:仅在本地仓库触发,用于约束开发者的提交、推送等操作。
  • 服务端钩子:在 Git 服务器(如 GitLab、GitHub)触发,用于全局控制推送行为(如分支保护、自动化部署)。
钩子名称类型触发时机核心作用示例场景
pre-commit客户端钩子git commit 执行时,暂存文件后、提交信息输入前校验代码质量(格式、语法)、运行预测试,阻止不合格提交运行 ESLint 检查代码格式,若失败则终止提交。
prepare-commit-msg客户端钩子git commit 执行时,提交信息编辑器(如 Vim)打开前自动生成或修改提交信息模板(如填充任务号、分支名)从分支名(feature/JIRA-123)提取任务号,自动写入提交信息。
commit-msg客户端钩子git commit 执行时,用户输入提交信息后、提交最终确认前校验提交信息格式(如 Conventional Commits 规范)强制提交信息以 feat: fix: 等类型开头,否则终止提交。
post-commit客户端钩子git commit 提交成功后提交后的通知或辅助操作(如发送消息、生成文档)提交后通过 Slack 通知团队新提交的哈希值。
pre-push客户端钩子git push 执行前(远程推送前)检查远程分支状态、运行集成测试,阻止无效推送推送前运行单元测试,测试失败则终止推送。
post-merge客户端钩子git mergegit rebase 合并完成后合并后的环境修复(如更新依赖、重新构建)合并后检测到 package-lock.json 变更,自动运行 npm install 安装新依赖。
pre-applypatch客户端钩子git am(应用邮箱补丁)或 git apply --apply(应用补丁文件)时,补丁写入工作目录前补丁应用前的预处理校验(如代码格式、敏感信息检查)检查补丁内容是否包含 password 等敏感词,若包含则终止补丁应用。
pre-receive服务端钩子服务器接收 git push 推送内容前(所有提交被处理前)全局校验推送内容(如权限、分支保护),阻止非法推送禁止向 main 分支直接推送(仅允许通过合并请求)。
post-receive服务端钩子服务器接收 git push 推送内容后(所有提交已写入仓库)触发后续操作(如自动部署、生成文档)推送后自动部署到生产环境(如拉取代码、重启服务)。

注意启用条件:钩子文件需移除 .sample 后缀(如 pre-commit.samplepre-commit),并通过 chmod +x 钩子名 赋予执行权限。

实战

在项目路径下执行 git init 创建Git库

创建测试文件 demo.py

def func_a():print("Hello A")  # 修改此行(触发行号变化)def func_b():print("Hello B")  # 新增此行(触发行号变化)

钩子文件内容(.git/hooks/pre-commit)
其中需要触发的test.py脚本放在SCRIPT_PATH="F:/my-project/test.py"
内容只需要简单打印,进行测试即可

#!/bin/sh
# 适用于 Windows Git Bash 环境的 pre-commit 钩子# 设置 Python 解释器路径(若 Python 已加入系统 PATH,可直接用 python)
PYTHON_EXE="python"  # 或完整路径(如 C:\\Python39\\python.exe)# 目标脚本路径(Windows 路径需用正斜杠或双反斜杠)
SCRIPT_PATH="F:/my-project/test.py"  # 或 F:\\my-project\\test.py# 执行脚本并捕获退出码
"$PYTHON_EXE" "$SCRIPT_PATH"
EXIT_CODE=$?# 若脚本执行失败(非零退出码),终止 commit
if [ $EXIT_CODE -ne 0 ]; thenecho "❌ pre-commit 钩子执行失败:脚本 $SCRIPT_PATH 退出码 $EXIT_CODE"exit 1
fi# 脚本执行成功,继续 commit
exit 0

可以看到在git commit后,会自动触发对应路径下的python脚本。

现在就动手配置你的第一个钩子,让代码提交与协作体验焕然一新吧!

相关文章:

  • 绘制板块层级图
  • AI与机器人外科手术:如何用智能化技术提升手术精度与安全性?
  • docker镜像构建常用参数
  • 实战篇:在QEMU中编写和调试VHost/Virtio驱动
  • [4282]PHP跨境电商源码-多语言商城源码/支持代理+商家入驻+分销+等等众多功能/带详细安装
  • 网工笔记-网络层
  • IS论文分享Estimating the Impact of “Humanizing” Customer Service Chatbots
  • 《AI大模型应知应会100篇》第39篇:多模态大模型应用:文本、图像和音频的协同处理
  • 探针台维护方法
  • EasyRTC嵌入式音视频通信SDK智能安防与监控系统的全方位升级解决方案
  • [Python开发] 如何用 VSCode 编写和管理 Python 项目(从 PyCharm 转向)
  • 局域网传文件——基于flask实现
  • 亚马逊云科技2025战略解析:AI驱动下的全球生态重塑
  • uni-app vue3 实现72小时倒计时功能
  • 从普查到防控:ArcGIS洪水灾害全流程分析技术实战——十大专题覆盖风险区划/淹没制图/水文分析/洪水分析/淹没分析/项目交流,攻克防洪决策数据瓶颈!
  • 「Mac畅玩AIGC与多模态05」部署篇03 - 在 Mac 上部署本地向量化模型(Embedding Models)
  • Deepseek-v3+cline+vscode java自动化编程
  • codeforcesB. Alice‘s Adventures in Permuting
  • VSCode 查看文件的本地修改历史
  • 推荐 1 款 9.3k stars 的全景式开源数据分析与可视化工具
  • 释新闻|西葡大停电为何规模大、恢复慢?可再生能源是罪魁祸首?
  • 人民日报评论员:汇聚起工人阶级和广大劳动群众的磅礴力量
  • 赛力斯拟赴港上市:去年扭亏为盈净利59亿元,三年内实现百万销量目标
  • 马上评|演唱会云集,上海如何把“流量”变“留量”
  • 起底网红热敷贴“苗古金贴”:“传承人”系AI生成,“千年秘方”实为贴牌货
  • 特朗普承认“24小时结束俄乌冲突”是玩笑:大家都知道