如何在同一台电脑上使用两个github账户

本文介绍如何在同一台机器上使用不同的GitHub账号,通过生成特定的SSH Key,并配置.ssh/config文件来区分不同账户,实现灵活地在私人账号和工作账号间切换。

场景:

使用github的时候,大家都知道需要给该账号添加一个SSH key才能访问,参考: 具体设置 。当然如果你在多台机器使用一个账户,你可以为该账户添加多个SSH key。由于github是使用SSH key的fingerprint来判定你是哪个账户,而不是通过用户名,这样你就可以在设置完之后,在本地直接执行下面的语句,它就会自动使用你的.ssh/id_rsa.pub所对应的账户进行登陆,然后执行相关命令。

 #本地建库
 $ git init
 $ git commit -am "first commit' 
 #push到github上去
 $ git remote add origin git@github.com:xxxx/test.git
 $ git push origin master

但是如果你想在一台机器使用两个github账号(比如私人账号和工作用账号)。这个时候怎么指定push到哪个账号的test仓库上去呢?

解决方案(假设你已经拥有私有账号且已经OK,现在想使用另一个工作用账号):

  • 1:为工作账号生成SSH Key

    $ ssh-keygen -t rsa -C "your-email-address"
    • 存储key的时候,不要覆盖现有的id_rsa,使用一个新的名字,比如id_rsa_work
  • 2:把id_rsa_work.pub加到你的work账号上

  • 3:把该key加到ssh agent上。由于不是使用默认的.ssh/id_rsa,所以你需要显示告诉ssh agent你的新key的位置

    $ ssh-add ~/.ssh/id_rsa_work
    • 可以通过ssh-add -l来确认结果
  • 4:配置.ssh/config

$ vi .ssh/config

# 加上以下内容
#default github
Host github.com
  HostName github.com
  IdentityFile ~/.ssh/id_rsa

Host github_work
  HostName github.com
  IdentityFile ~/.ssh/id_rsa_work
  • 5:这样的话,你就可以通过使用github.com别名github_work来明确说你要是使用id_rsa_work的SSH key来连接github,即使用工作账号进行操作。
#本地建库
$ git init
$ git commit -am "first commit'

#push到github上去
$ git remote add origin git@github_work:xxxx/test.git
$ git push origin master
同一电脑上设置两个GitHub或GitLab账号并分别拉取远程代码库,你需要按照以下步骤操作: 1. **安装Git**:首先确保电脑已经安装了Git。如果没有,可以从官方网站下载并安装最新版本。 2. **配置SSH密钥对**:对于GitHub,你可以按照官方文档创建一个新的SSH密钥对,分别为两个账户生成,然后添加到各自的GitHub帐户设置中。这一步可以让你通过SSH协议无交互登录。 - 对于Windows用户,通常在`%USERPROFILE%\.ssh`目录下会有两个文件,分别为公钥(id_rsa.pub)和私钥(id_rsa),替换到相应的账户关联。 3. **克隆仓库**:打开终端(如果是Windows用户则需要Git Bash或其他Git客户端提供的命令行环境)并切换到你想存放代码的目录,例如: ```bash cd /path/to/repo_directory ``` 4. **初始化新仓库**(如果不存在): ```bash git init ``` 5. **添加远端仓库**,假设其中一个账户的仓库地址是`https://github.com/user1/repository.git`,另一个是`https://github.com/user2/repository.git`,你可以使用: ```bash git remote add origin1 https://github.com/user1/repository.git git remote add origin2 https://github.com/user2/repository.git ``` 6. **切换分支或克隆**:使用`git checkout`或`git clone`命令时,指定对应的origin,比如: ```bash git checkout -b branch_name origin1/branch_name ``` 7. **拉取代码**:当需要更新代码时,使用`git pull`命令,同样指定相应的origin: ```bash git pull origin1 master git pull origin2 feature_branch ``` 现在,你可以在这两个仓库之间自由切换,拉取各自项目的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值