Mastering Multiple GitHub Accounts

Sushant Mimani
Nerd For Tech
Published in
2 min readJul 26, 2023
Photo by Roman Synkevych on Unsplash

Introduction:

Managing multiple GitHub accounts can be a daunting task, especially for developers who work on personal and professional projects across different organizations. Manually switching between accounts every time you want to push code can lead to confusion and potential errors. Thankfully, there’s a powerful solution — the ~/.ssh/config file. In this blog post, we'll explore how to leverage this configuration file to set up seamless access to multiple GitHub accounts simultaneously. By the end, you'll be empowered to effortlessly navigate between your various accounts, streamlining your development workflow.

Understanding ~/.ssh/config:

The ~/.ssh/config file is a hidden configuration file located in the user's home directory. It allows you to define custom configurations for SSH connections, including those to GitHub repositories. By setting up specific rules for each GitHub account, you can automatically switch between accounts without the need for manual configurations.

Configuring Multiple GitHub Accounts:

Step 1: Backup Existing SSH Configurations

Before making any changes, it’s essential to back up your existing ~/.ssh/config file. This ensures that you can easily revert to your original settings if needed.

Step 2: Generate SSH Key Pairs for Each Account

For each GitHub account you want to access, you’ll need to generate a separate SSH key pair. This can be done using the ssh-keygen command. Be sure to name each key pair uniquely, corresponding to the associated GitHub account.

Step 3: Edit ~/.ssh/config

# Personal GitHub account
Host github.com-personal
HostName github.com
User git
IdentityFile ~/.ssh/id_rsa_personal

# Work GitHub account
Host github.com-work
HostName github.com
User git
IdentityFile ~/.ssh/id_rsa_work

Replace id_rsa_personal and id_rsa_work with the file paths of the SSH private keys you generated for your personal and work GitHub accounts, respectively.

Step 4: Configure/Clone Your Repositories

For any cloned repository you want to access, update the remote URL in the repository’s .git/config file. For example:

[remote "origin"]
url = git@github.com-personal:YourUsername/YourRepo.git

Replace YourUsername and YourRepo with your personal GitHub account's username and the repository name, respectively. Repeat this process for other repositories.

For cloning new repositories, simply use the appropriate suffix

git clone git@github.com-personal:YourUsername/YourRepo.git
git clone git@github.com-work:WorkOrg/WorkRepo.git

Conclusion:

Leveraging the power of ~/.ssh/config to manage multiple GitHub accounts can significantly enhance your development experience. With this simple yet powerful configuration, you can seamlessly switch between accounts, ensuring a smooth and error-free workflow. Embrace the convenience of managing multiple GitHub accounts effortlessly, and watch your productivity soar to new heights. Happy coding!

Resources:

Creating a new ssh key: https://docs.github.com/en/authentication/connecting-to-github-with-ssh/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent

Adding an ssh key to GitHub: https://docs.github.com/en/authentication/connecting-to-github-with-ssh/adding-a-new-ssh-key-to-your-github-account

--

--

Sushant Mimani
Nerd For Tech

Experienced software engineer with expertise in Java, C#, GoLang, AWS, and open source contributions. Passionate about building innovative solutions. ✨