2

引言

git命令应该是工作中几乎天天都要接触到的,对于git一些常用命令大家也都能熟练操作。但git的配置却较少人关注。git config虽然用得少,但它很重要,使用它后会给我们带来极大的便利。下面就简单介绍下这个命令及其基本使用方法~    

先谈谈字面意思,config译为配置,那git config就是获取和设置仓库的配置

要了解这个命令,我们可以在控制台中打出git config,就可以看到一些相关的用法,如下图:
图1 git config的使用方法(下面会多次提及)
untitled.png

config file location

据了解,git config命令就是对git进行一些配置。而配置一般都是写在配置文件里面,那么git的配置文件在哪里呢?

从上图我们可以看到相关的三个关键词,即localglobalsystem,这就是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


ripple07
838 声望77 粉丝

爱前端,爱喵星人( =•ω•= )