git多账号配置

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

具体流程

  • ssh-keygen -t rsa -C [email protected], 生成秘钥, 注意不要覆盖原有的秘钥文件(生成时候重新命名该秘钥文件, 其它直接默认即可)
  • ssh-add -l 查看当前电脑已经添加了多少用户标识(也就是秘钥), .ssh下的id_rsa文件(首次新建的秘钥文件)不添加也可被git感知
  • ssh-add ~/.ssh/id_rsa_custom, 添加自定义的秘钥, 若报错, 请使用ssh-agent bash开启bash环境代理来执行相关的git命令
  • 编辑.ssh目录下的config文件, 不存在则新建即可. 该文件内容如下:
    Host [email protected]
    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 [email protected] 测试自定义的账号是否配置成功
  • 配置好以上后, 基本就可以进行多账号的环境开发了. 但是一般在提交或者推送时候, git是需要你提供你的emai, 此时可以将主要开发的邮件设置为全局的(git config --global user.email [email protected], 设置全局用户名git config --global user.name primary_name). 如果在你的开源工程或者学习工程不想使用该邮件, 则进去该工程根目录下, 执行git config user.email [email protected]以及git config user.name test. 此时改工程下的用户名和邮件会取代全局的用户名和邮件

bug记录

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

你可能感兴趣的:(git多账号配置)