git多账号配置

工作中往往我们会遇到这种情况, 公司给了邮箱, 采用类似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

转载于:https://juejin.im/post/59dda08751882578c5266046

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值