git多账号配置

2017-10-11 Shipinsr

工作中往往我们会遇到这种情况, 公司给了邮箱, 采用类似 gitlab 之类的 git 服务托管商, 而我们又拥有自己的 github 账户. 闲暇之余, 我们希望能将个人开源项目或者学习笔记之类的托管到 github 上, 这时就涉及到 git 的多账号配置了.

具体流程

  • ssh-keygen -t rsa -C test@test.com , 生成秘钥, 注意不要覆盖原有的秘钥文件(生成时候重新命名该秘钥文件, 其它直接默认即可)
  • ssh-add -l 查看当前电脑已经添加了多少用户标识(也就是秘钥), .ssh 下的 id_rsa 文件(首次新建的秘钥文件)不添加也可被 git 感知
  • ssh-add ~/.ssh/id_rsa_custom , 添加自定义的秘钥, 若报错, 请使用 ssh-agent bash 开启 bash 环境代理来执行相关的 git 命令
  • 编辑 .ssh 目录下的 config 文件, 不存在则新建即可. 该文件内容如下:
    Host git@github.com
    HostName https://github.com
    User git
    IdentityFile ~/.ssh/id_rsa_custom
    • Host 为你的 HostName 的别名, 可自定义使用(若自定义后则执行克隆时候, 使用 git clone custom_name:xxx/xxx.git , 其它操作类似)
    • HostName 为你的 git 服务托管商网址, 我这边直接选择的是 github
    • User 表示你采用的是那种代码托管服务, 这里采用 git
    • IdentityFile 为你的秘钥文件(带上路径)
  • ssh -T git@github.com 测试自定义的账号是否配置成功
  • 配置好以上后, 基本就可以进行多账号的环境开发了. 但是一般在提交或者推送时候, git 是需要你提供你的 emai , 此时可以将主要开发的邮件设置为全局的( git config --global user.email primary@primary.com , 设置全局用户名 git config --global user.name primary_name ). 如果在你的开源工程或者学习工程不想使用该邮件, 则进去该工程根目录下, 执行 git config user.email test@test.com 以及 git config user.name test . 此时改工程下的用户名和邮件会取代全局的用户名和邮件

bug记录

  • question : fatal: refusing to merge unrelated histories
  • method : git pull origin master --allow-unrelated-histories

用户评论
开源开发学习小组列表