简介
作为一个开发者,通常会拥有公司与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