定义:
钩子:由事件触发的函数
分类:
客户端钩子:由诸如提交和合并这样的操作触发
服务器端钩子:由诸如接收被推送的提交这样的联网操作触发
安装:
a.钩子都被存储在 .git 目录下的 hooks 子目录中
b.当 git init 初始化一个新版本库时,默认会在这个目录中放置一些示例脚本
c.任何正确命名的可执行脚本都可以正常使用(Ruby、Python、shell或其它语言)
d.这些示例的名字都是以.sample 结尾,如果想启用它们,移除这个后缀就可以了
客户端钩子:
提交工作流钩子:
pre-commit 钩子在键入提交信息前运行
a.用于检查即将提交的快照,例如,检查是否有所遗漏,确保测试运行,以及核查代码
b.如果该钩子以非零值退出,Git 将放弃此次提交
c.可以用 git commit --no-verify 来绕过这个环节
prepare-commit-msg 钩子在启动提交信息编辑器之前,默认信息被创建之后运行
a.入参:存有当前提交信息的文件的路径、提交类型和修补提交的提交的SHA-1校验
b.它允许你编辑提交者所看到的默认信息
c.对那些会自动产生默认信息的提交可以结合提交模板来使用它,动态地插入信息
commit-msg 钩子在提交之后运行
a.入参:存有当前提交信息的文件的路径
b.如果该钩子以非零值退出,Git 将放弃此次提交
c.可以用来在提交通过前验证项目状态或提交信息
post-commit 钩子在整个提交过程完成后运行
a.不接收任何参数
b.通过 git log -1 HEAD 来获得最后一次的提交信息
c.一般用于通知之类的事情
电子邮件工作流钩子:
a.电子邮件工作流钩子都是由 git am 命令调用
b.如果需要通过电子邮件接收由 git format-patch 产生的补丁,这些钩子也许用得上
applypatch-msg 钩子 在git am 运行前被调用
a.接收单个参数:包含请求合并信息的临时文件的名字
b.如果脚本返回非零值,Git 将放弃该补丁
c.可以用该脚本来确保提交信息符合格式,或直接用脚本修正格式错误
pre-applypatch 钩子 在git am 运行期间被调用
a.他正好运行于应用补丁之后,产生提交之前,所以可以用它在提交前检查快照
b.可以用这个脚本运行测试或检查工作区。
c.如果有什么遗漏,或测试未能通过,脚本以非零值退出,中断 git am 的运行,补丁就不会被提交
post-applypatch 钩子 运行于提交产生之后
a.可以用它把结果通知给一个小组或所拉取的补丁的作者
b.但无法用它停止打补丁的过程
其他钩子:
pre-rebase 钩子 变基之前被调用
a.以非零值退出可以中止变基的过程
b.可以使用这个钩子来禁止对已经推送的提交变基
post-rewrite 钩子被那些会替换提交记录的命令调用,
a.例如git commit --amend 和 git rebase(不包括 git filter-branch)
b.它唯一的参数是触发重写的命令名,同时从标准输入中接受一系列重写的提交记录
c.用途很大程度上跟 post-checkout 和 post-merge 差不多。
post-checkout 钩子在 git checkout 成功运行后会被调用
a.可以根据你的项目环境用它调整你的工作目录
b.例如:放入大的二进制文件、自动生成文档或进行其他类似这样的操作。
post-merge 钩子在 git merge 成功运行后会被调用
a.可以用它恢复 Git 无法跟踪的工作区数据,例如:权限数据。
b.可以用来验证某些在 Git 控制之外的文件是否存在,对这些文件进行处理。
pre-push 钩子在 git push 之前调用。
a.它接受远程分支的名字和位置作为参数,同时从标准输入中读取一系列待更新的引用
b.可以在推送开始之前,用它验证对引用的更新操作
c.一个非零的退出码将终止推送过程
pre-auto-gc 钩子会在垃圾回收开始之前被调用
a.git的一些日常操作在运行时,偶尔会调用 git gc --auto 进行垃圾回收。
b.可以用它来提醒你现在要回收垃圾了,或者依情形判断是否要中断回收。
说明:克隆某个版本库时,它的客户端钩子 并不 随同复制。 如果需要靠这些脚本来强制维持某种策略,可以在服务器端实现这一功能
服务器端钩子:
pre-receive 处理来自客户端的推送操作时,最先被调用的脚本是 pre-receive
a.它从标准输入获取一系列被推送的引用。
b.如果它以非零值退出,所有的推送内容都不会被接受
c.可以用这个钩子阻止对引用进行非快进(non-fast-forward)的更新
d.可以对该推送所修改的所有引用和文件进行访问控制。
update
a.update 脚本和 pre-receive 脚本十分类似,不同之处在于它会为每一个准备更新的分支各运行一次
b.假如同时向多个分支推送内容,pre-receive 只运行一次,update 会每一个被推送的分支运行一次
c.接受三个参数:引用的名字(分支),推送前引用指向的SHA-1值,推送内容的SHA-1值
d.如果 update 脚本以非零值退出,只有相应的那一个引用会被拒绝;其余的依然会被更新。
post-receive 在整个过程完结以后运行
a.可以用来更新其他系统服务或者通知用户,例如:给某个邮件列表发信,通知持续集成的服务器
b.该脚本无法终止推送进程
c.不过客户端在它结束运行之前将保持连接状态