定义:
钩子:由事件触发的函数
分类:
客户端钩子:由诸如提交和合并这样的操做触发
服务器端钩子:由诸如接收被推送的提交这样的联网操做触发git
安装:
a.钩子都被存储在 .git 目录下的 hooks 子目录中
b.当 git init 初始化一个新版本库时,默认会在这个目录中放置一些示例脚本
c.任何正确命名的可执行脚本均可以正常使用(Ruby、Python、shell或其它语言)
d.这些示例的名字都是以.sample 结尾,若是想启用它们,移除这个后缀就能够了shell
客户端钩子:
提交工做流钩子:
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 控制以外的文件是否存在,对这些文件进行处理。app
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.不过客户端在它结束运行以前将保持链接状态函数