git提交限制规范

创建全局 Git Hook 配置文件

1. 创建安装脚本

创建一个文件 setup-global-git-hook.sh

bash 复制代码
#!/bin/bash

# 创建全局 hooks 目录
GLOBAL_HOOKS_DIR="$HOME/.git-hooks"
mkdir -p "$GLOBAL_HOOKS_DIR"

# 创建 commit-msg hook 文件
cat > "$GLOBAL_HOOKS_DIR/commit-msg" << 'EOF'
#!/bin/bash

# 提交信息文件路径
commit_msg_file="$1"

# 读取提交信息
commit_msg=$(cat "$commit_msg_file")

# 定义允许的关键字
allowed_types="add|mod|fix|del|doc"

# 正则表达式:必须以 [关键字] 开头,后面至少跟一个空格和内容
pattern="^\[($allowed_types)\]\s+.+$"

# 检查提交信息是否符合规范
if ! echo "$commit_msg" | grep -qE "$pattern"; then
    echo ""
    echo "❌ 提交信息格式不符合规范!"
    echo ""
    echo "📝 格式要求:必须以以下关键字开头:"
    echo "  [add] 新增功能"
    echo "  [mod] 修改功能"
    echo "  [fix] 修复问题"
    echo "  [del] 删除功能"
    echo "  [doc] 文档(sql、接口文档、readme等)"
    echo ""
    echo "✅ 正确示例:"
    echo "  [add] 新增用户登录功能"
    echo "  [mod] 优化订单查询性能"
    echo "  [fix] 修复登录超时问题"
    echo "  [del] 移除过时的API接口"
    echo "  [doc] 更新接口文档"
    echo "  [doc] 添加数据库初始化sql"
    echo ""
    echo "❌ 错误示例:"
    echo "  add 新增功能          (缺少方括号)"
    echo "  [add]新增功能         (缺少空格)"
    echo "  [update] 更新代码     (不允许的关键字)"
    echo ""
    exit 1
fi

exit 0
EOF

# 添加执行权限
chmod +x "$GLOBAL_HOOKS_DIR/commit-msg"

# 配置 Git 使用全局 hooks 目录
git config --global core.hooksPath "$GLOBAL_HOOKS_DIR"

echo ""
echo "✅ 全局 Git Hook 配置完成!"
echo "📁 Hook 目录:$GLOBAL_HOOKS_DIR"
echo ""
echo "现在所有 Git 仓库的提交信息都必须符合规范:"
echo "  [add] 新增功能"
echo "  [mod] 修改功能"
echo "  [fix] 修复问题"
echo "  [del] 删除功能"
echo "  [doc] 文档(sql、接口文档、readme等)"
echo ""

2. 运行脚本

bash 复制代码
# 给脚本添加执行权限
chmod +x setup-global-git-hook.sh

# 运行脚本
./setup-global-git-hook.sh

或者直接手动配置

如果你想手动配置,执行以下命令:

bash 复制代码
# 1. 创建全局 hooks 目录
mkdir -p ~/.git-hooks

# 2. 创建 commit-msg 文件
cat > ~/.git-hooks/commit-msg << 'EOF'
#!/bin/bash

commit_msg_file="$1"
commit_msg=$(cat "$commit_msg_file")

pattern="^\[(add|mod|fix|del|doc)\]\s+.+$"

if ! echo "$commit_msg" | grep -qE "$pattern"; then
    echo ""
    echo "❌ 提交信息格式不符合规范!"
    echo ""
    echo "格式要求:必须以 [add]、[mod]、[fix]、[del]、[doc] 开头"
    echo "示例:"
    echo "  [add] 新增用户登录功能"
    echo "  [mod] 优化订单查询性能"
    echo "  [fix] 修复登录超时问题"
    echo "  [del] 移除过时的API接口"
    echo "  [doc] 更新接口文档"
    echo ""
    exit 1
fi

exit 0
EOF

# 3. 添加执行权限
chmod +x ~/.git-hooks/commit-msg

# 4. 配置 Git 使用全局 hooks
git config --global core.hooksPath ~/.git-hooks

echo "✅ 全局配置完成!"

验证配置

配置完成后,可以测试一下:

bash 复制代码
# ✅ 正确的提交(会成功)
git commit -m "[add] 新增用户登录功能"

# ✅ 正确的提交
git commit -m "[doc] 更新README文档"

# ✅ 正确的提交
git commit -m "[fix] 修复登录bug"

# ❌ 错误的提交(会被拒绝)
git commit -m "add 新增功能"           # 缺少方括号
git commit -m "[add]新增功能"          # 缺少空格
git commit -m "[update] 更新代码"      # 不允许的关键字

注意事项

  1. 全局配置生效范围:这个配置会对你电脑上所有 Git 仓库生效
  2. 绕过检查 :如果需要紧急跳过检查,可以使用 git commit --no-verify -m "message",但建议只在特殊情况下使用
  3. 团队协作:如果团队成员也需要此规范,可以把这个脚本分享给他们执行

这样配置后,任何不符合 [add][mod][fix][del][doc] 开头的提交都会被拒绝。

相关推荐
marteker5 小时前
哈雷戴维森在推出增长战略前重塑品牌形象
大数据·人工智能
歪歪歪比巴卜5 小时前
2026年AI新媒体运营工具怎么选?核心功能与适用场景解析
大数据·矩阵·新媒体运营
KKKlucifer5 小时前
三权分立 + AI 审计:解析国内堡垒机的合规与智能双引擎
大数据·数据库·人工智能
面向Google编程5 小时前
从零学习Kafka:认证机制
大数据·kafka
大大大大晴天️5 小时前
Flink技术实践-FlinkSQL Join技术全解
大数据·flink
蓝天守卫者联盟15 小时前
烧结机一氧化碳治理厂家技术路线与市场格局分析
大数据·人工智能·python
csgo打的菜又爱玩5 小时前
4.BlobServer 源码解析
大数据·架构·flink
Legend NO245 小时前
从“看报表”到“对话决策”:AI正在重构数据分析体系
大数据·人工智能
虞十三5 小时前
AtomGit 开源入门全攻略:环境搭建 + Git/Docker 实操 + 新手避坑(全平台版)
git·docker·容器
Elasticsearch6 小时前
多大才算太大?Elasticsearch 容量规划最佳实践
elasticsearch