How To Work With Multiple Github Accounts on a single Machine

·

4 min read

How To Work With Multiple Github Accounts on a single Machine

Let suppose I have two github accounts, https://github.com/tarun-office and https://github.com/tarun-personal. Now i want to setup my mac to easily talk to both the github accounts.

NOTE: This logic can be extended to more than two accounts also. :)

The setup can be done in 5 easy steps:

Steps:

  • Step 1 : Create SSH keys for all accounts
  • Step 2 : Add SSH keys to SSH Agent
  • Step 3 : Add SSH public key to the Github
  • Step 4 : Create a Config File and Make Host Entries
  • Step 5 : Cloning GitHub repositories using different accounts


Step 1

Create SSH keys for all accounts

First make sure your current directory is your .ssh folder.

     $ cd ~/.ssh

Syntax for generating unique ssh key for ann account is:

     ssh-keygen -t rsa -C "your-email-address" -f "github-username"

here,

-C stands for comment to help identify your ssh key

-f stands for the file name where your ssh key get saved

Now generating SSH keys for my two accounts

     ssh-keygen -t rsa -C "my_office_email@gmail.com" -f "github-tarun-office"
     ssh-keygen -t rsa -C "my_personal_email@gmail.com" -f "github-tarun-personal"

Notice here tarun-office and tarun-work are the username of my github accounts corresponding to my_office_email@gmail.com and my_personal_email@gmail.com email ids respectively.

After entering the command the terminal will ask for passphrase, leave it empty and proceed.

Passphrase Image

Now after adding keys , in your .ssh folder, a public key and a private will get generated.

The public key will have an extention .pub and private key will be there without any extention both having same name which you have passed after -f option in the above command. (in my case github-tarun-office and github-rahu-personal)

Added Key Image


Step 2

Add SSH keys to SSH Agent

Now we have the keys but it cannot be used until we add them to the SSH Agent.

     ssh-add -K ~/.ssh/github-tarun-office
     ssh-add -K ~/.ssh/github-tarun-personal

You can read more about adding keys to SSH Agent here.


Step 3

Add SSH public key to the Github

For the next step we need to add our public key (that we have generated in our previous step) and add it to corresponding github accounts.

For doing this we need to:

1. Copy the public key

We can copy the public key either by opening the github-tarun-office.pub file in vim and then copying the content of it.

     vim ~/.ssh/github-tarun-office.pub
     vim ~/.ssh/github-tarun-personal.pub

OR

We can directly copy the content of the public key file in the clipboard.

     pbcopy < ~/.ssh/github-tarun-office.pub
     pbcopy < ~/.ssh/github-tarun-personal.pub

2. Paste the public key on Github

  • Sign in to Github Account
  • Goto Settings > SSH and GPG keys > New SSH Key
  • Paste your copied public key and give it a Title of your choice.

OR

  • Sign in to Github
  • Paste this link in your browser (github.com/settings/keys) or click here
  • Click on New SSH Key and paste your copied key.


Step 4

Create a Config File and Make Host Entries

The ~/.ssh/config file allows us specify many config options for SSH.

If config file not already exists then create one (make sure you are in ~/.ssh directory)

     touch config

The commands below opens config in your default editor....Likely TextEdit, VS Code.

     open config

Now we need to add these lines to the file, each block corresponding to each account we created earlier.

     #tarun-office account
     Host github.com-tarun-office
          HostName github.com
          User git
          IdentityFile ~/.ssh/github-tarun-office

     #tarun-personal account
     Host github.com-tarun-personal
          HostName github.com
          User git
          IdentityFile ~/.ssh/github-tarun-personal


Step 5

Cloning GitHub repositories using different accounts

So we are done with our setups and now its time to see it in action. We will clone a repository using one of the account we have added.

Make a new project folder where you want to clone your repository and go to that directory from your terminal.

For Example: I am making a repository on my personal github account and naming it TestRepo Now for cloning the repo use the below command:

     git clone git@github.com-{your-username}:{owner-user-name}/{the-repo-name}.git

     [e.g.] git clone git@github.com-tarun-personal:tarun-personal/TestRepo.git


Finally

From now on, to ensure that our commits and pushes from each repository on the system uses the correct GitHub user — we will have to configure user.email and user.name in every repository freshly cloned or existing before.

To do this use the following commands.

     git config user.email "my_office_email@gmail.com"
     git config user.name "tarun Pandey"

     git config user.email "my-personal-email@gmail.com"
     git config user.name "tarun Pandey"

Pick the correct pair for your repository accordingly.

To push or pull to the correct account we need to add the remote origin to the project

     git remote add origin git@github.com-tarun-personal:tarun-personal

     git remote add origin git@github.com-tarun-office:tarun-office

Now you can use:

     git push

     git pull

P.S:
If this gist has been helpful to you, kindly consider leaving a star.
If you'd like, let's connect on LinkedIn and build a supportive community together.