Git 的 pre-commit hook(以及其他钩子脚本)默认不会被 git commit 追踪,也不会被 git push 推送到远程仓库

结论先行

Git 的 pre-commit hook(以及其他钩子脚本)默认不会被 git commit 追踪 ,也不会被 git push 推送到远程仓库------除非你主动将钩子文件加入版本控制并提交。

详细解释

1. 钩子文件的默认存储位置

Git 钩子脚本默认存放在仓库的 .git/hooks/ 目录下:

  • .git/ 目录本身是 Git 的「版本控制元数据目录」,默认被 .gitignore 排除 (Git 不会追踪 .git/ 内的文件);
  • 因此 .git/hooks/ 下的 pre-commit 等钩子文件,天然不会被 git add/git commit 捕获,更不会被 push 到远程。
2. 如何让钩子被版本控制(可选)

如果你希望团队共享钩子脚本,需要手动处理:

步骤 1:在仓库根目录创建钩子模板目录
bash 复制代码
# 比如创建 .githooks 目录(自定义名称,非默认)
mkdir .githooks
# 将 pre-commit 钩子复制到该目录
cp .git/hooks/pre-commit .githooks/
步骤 2:将 .githooks 加入版本控制
bash 复制代码
git add .githooks/pre-commit
git commit -m "添加pre-commit钩子模板"
git push  # 此时钩子会被推送到远程
步骤 3:让 Git 识别自定义钩子目录

其他开发者拉取代码后,需要执行以下命令让 Git 使用 .githooks 下的钩子:

bash 复制代码
# 局部生效(仅当前仓库)
git config core.hooksPath .githooks

# 或全局生效(所有仓库)
git config --global core.hooksPath ~/.githooks

注意:即使将钩子提交到远程,其他开发者也需要手动执行 core.hooksPath 配置,否则 Git 仍会使用默认的 .git/hooks/ 目录。

关键总结

场景 是否被 commit 是否被 push
默认 .git/hooks/pre-commit ❌ 否 ❌ 否
手动移到仓库根目录并 git add ✅ 是 ✅ 是

简单来说:默认不追踪、不推送;主动提交则会被追踪和推送

如果你的目标是「仅本地使用钩子,不希望推送到远程」,保持默认的 .git/hooks/ 目录即可,无需额外操作。

相关推荐
天若有情67320 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
果汁华1 天前
GitHub Trending 热门仓库整理 (2026年4月10日)
github
无限进步_1 天前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
粥里有勺糖1 天前
视野修炼-技术周刊第129期 | 上一次古法编程是什么时候
前端·javascript·github
无限进步_1 天前
【C++】验证回文字符串:高效算法详解与优化
java·开发语言·c++·git·算法·github·visual studio
Gavin_ZYX1 天前
Skill 管理过于繁琐,不如写个自动同步的工具
人工智能·架构·github
Hommy881 天前
【开源剪映小助手-客户端】桌面客户端
python·开源·node.js·github·剪映小助手
张二娃同学1 天前
Claude Code 使用教程:下载安装、CC Switch 配置、MiniMax API 获取与启动实操
人工智能·windows·深度学习·github·claude code
华仔啊1 天前
写简历太痛苦?这个开源项目用 AI 帮你一键搞定
github
70asunflower1 天前
个人主页从 0 到 1:Jekyll + GitHub Pages + AI Agent 完全指南
github·个人主页