0


gitlab服务器端hook最全详解

1.hook是什么?

GitLab hook 可用于拦截特定事件(如 push 代码),以便实现功能扩展。

主要有两类hook:

  • web hooks

  • customer hooks

其中customer hooks具有客户端和服务器端配置,现在主要讲一下服务器端hook配置

2.服务器端的hook怎么配置

往GitLab服务器push提交点,会按顺序先后执行服务器上的pre-receive、update和post-receive三种类型的钩子脚本。

2.1 单仓库钩子(两种方法)

方法一:

找到仓库所在目录。(14.0版本以后只能靠gitlab服务器管理员寻找hash存储路径)

在仓库 xxx.git 目录下创建 custom_hooks 子目录。

在 custom_hooks 目录中创建脚本文件(如pre-receive)。

确保脚本文件具有可执行权限,并且属主为Git用户。

编写脚本内容,脚本支持很多语言,包括但不限于shell、ruby等脚本。

方法二:(个人推荐这个,比较容易直观看出脚本简洁信息)

找到仓库所在目录。

在仓库 xxx.git 的custom_hooks 下建这三个目录pre-receive.d update.d post-receive.d

在pre-receive.d下创建脚本文件如:1_commit_message.sh

2.2 多仓库钩子(以pre-receive为例)

注意:对gitlab服务器上所有的项目起作用

第一步,找到要配置仓库在 gitlab 中存储的路径,但因 gitlab 的仓库自某个版本开始采用 hash 存储,我们想要知道仓库对应的物理路径,可以通过管理员账号拿到对应的物理路径

第二步,进入路径下新建目录 custom_hooks/pre-receive.d,进入目录后再创建脚本文件 (推送前),同时修改 脚本文件的权限。

chmod +777 xxxx.sh

第三步,在本地尝试推送,推送显示如下,如果不符合规范则无法提交成功。

PS:

对于全局的hook,配置脚本后gitlab系统上所有仓库都受影响,开关在配置文件gitlab.rb中(默认安装路径/etc/gitlab/gitlab.rb),找到下面这条

#gitaly['custom_hooks_dir'] = "/var/opt/gitlab/gitaly/custom_hooks"

去掉注释,配置自己的hook脚本存放路径。

标签: git 服务器 分布式

本文转载自: https://blog.csdn.net/qq_44945678/article/details/129030420
版权归原作者 小青蛙技术员 所有, 如有侵权,请联系我们删除。

“gitlab服务器端hook最全详解”的评论:

还没有评论