引言
git命令应该是工作中几乎天天都要接触到的,对于git一些常用命令大家也都能熟练操作。但git的配置却较少人关注。git config虽然用得少,但它很重要,使用它后会给我们带来极大的便利。下面就简单介绍下这个命令及其基本使用方法~
先谈谈字面意思,config译为配置,那git config就是获取和设置仓库的配置
要了解这个命令,我们可以在控制台中打出git config,就可以看到一些相关的用法,如下图:
图1 git config的使用方法(下面会多次提及)
config file location
据了解,git config命令就是对git进行一些配置。而配置一般都是写在配置文件里面,那么git的配置文件在哪里呢?
从上图我们可以看到相关的三个关键词,即local
、global
、system
,这就是git里的3个配置文件
- .git/config 文件,即「仓库级配置」文件:这个配置中的设置只对当前所在仓库有效。使用
.git/config --local
,此时读写的就是这个文件。这里的配置仅仅针对当前项目有效。 - ~/.gitconfig 文件,即「全局级配置」文件:用户目录下的配置文件只适用于该用户。可以使用
git config --global
选项去设置它。 - /etc/gitconfig 文件,即「系统级配置」文件:系统中对所有用户都普遍适用的配置。可以使用
git config --system
选项。
如何选择要操作的配置文件
上文提到了三种配置文件,及其适用的情况。那么我们应该操作哪个配置文件呢?答案当然是根据不同情况而定啦~
(1) git config [--local] 针对一个仓库
使用场景:只想在某个项目中生效,而不是在所有的git仓库中都生效
例如:
$ git config core.ignorecase false
(2) git config --global 针对一个用户
使用场景:想让当前用户操作的所有仓库都生效,例如下面要说的配置快捷键
(3) git config --system 针对一个系统,必须要管理员权限,即使用sudo
使用场景:让这个系统下的所有用户操作的仓库都生效,例如配置文本编辑器的,就可以针对系统去设置
查看配置项及其优先级
了解了以上三种配置类型后,那么,怎么查看具体的配置呢?我们可以用以下的命令来查看
$ git config [--local|--global|--system] --list
// 或者
$ git config [--local|--global|–system] -l
// 注意:使用list时有两个横线“--” ,使用简写的 l 时仅有一个“-”
$ git config -l
为查看当前生效的配置,即三个配置文件的集合
我们可以来尝试一下
上图是 local级 的配置。我们还可以用 cat命令 来查看该config文件
从这个图我们可以清楚的看到,在git中,每一项的配置名称又叫做“section”,“section”下面的每一行对应着一个key和一个value。
比如上图中的 core 即为一个 section,名为 repositoryformatversion 的 key 对应的 value 为0。每个 section 可以对应很多对key、value,而key、value必定成对
出现,但并不是一对一,也就是说一个key可以设置多个value(git默认采用最后一个)。
这是 global级 的配置。与 local级 的比较下,我们很快便意识到,cat.name 在 local级 值为duanwu,而在 global级 的值却为miao。
那么,问题来了,一个git项目中的配置到底是由什么决定的呢?这就涉及到配置项的优先级问题了。
对于git来说,配置文件的权重是「仓库 > 全局 > 系统」,即 「local > global > system」。git 会使用这一系列的配置文件来存储你定义的偏好,它首先会查找 /etc/gitconfig
文件(系统级),然后查找每个用户的 ~/.gitconfig文件
(全局级)。最后查找由用户定义的各个库中Git目录下的配置文件 .git/config
(仓库级)。每一个级别的配置都会覆盖上层的相同配置,所以 .git/config 里的配置会覆盖 /etc/gitconfig 中的同名变量。
其实很好理解,因为它是按 system、global、local 的顺序查找的,后面的同名配置会覆盖上一级的配置。
增删改查
了解完配置文件的基本情况,下面就该谈谈怎么用了。PS:以下详细介绍了各常用命令并配图,有兴趣的可以自己也操作一遍~
回到图1,其中的Action,涉及到的都是git config的用法。
首先要知道的是,①增、删、改,若不显式说明是哪个配置,则默认操作的是 local 配置。②对 system 进行增删改操作时,需要管理员权限
1. 增:--add
$ git config [–-local | global | system] --add section.name value
例:git config --add cat.name niuniu (默认情况,即添加到local配置中,如下图)
正如上面说的,key和value必须成对出现,缺一不可,缺项则报错,如下。
2. 删:--unset | --unset-all | --remove-section
$ git config [–-local | global | system] --unset section.name
例,git config --unset cat.age
若是一个key对应多个value,那么应该把要删除的value带上,否则会报错(如下)
倘若想一次性把某个属性的所有值都删掉,则用--unset-all命令
$ git config [–-local | global | system] --unset-all section.name
例,git config --unset -all cat.name
以上两个命令就是与add相对,删除配置项的某个属性值(或所有属性值)。虽然属性值删除了,但该配置项还存在,若想将配置项删除,则使用remove-section命令
$ git config [–-local | global | system] --remove-section section
3. 改:--rename-section | --replace-all
// 重新设值(前提:此key只对应一个value,否则报错)
$ git config [–-local | global | system] section.key newValue
// 重命名
$ git config [–-local | global | system] --rename-section oldName newName
// 替换所有的值
$ git config [–-local | global | system] --replace-all section.key newValue
此时,将会把key对应的所有value值都替换成新的。需要注意的是,此时最终只保留一个value(如下例)
我们也可以直接编辑配置文件,用以下命令:
$ git config --local -e | git config --local --edit
缺local项时默认编辑local文件
4. 查:get | get-all | get-regexp
获取某个属性值
$ git config [--local | global | system] --get section.key [value]
如果此key对应多个value,且获取时不带具体的value,那么获取的是最后的value(如下例)
当然了,如果 global, system 下也有对应的cat.name,那该项是会被local下覆盖的,也就是获取不到的(记住查找的顺序,永远是先system 再 global 再 local, git默认采用最后一项)
获取所有属性值
没有注明哪个配置的话,则是获取所有配置下的属性值,包括global,system
$ git config [--local | global | system] --get-all section.key
获取某个section下的所有key和value(包括global和system)
$ git config [--local | global | system] --get-regexp section
5. 查 Type:--bool | --int | --bool-or-int | --path
正如“引言”的图中Type模块下的命令,这些是用来判断value值的类型的。
$ git config [--local | global | system] [--bool|--int|--bool-or-int|--path] section.key
例 git config --local --bool cat.name
如果cat.name的值既不是布尔值,也不能被转换为布尔值,那就会报错
常用的配置
1.配置用户信息
当我们安装好git时,第一个要配置的就是你的个人信息——用户名和电子邮件地址,这两项配置很重要,每次commit时都会引用这两条信息,以说明是谁提交了代码。
如上图的Author,如果你没配置个人信息,就会采用默认的情况。
2.取别名 配置快捷键
配置快捷键虽然不是必须的,但当学会偷懒后,会给工作带来极大的便利~
平时操作git仓库时,有个常用的命令git status,status这个单词虽然短但实在容易打错。我们就可以给它取个别名 (alias意为别名):
$ git config --global alias.st status
这条命令表示 alias.st = status
,以后就可以使用 git st
代替烦人的 git status
啦~
同时,用这种方法也能创建新的命令,例如用 last 表示查看最后一次提交
$ git config --global alias.last 'log -1 HEAD'
常用的命令还有很多,都可以简写。很多人都用 co 表示checkout,ci 表示commit,br 表示 branch,当然你也可以自己命名,用的顺手就可以啦~
3.文本编辑器
git也可以设置默认使用的文本编辑器。当需要你输入一些额外消息的时候,会自动调用一个外部文本编辑器给你用。默认会使用操作系统指定的默认编辑器,一般可能会是 Vi 或者 Vim。如果你有其他偏好,比如 Emacs 的话,可以重新设置:
$ git config --global core.editor emacs
4.差异分析工具
还有一个比较常用的是,在解决合并冲突时使用哪种差异分析工具。比如要改用 vimdiff 的话:
$ git config --global merge.tool vimdiff
结语
git config 还有很多其他的功能,以上只是介绍了一些常用的。有兴趣的可以自己了解噢~
有需要帮助的地方,可以使用 git help config
命令查看帮助文档。或者戳 https://git-scm.com/docs/git-config
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。