Git 常用配置
Posted 有且仅有
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Git 常用配置相关的知识,希望对你有一定的参考价值。
一、SSH
首先要明白,Git 和SSH 的关系是:Git 使用了SSH 协议构建一个安全传输通道。SSH 协议大体是这样运作的:
- SSH 下的Client 发起对Server 的TCP 连接成功后,Server 会首先向Client 出示自己的身份信息,在Client 操作信任后进入下一步。
- 接着双方会协商生成一个对称密钥,用于加密本次会话其后所有传输的数据。
- 最后Server 需要对Client 进行身份认证,这依赖两种方式,即账户密码或SSH 密钥(非对称)。
知道了Git 和SSH 的关系接下来让我们看下一些Git 使用中需要的SSH 配置怎么做。
1. 多个SSH KEY
Git 使用SSH 时默认会在~/.ssh
目录中找id_rsa
和id_rsa.pub
这个密钥对。不过有些时候,我们希望使用多对密钥来应对不同情况。例如:在个人电脑中,一个用于公司的Git 库,另一个用于GitHub,此时我们就需要知道怎么设置多对Key。
首先,生成两对不同的密钥对
ssh-keygen -t rsa -C "邮箱@公司.com" -f ~/.ssh/<公司名>-id-rsa ssh-keygen -t rsa -C "邮箱@个人.com" -f ~/.ssh/<个人标识>-id-rsa
接着,添加配置文件
~/.ssh/config
区分不同Git 库(主机)# 公司 Host gitlab.公司.com PreferredAuthentications publickey IdentityFile ~/.ssh/<公司名>-id-rsa # 个人 Host github.com PreferredAuthentications publickey IdentityFile ~/.ssh/<个人标识>-id-rsa
Host : 指定匹配的host,全部使用
*
,多个中间用空格
隔开
PreferredAuthentications:指定使用什么验证方式
RSAAuthentication:是否使用RSA验证,其实不配也行,默认就是yes
IdentityFile:验证文件在哪,写上私钥的地址最后,将两个公钥分别在公司、GitHub 相关Web 功能中配置上。这样就完成了我们的目标。
二、Git 配置文件
关于配置文件的说明:Git-config-files-order官网说明,摘取一部分如下:
$(prefix)/etc/gitconfig
System-wide configuration file.
$XDG_CONFIG_HOME/git/config
Second user-specific configuration file. If$XDG_CONFIG_HOME
is not set or empty,$HOME/.config/git/config
will be used. Any single-valued variable set in this file will be overwritten by whatever is in~/.gitconfig
. It is a good idea not to create this file if you sometimes use older versions of Git, as support for this file was added fairly recently.
~/.gitconfig
User-specific configuration file. Also called “global” configuration file.
$GIT_DIR/config
Repository specific configuration file.The files are read in the order given above, with last value found taking precedence over values read earlier.
上面4个地方的文件会被按顺序读取,越往下优先级越高;
1. 全局ignore
有时候你需要对某类文件进行全局的忽略而不希望一个个repository
的设置。显然这样的需求在配置文件中是被支持的,那么选择什么样的“全局”呢?
个人认为“操作系统用户级别”作为全局是最合适的,毕竟我就是希望“我”这个用户有一个自己的全局配置,事实上Git的global
也是这个意思。
所以根据如上配置文件顺序,我们选择
~/.gitconfig
文件进行修改:[user] name = xxx email = xxx@xxx.xxx [core] excludesFile = ~/.gitignore_global [i18n] logOutputEncoding = UTF-8
在这个文件中我希望全局设置
name
和email
,当然最重要的还是core.excludesFile
(官网配置说明,搜core.excludesFile);这句配置我指定了“配置排除什么文件的”配置文件的位置,即用户目录下的.gitignore_global
(名字任意,~
代表用户目录):**/*.iml # 任意目录下-后缀为.iml的文件被排除 **/target # 任意目录下-target目录(及其下所有文件)被排除 **/classes # 任意目录下-classes目录(及其下所有文件)被排除 **/.idea # 任意目录下的.idea目录被排除
这里面具体能怎么配置呢?其实就是一个简单的模式匹配,有官网文档说明,往下翻翻就能看到。
这样,我们就做好了全局
ignore
,IDE 们也都会认识的。Eclipse
中
2和3我准备说一下Eclipse和IDEA中怎么配置,一般来说无需配置所以我加了删除线,为什么讲呢,就是防止IDE中原先你做了不同的设置导致1的设置没生效;打开
Preferences
->Team
->Git
->Configuration
这里能改变Git的配置文件位置,可以自行看看设置的时候正确。
IDEA中
IDEA其实没啥讲,因为不能在Settings中设置Git配置文件地址,它使用的就是Git约定的位置。
不过IDEA有另一个可以配置忽略文件的设置,在Settings
->Version Control
->Ignored Files
:这里是IDEA自己的配置和规则和Git无关,不过如果用IDEA开发,这样配置当然也有用。
2. 不同repository
不同配置
不同repository不同配置,其实就是修改不同下的repository_dir/.git/config
文件:
[user]
name = xxx
email = xxx@xxx.xxx
[core]
repositoryformatversion = 0
filemode = false
bare = false
logallrefupdates = true
symlinks = false
ignorecase = true
[remote "origin"]
url = git@xxx.xxx.xxx:xxx.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
这有什么用呢?其实目前我用到的最大用处就是公司Git库和个人Git库使用的[user]
配置不一样,这样的情况就可以通过配置不同的[user.name][user.email]
来解决
……待遇见情况后补充
以上是关于Git 常用配置的主要内容,如果未能解决你的问题,请参考以下文章