Simple GitHub Tutorial
Published at 2024-01-27
Updated at 2024-11-25
Licensed under CC BY-NC-SA 4.0
git
software-engineering
ssh
github
version-control
I wrote a tutorial on Git. In this post, I'd like to introduce the platform that is indispensable when it comes to Git: GitHub.
As mentioned in the article about Git, GitHub is a platform for hosting remote Git repositories. Think of it simply, as a little cloud drive that you can use to sync (upload, download) your code and communicate with other developers.
Note
If you encounter any problems, I recommend that you check Github Docs, use a search engine, or ask an AI assistant. Alternatively, you can contact me at email.
Creating a Github Account
See:
Checking your Local Git Config
Make sure that you have told Git your name and email. That is say, you should have run:
git config --global user.name YOUR_NAME
git config --global user.email YOUR_EMAIL
Also see:
- Basic Configuration - Simple Git Tutorial
- Setting your username in Git - GitHub Docs
- Setting your commit email address - GitHub Docs
Connecting to GitHub with SSH
You are recommended to connecting to GitHub with SSH (instead of HTTP/HTTPS).
First, generate a new SSH key using new ED25519 algorithm:
ssh-keygen -t ed25519 -C YOUR_EMAIL
Then, Keep on repeating pressing Enter
until your prompt appear again.
Finally, add your public key to GitHub:
- Go to SSH and GPG keys - GitHub.
- Click the green
New SSH key
button at the top right of the page. - Fill out the form, where
key
is the content of~/.ssh/id_ed25519.pub
(This file is generated by thessh-keygen
command above. You may runcat ~/.ssh/id_ed25519.pub
on Linux or Mac or runnotepad ~/.ssh/id_ed25519.pub
on Windows to check its content). - Submit the form by clicking the green
Add SSH key
button.
Tip
The postfix .pub
indicates that the id_ed25519.pub
file is a public key. The ssh-keygen
command above also generates a private key file id_ed25519
(without the .pub
postfix).
Also see:
Using SSH over the HTTPS port (Optional but Recommended)
Due to the special network environment in China, you may often need to use proxy service to get a better browsing experience. Generally, when you enable the System Proxy
option, only the traffic on port 80/443 (corresponding to HTTP/HTTPS) will go through the proxy server, while the traffic on SSH's default port 22 will not. With the following settings, you can force SSH traffic to go to port 443.
To test if SSH over the HTTPS port is possible, run:
ssh -T -p 443 [email protected]
Type yes
if you see some info like:
Are you sure you want to continue connecting (yes/no/[fingerprint])?
If you receive response like below, it means it's OK:
Hi USERNAME! You've successfully authenticated, but GitHub does not
provide shell access.
You can now override your SSH settings to force any connection to GitHub.com to run through that server and port. Edit ~/.ssh/config
and add this section:
Host github.com
Hostname ssh.github.com
Port 443
User git
Now your usual command like:
git clone [email protected]/YOUR-USERNAME/YOUR-REPOSITORY.git
is equivalent to:
git clone ssh://[email protected]:443/YOUR-USERNAME/YOUR-REPOSITORY.git
Also see:
Basic Concept & Usages
Cloning
Repository (Repo) is a concept in Git that refers to a place where your code is stored. Repositories can be categorized as local or remote. You can use the git clone
command to clone a repository from GitHub, i.e. to clone a local repository based on a remote repository. The command format is as follows:
git clone URL [LOCAL_DIRECTORY_NAME]
where center brackets mean that LOCAL_DIRECTORY_NAME
is optional.
On the front page of any GitHub repository, you'll find a green Code
button; clicking on it will bring up a tab with HTTPS and SSH tabs (you must be logged in to see the SSH tabs). For public repositories that you don't have editing or modification rights to, you can use their HTTPS links to clone them; if you wish to edit a repository, you must use the corresponding SSH link.
Tip
If you have accidentally cloned the repository you wish to edit using an HTTPS link, you can run the following command on your local repository to update the remote address of your repository to the SSH version of the link (the origin
in the command is actually an "alias" to indicate which remote Git repository it is! ):
git remote set-url origin SSH_URL
Use the following command to check if the changes take effect:
git remote -v
The output should be similar to:
origin [email protected]:YOUR_NAME/YOUR_REPOSITORY.git (fetch)
origin [email protected]:YOUR_NAME/YOUR_REPOSITORY.git (push)
If you want to specify a branch when cloning, you can use -b
option:
git clone -b BRANCH URL
If you don't want to include all commits, you can use the --depth
option. This is helpful when cloning a large repo (you don't need so many commits before actually).
git clone URL --depth=1
Issues & Pull Requests
Issues and Pull Requests (PR) are two of the most important collaboration features on GitHub. With an Issue, you can point out problems with a codebase, suggest improvements, request new features, etc. With a Pull Request, you can ask the administrator of a codebase to merge your submitted code for the purpose of contributing to that codebase.
GitHub Workflow
Nothing helps you grasp how to use GitHub faster than learning by example. Below are two GitHub workflows to help you better understand the basic concepts and usage of GitHub.
Team Work
The following example workflow assumes you want to collaborate with your team members on a project and that you are the team leader responsible for creating and managing the repository:
- First, go to the GitHub homepage, click the plus button on the right side of the top toolbar, and select
New repository
from the dropdown menu. - Fill in the basic information for the repository, including the repository name, and specify the repository type (the default is
Public
, but in a group project context, you may prefer it to bePrivate
). Once completed, click theCreate repository
button at the bottom right of the page.
- After creation, you will be automatically redirected to the repository page:
- Follow the prompts on the page to execute the corresponding commands locally (remember to switch to
SSH
first):
- If you haven't created a local repository yet, create a new directory (e.g., named
teamwork-example
), thencd
into it and selectively execute the following commands:
echo "# teamwork-example" >> README.md # Create a README.md file
git init # Initialize a Git repository
git add README.md # Add the newly created README.md to the staging area
git commit -m "first commit" # Commit with the message "first commit"
git branch -M main # Rename the current branch to main
git remote add origin [email protected]:YOUR-NAME/teamwork-example.git # Add a remote repository named origin
git push -u origin main # Push to the main branch of the remote repository named origin
- If you already have a local repository, just
cd
into it and execute the following commands:
git remote add origin [email protected]:YOUR-NAME/teamwork-example.git # Add a remote repository named origin
git branch -M main # Rename the current branch to main
git push -u origin main # Push to the main branch of the remote repository named origin
-
Return to the GitHub repository page; you should now see your code here.
-
So far, only you have edit permissions for this repository. If you want to invite your group members, click on
Settings
in the top toolbar, selectCollaborators
in the leftAccess
section, and click theAdd people
button on the right:
The invited collaborators will receive an email notification. By following the instructions in the email, they will gain edit permissions for the repository. Then, collaborators can clone the repository using the SSH link, make changes locally following the regular Git workflow, and finally use git push
to push changes to the remote repository. Once a collaborator pushes, others can use git pull
to fetch the latest changes.
Important
In multi-editor scenarios, branch management becomes more complex. A good practice is for each editor to execute git pull
to fetch the latest changes before starting work and to develop on their own feature branches instead of directly on the main branch. This can help avoid direct conflicts and make code review and merging easier to manage. Additionally, the PR feature introduced in the next example workflow can facilitate more efficient collaboration.
Contributing Code to an Open Source Project
The following example workflow assumes you want to contribute code to an open-source project:
- First, go to the homepage of the open-source project and click the Fork button in the upper right corner.
- On the new Fork page that you are automatically redirected to, customize the relevant information as needed or keep the default, then click the
Create fork
button.
- Now you should be redirected to a repository with the same name (if you did not change the default settings in the previous step). Under the repository name, it will indicate the source of this fork. For example, in the image below, the public repository is
withastro/astro
, and my GitHub username is BlockLune, so the forked repository is namedBlockLune/astro
.
- Clone this repository to your local machine using the SSH link:
git clone SSH_URL
- In your terminal, navigate to the project's root directory and run the following command to create a new branch and switch to it. The
BRANCH_NAME
should be descriptive and conform to the project's conventions (for example, if you want to add a new greeting feature, your branch name might befeature/greeting
):
git checkout -b BRANCH_NAME
-
Execute your Git workflow. For example, edit the file, save the changes using
git add
andgit commit
when appropriate (with a commit message that is also descriptive and conforms to the project's conventions), and then usegit push
to push the changes to the repository you Forked. -
When you believe your changes are complete, return to GitHub and navigate to the public repository address of the project. Click on
Pull requests
at the top to enter the pull request tab, then click the greenNew pull request
button on the right.
-
On the new pull request page, choose the
base
andcompare
branches.base
indicates the branch you want to push to;compare
indicates the branch where your new feature resides (e.g.,feature/greeting
), which you want the other party to pull from. After making your selections, click the greenCreate pull request
button. -
The page will automatically redirect to a new pull request page. Here, you can communicate with the repository maintainers or others, and continue to submit new commits to this branch regarding any issues or possible improvements you discover. Observe the URL of this page, which looks like
https://github.com/REPO_OWNER/REPO/pull/ID
. The ID is incrementally generated; Issues and PRs increment together, so the first Issue or PR in the repository has the ID#1
, the second is#2
, and so on. -
If the work in your branch is to fix a specific issue (for example,
#2
), you can also add keywords likeClose #2
in the description text to link your PR to that Issue, which will automatically close the associated Issue when the PR is merged. For more information on linking PRs to Issues, refer to Linking a pull request to an issue. -
The next steps will be the repository owner's responsibility: they will review your code and, if everything is correct, merge your branch (completing the pull operation). Once merged, the commits from the contribution branch will be integrated into the
base
branch in some form, at which point it is safe to delete the contribution branch (thecompare
branch mentioned above).
Tip
Through this workflow, you should now understand the meaning of a "pull request (PR)": you forked the original repository and pushed your contributions to this repository, so you are requesting the original repository to pull your contributions, which is what a "pull request (PR)" is.
Learn more:
Related Git Commands
# add a new remote server
git remote add NAME URL
# remove a specific remote server
git remote remove NAME
# set (update) the URL of a remote server
git remote set-url NAME URL
# show remote servers
git remote -v
# rename a remote server
git remote rename OLD_NAME NEW_NAME
# some info about a specific remote server
git remote show NAME
# push
git push -u NAME BRANCH # or `git push --set-upstream NAME BRANCH`
# fetch
git fetch # from the default remote upstream repo
git fetch NAME # from a specific remote upstream repo
# fetch & merge
git pull
Repository Statistics
You can see the Languages
section on the right side of the GitHub repository page that shows information about the languages used by this repository. This information is generated by github-linguist/linguist.
Sometimes you may want to have some control over the information here (e.g. you may want to categorize Jupyter Notebook as Python), so it's useful to know where they come from. One possible way to do this control is to use .gitattributes
, for example:
*.ipynb linguist-language=Python
Learn more:
GitHub Profile
You can create a profile page by creating a repository with the same name as your GitHub username and adding a README.md
file to it. This page will appear on your GitHub personal page. For example, my repository is BlockLune/BlockLune, which is displayed on my GitHub personal page.
Many people will choose to add some statistics here. there are actually a number of specialized projects on GitHub for generating these statistics, for example:
- anuraghazra/github-readme-stats
- ryo-ma/github-profile-trophy
- DenverCoder1/github-readme-streak-stats
Learn more: