Introduction
In our last article, we demonstrated how we could mirror our repository from our local computer to GitHub and use https to push our repository data from our local computer to GitHub. In this article, we will demonstrate how we may use the ssh protocol to authenticate with GitHub and push changes to it.
Demonstration:
First, we will need to generate our ssh keys on our local computer. We will be using these keys to authenticate with GitHub.
[sahil@git-ansible ~]$ ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/home/sahil/.ssh/id_rsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/sahil/.ssh/id_rsa. Your public key has been saved in /home/sahil/.ssh/id_rsa.pub. The key fingerprint is: b3:b4:0c:ad:44:a2:c4:7b:46:52:1e:5d:c9:14:7c:d0 sahil@git-ansible The key's randomart image is: +--[ RSA 2048]----+ | o. === | | . o .. + E | | + + . . | | . = o . | | o o o S | | o . = + | | . + | | | | | +-----------------+ [sahil@git-ansible ~]$ ls -l /home/sahil/.ssh total 24 -rw-r--r--. 1 sahil sahil 658 Dec 28 04:03 authorized_keys -rw-------. 1 sahil sahil 668 Dec 17 20:26 id_dsa -rw-r--r--. 1 sahil sahil 601 Dec 17 20:26 id_dsa.pub -rw------- 1 sahil sahil 1679 Jun 12 09:44 id_rsa -rw-r--r-- 1 sahil sahil 399 Jun 12 09:44 id_rsa.pub -rw-r--r--. 1 sahil sahil 741 Feb 19 17:28 known_hosts
Now that our ssh keys have been generated we will need to copy our public key id_rsa.pub to GitHub. Log in to your account on GitHub and go to settings. From there select ‘SSH and GPG keys’. Now click on New ssh key. Here paste the content of your public key. Once that is done You should see the below page. Now we’ll set GitHub as our remote, named as the origin and will push code from our local repository to GitHub. Given below is the command we need to type to accomplish this task.
[sahil@git-ansible perl_scripts_for_training]$ git remote add origin git@github.com:sahilsuri007/perl_scripts_for_training.git [sahil@git-ansible perl_scripts_for_training]$
Notice that this time the URL I provided for the origin is different. This is because now we will be using ssh to authenticate with GitHub instead of https. The ssh based URL will be git@github.com:sahilsuri007/perl_scripts_for_training.git for our repository named perl_scripts_for_training. By running ‘git remote -v’ we may view the push and fetch URLs for our remote origin.
[sahil@git-ansible perl_scripts_for_training]$ git remote -v origin git@github.com:sahilsuri007/perl_scripts_for_training.git (fetch) origin git@github.com:sahilsuri007/perl_scripts_for_training.git (push)
Since we have copied our public key over to GitHub and have added the required URLs for our remote, let’s push our repository over to GitHub.
[sahil@git-ansible perl_scripts_for_training]$ git push origin master The authenticity of host 'github.com (192.30.253.113)' can't be established. RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added 'github.com,192.30.253.113' (RSA) to the list of known hosts. Counting objects: 40, done. Delta compression using up to 2 threads. Compressing objects: 100% (40/40), done. Writing objects: 100% (40/40), 8.32 KiB | 0 bytes/s, done. Total 40 (delta 10), reused 0 (delta 0) remote: Resolving deltas: 100% (10/10), done.
If you refresh your GitHub page for the repository you would observe that it has been updated with the content that we just pushed to it.
Conclusion
In this article, we demonstrated how we could use the ssh protocol and ssh public keys to authenticate with GitHub. This provides a more flexible mechanism for the integration of our git repositories with GitHub as the process can be automated/scripted. We hope that you found this article to be useful and we look forward to your suggestions and feedback.
Sahil Suri
Latest posts by Sahil Suri (see all)
- Google Cloud basics: Activate Cloud Shell - May 19, 2021
- Create persistent swap partition on Azure Linux VM - May 18, 2021
- DNF, YUM and RPM package manager comparison - May 17, 2021
- Introduction to the aptitude package manager for Ubuntu - March 26, 2021
- zypper package management tool examples for managing packages on SUSE Linux - March 26, 2021