git-config配置多用户场景实践

38次阅读

共计 2032 个字符,预计需要花费 6 分钟才能阅读完成。

git

git 是一个分布式版本控制软件,最初由林纳斯·托瓦兹创作,于 2005 年以 GPL 发布。最初目的是为更好地管理 Linux 内核开发而设计。应注意的是,这与 GNU Interactive Tools(一个类似 Norton Commander 界面的文件管理器)有所不同。git 最初的开发动力来自于 BitKeeper 和 Monotone。git 最初只是作为一个可以被其他前端(比如 Cogito 或 Stgit)包装的后端而开发的,但后来 git 内核已经成熟到可以独立地用作版本控制。很多著名的软件都使用 git 进行版本控制,其中包括 Linux 内核、X.Org 服务器和 OLPC 内核等项目的开发流程。

更多相关介绍可以查看百科

git 的基本使用

主要是指一下基本操作:

  1. 安装
  2. ssh 登入配置
  3. 命令使用

安装

根据自己的系统进行选择安装方式,可以使用命令行安装,也可以使用安装包安装,git 官方安装包地址

ssh 登入配置

安装完成之后,需要考虑和远程的仓库建立连接,就需要账号和密码,无论是 githubgitlab 等,都需要一个账户名,可以注册完成,然后设置:

git config --global user.name "yourName"
git config --global user.email "yourEmail"

为了避免每次 push 代码都需要密码之类的,我们通过 ssh 来配置;执行:

ssh-keygen

一路 enter 即可,在 ~/.ssh/ 下会生成两个文件,复制其中的公钥:

pbcopy < ~/.ssh/id_rsa.pub

进入远程仓库的个人中心,https://github.com/settings/profile;会找到关于 SSH and GPG keys,有一个New SSH key 的按钮,点击后,可以黏贴上刚复制的公钥,然后 Add SSH key 即可;

可以 pull 和 push 代码测试是否成功。

git 命令使用

  1. 对于 win10 系统,推荐升级后使用好的官方新出的终端,Windows Terminal,需要当前最新的 win10 版本,用起来挺好的,可以再 Microsoft 的官方商城下载体验。
  2. 对于 mac 或者 linux 用户,推荐配置 oh-my-zsh, 这个 oh-my-zsh 默认安装上了 git plugin~/.zshrc配置文件中,可以使用很多的简洁命令,git 简写命令集合

多用户配置

git-config 的官网巨长文档,开发人员经常遇到这样的问题,我们的公司仓库和个人仓库的用户名和邮箱配置是有区别的,为了能够很好地区分工程上传到不同的远程仓库,我们需要分别处理,保证在不同的工程使用不同的账户

  1. 按工程配置多用户
  2. 按目录配置多用户

按工程配置多用户

目前 git 的配置变量可以放在三个地方:

  1. /etc/gitconfig 系统配置, 对所有用户都生效。
  2. ~/.gitconfig 用户配置,仅对当前用户生效。

    git config --global user.name "yourName"
    git config --global user.email "yourEmail"
  3. projectRootPath/.git/config 项目根目录配置,仅对当前项目生效。对应:进入工程根目录执行

    git config user.name "yourName"
    git config user.email "yourEmail"

三层是从 3 -2- 1 的优先级处理的,这样我们可以对不同工程完成不同的配置,这个在工程数量多的时候简直不忍直视,所以需要寻找更好的方法。

按目录配置多用户

在 2017 年,git 新发布的版本 2.13.0 包含了一个新的功能 includeIf 配置,可以把匹配的路径使用对应的配置用户名和邮箱;

~/ 目录下面存在三个配置文件,

  • .gitconfig // 全局通用配置文件
  • .gitconfig-self // 个人工程配置文件
  • .gitconfig-work // 公司工程配置文件

全局通用配置文件 ~/.gitconfig 里面的内容是:主要是通过 includeIf 配置匹配不用的目录映射到不同配置文件上,

[includeIf "gitdir:~/self-workspace/"]
    path = .gitconfig-self
[includeIf "gitdir:~/workspace/"]
    path = .gitconfig-work

个人工程配置文件~/.gitconfig-self

[user]
    name = yourname-self
    email = yourname-self@gmail.com

公司工程配置文件~/.gitconfig-work

[user]
    name = yourname-work
    email = yourname-work@yourCompanyName.com

遇到的问题:

  1. 文件 ~/.gitconfig 里面的 includeIf 后面的 path 最后需要 / 结尾
  2. 文件 ~/.gitconfig 里面原有的 user 部分需要删除
  3. 个人工程目录和公司工程目录需要要求是非包含关系,就是这两个工程目录配置路径不可以是父子关系。

正文完
 0