配置Git多目录下区分不同用户的提交

简介

作为一个开发者,通常会拥有公司与github/gitlab等多个账户,在不同项目下开发时,commit的用户名和邮箱是不同的,例如公司项目中,使用的是本名+公司邮箱,而github项目中使用的是个人邮箱和昵称。以往我会在全局的~/.gitconfig中配置为个人邮箱,当拉新项目时再根据项目的归属来设置项目内的信息,虽然可以使用alias一键完成设置操作,但拉仓库和新建仓库的频率较低,往往会忘记这个事情,导致commit时提交的用户信息不正确。

配置文件生效的优先级

首先,我们需要了解一下Git配置文件生效的优先级。对于一个Git仓库来说,配置优先级为 仓库 > 全局 > 系统。操作Git时,首先会查找/etc/gitconfig(系统),然后查找用户的全局配置~/.gitconfig,最后查找每个仓库的.git/config配置。所有的配置项,从低优先级开始加载,出现冲突时,较高优先级的配置项会覆盖前面的配置。

使用includeif 参数实现不同目录的配置

git (version >= 2.13.0)版本支持includeIf用于开启不同目录下匹配不同的配置文件,使用方式:

# 在~/.gitconfig 中配置
[includeIf "gitdir:~/work/"]
   path = ~/.gitconfig-work
[includeIf "gitdir:~/github/"]
  path = ~/.gitconfig-github

通过这个方式,我们可以为不同目录下的git仓库提供额外的配置文件,实现不同的仓库使用不同的用户名和邮箱。
该配置文件由全局配置加载,优先级低于仓库配置,设置好后,只需将使用相同用户名/邮箱的仓库放在同一路径下,即可使用相同的配置。

无法生效的问题

在尝试配置过程中,由于我在公司的开发环境使用的是win10+vscode+wsl-remote,一开始以为linux环境下配置好即可生效,发现配置项不起作用,后来搜索了一下vscode #40354,发现window下需要添加参数忽略路径大小写:[includeIf "gitdir/i:~/work/"] 才能生效。

参考

更多的细节可以参考官方指引:
https://git-scm.com/docs/git-config#_includes

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。