dev-resources.site
for different kinds of informations.
How to Link git to GitHub via SSH on Windows
As a developer, learning about github can feel great at first, I mean who doesn't need a secure cloud storehouse for their codes? The importance and use of git and GitHub cannot be overemphasized but there come a point in time where you just get tired and bored of always;
- Heading to github.com,
- Locating your repo
- Adding new files to the repo
- Clicking and dragging the files from your PC into GitHub
- And finally writing a commit message.
All these just to push your code to GitHub, what if you needed to make just a minor change? You'd have to go through that mini hell again? Actually, you don't have to because all these steps can be shortened to;
git add .
git commit -m "minor fix"
git push
Yeah that's right, just these 3 commands above does all that work for you and fast.
But before you acquire such power, there's a price you'd have to pay. and that is, you'd have to setup a connection between git and GitHub first which luckily isn't that hard at all. I am going to share those steps in this post.
Β
Step 1: Download and install git
Alright, the first step is to have git installed in your PC, if you already have it, great! If not just click here and download a version suitable for you PC
After download, start the install wizard and follow the prompts to install.
Upon installation of git, 3 other applications would also be automatically installed in your PC: Git cmd, Git GUI and Git Bash. These are just the different ways of interacting with git.
Configuring git
Open Git Bash, which should look similar to the image below
Run these commands:
git config --global user.name "Your Name"
#This name will be associated with your commits
git config --global user.email "Your email Address"
#This email will be associated with your commits
You can verify that these has been set by running
git config --list
Β
Step 2: Generate SSH Key
Installing and configuring git was so easy right, now to an easy but not so easy step, generating an SSH key;
What is an SSH key and why do we need it?
To answer that let's first understand what SSH even mean.
SSH stands for Secure Shell, and it's a network protocol (like HTTPS but different) that allows secure communication between devices over an insecure connection.
Meanwhile an SSH key is a pair of cryptographic keys (a public key and a private key) used to authenticate a secure connection between your computer and a remote server (in this case, GitHub). Put simply, it's a file containing encrypted texts used for authetication.
We need it to authenticate to GitHub without our username or password.
To generate the key, open Git Bash and run these commands:
ssh-keygen -t rsa -b 4096 -C "[email protected]"
#Replace "[email protected]" with the email address associated with your GitHub account.
Let's breakdown some of the command arguments above:
ssh-keygen - This generates a new SSH key pair (a public key and a private key)
-t rsa - This sets the type of SSH encryption to rsa (Rivest-Shamir-Adleman) which is the most widely used. Other types includes;
ECDSA (Elliptic Curve Digital Signature Algorithm)
ED25519 (Edwards-curve Digital Signature Algorithm 25519)-b 4096 - This sets the number of bits of the generated key to 4096. The other possible value for rsa encryption is 2048 which is less secure.
-C [email protected] - This adds a comment to the key (usually your email address)
When prompted after running the above command, press Enter to accept the default file location for the file containing the generated SSH key.
Next, you can optionally set a passphrase for extra security or simply leave the field blank and press Enter twice.
Lastly, copy the public key to your clipboard with the following command.
clip < ~/.ssh/id_rsa.pub
or
cat ~/.ssh/id_rsa.pub
This will display the public key on your Git Bash terminal, then you can manually highlight and copy the public SSH key
Β
Step 3: Add SSH Key to Github and link to Github repository locally
Now for the third and final step, do these:
- Log in to your GitHub account.
- Go to Settings > SSH and GPG keys.
- Click New SSH key.
- In the Title field, add a descriptive name (e.g., "git ssh")
- Paste your public key into the Key field. (The one you copied earlier)
- Click Add SSH key.
Confirm successfull connection
To confirm the connection between git and GitHub, open Git Bash and run the command:
ssh -T [email protected]
if connection was successful you'll a message similar to:
Hi <username>! You've successfully authenticated, but GitHub does not provide shell access.
Else simply reply yes multiple times when prompted. Afterwards, run the first command again to reconfirm.
Linking to a GitHub repo from VS code terminal
Congratulations on Linking your git to your GitHub via SSH. Goodnews is you only need to go through all those linking steps once. Now comes the easiest part.
Goto GitHub and create a new repo or open an existing repo
Click on SSH
For a new repo without any files that looks like the above pic:
Click on SSH and copy the url
For an already existing repo with files, open the repo, click Code > click on the ssh tab and copy the url
Open your project folder in VS and click on Terminal > New Terminal
run the following command:
git clone [email protected]:rowleks/test-repo.git
Next navigate to the recently cloned repo (folder) on your PC project folder and open the newly cloned repo in VS code
Open the VS code terminal and run the following commands
git add .
git commit -m "Initial commit"
git branch -M main
git push origin main
And that's it.
Subsequently all you need to do to push to GitHub from that repository are the commands:
git add .
git commit -m "commit message"
git push
Thank you for reading! I hope this helped.
Featured ones: