GitHub is a famous portal, widely known by developers around the world to collaborate in code creation and sharing.
Most users know GitHub only for “git clone” commands, which allows you to download and use packages from remote repositories.
In this tutorial I’ll show you how to create your own repository on GitHub and manage files from a terminal in Raspberry PI OS with main git commands.
I’ll use a Raspberry Pi Zero W, but every Raspberry PI board will work same way.
Understanding Git Basic process with GitHub
Before starting in explainig commands to create your repository and aligning files, we need to cover a deeper knowledge in git and GitHub process.
Following picture simplify what is behind their relation:
Git manages all processes inside local system (Raspberry PI for us). It initialize folders structure and is responsible for managing communications with GitHub portal. Here are located files you are going to modify with your local version.
GitHub Repository is like a remote folder including files already added to specific version (main version is usually named “master”). GitHub repository also marks all modifications received from remote users, maintaining change trace for possible restore needs.
Local folder will usually be copied from GitHub repository by initial “git copy” process (if you start from existing repository). This is an example of downstream process. Repository can then be sinced with the “git add origin” command if you need to propose changes to original GitHub files.
Once every change is made on local folder/files, it is saved only in your local PC and traced by git. If you want to upload it to GitHub repository, you need first to move changes in a local staging area. After being recorded on staging, then changes can be pushed on GitHub repository with “git push” command. Last one is an example of upstream process.
A simple picture can show the main overall process:
What We Need
As usual, I suggest adding from now to your favourite ecommerce shopping chart all needed hardware, so that at the end you will be able to evaluate overall costs and decide if continuing with the project or removing them from shopping chart. So, hardware will be only:
- Raspberry PI Zero W (including proper power supply or using a smartphone micro usb charger with at least 3A) or newer Raspberry PI Board
- high speed micro SD card (at least 16 GB, at least class 10)
This guide is based on Raspberry PI OS Lite installation (headless). With Desktop installation you also will need Monitor and Keyboard/Mouse.
Check hardware prices with following links:
Operating System preparation
I will use an headless Raspberry PI OS Lite installation. Anyway, you can use this guide also from a Desktop distribution by using Terminal available inside it.
Once installed, make your OS up to date:
sudo apt update sudo apt upgrade
Istall git package:
sudo apt install git
Configure Git Environment
One of most common personalization is about user identity (name and email are required for commit operations):
git config --global user.name "myGitHubUser" git config --global user.email myEmail@example.com
pi@raspberrypi:~ $ git config --list user.name=myGitHubUser user.email=myEmail@example.com
Basic git configuration is done. Move to GitHub operations.
GitHub User Account and Repository creation
For a new GitHub repository, you will need to create it from GitHub portal.
So, go to GitHub Home Page from your favourite browser and create a new free account. Once you account is ready and activated, login and, from dashboard, use profile icon to open drop-down menù and select “Your repositories”:
Your repositories page will be empty:
Use “New” green button to create a new repo. Next page will ask you to set Repository name and some few settings. The only one field mandatory to create a new repository is its name:
You can then decide to make it public or private. Then you can scroll down to “Create Repositpry” button leaving all other settings as default (all settings can be changed after Repo creation). New screen will show link to sincronyze your GitHub Repository:
This url will be useful in local git commands.
For the moment demo is still empty. Swith on Raspberry PI terminal for next steps.
Git Basic Operations for Publishing Changes
From terminal session, create a new folder (where local files will be stored) and enter it:
mkdir demo cd demo
To start version control for this folder with Git, you first need initialize it and will have following result:
pi@raspberrypi:~/demo $ git init Initialized empty Git repository in /home/pi/demo/.git/
After this operation, a new hidden folder named “.git” is created:
pi@raspberrypi:~/demo $ ls -la total 12 drwxr-xr-x 3 pi pi 4096 Sep 14 18:14 . drwxr-xr-x 5 pi pi 4096 Sep 14 18:11 .. drwxr-xr-x 7 pi pi 4096 Sep 14 18:14 .git
Create a simple README.md file with a few text:
My file will include followin text:
# My Demo Repository by peppe8o.com
Close and save. “Git status” command will show following result:
pi@raspberrypi:~/demo $ git status On branch master No commits yet Untracked files: (use "git add …" to include in what will be committed)
README.mdnothing added to commit but untracked files present (use "git add" to track)
This message warnings you that a new untracked file is present, but it needs to be moved in staging area before being committed. Your GitHub Repository is still empty. Move README.md in staging area:
git add README.md
and check again current status:
pi@raspberrypi:~/demo $ git status On branch master No commits yet Changes to be committed: (use "git rm --cached …" to unstage)
new file: README.md
A bit better. README.md file is ready to be committed. Remember, your GitHub Repository is still empty. You can also comment this operation with -m option, followed by your comment. Below command and result:
pi@raspberrypi:~/demo $ git commit -m "first commit note" [master (root-commit) 48e5a48] first commit note 1 file changed, 2 insertions(+) create mode 100644 README.md
Ok, now your local repository is aligned with workspace.
To upstream your README.md file, you need first to set remote Repository where to push changes. Get back your GitHub repository url and keep with you GitHub username and password (last one will be necessary in a few lines). From terminal (changing “https://github.com/peppe8o/demo.git” with your one):
git remote add origin https://github.com/peppe8o/demo.git
This will set the new remote. Checking it, will return results similar to following:
pi@raspberrypi:~/demo $ git remote -v origin https://github.com/peppe8o/demo.git (fetch) origin https://github.com/peppe8o/demo.git (push)
Push changes from local Repository to GitHub origin (will require your GitHub user and password) and results will be:
pi@raspberrypi:~/demo $ git push origin master Username for 'https://github.com': peppe8o Password for 'https://email@example.com': Enumerating objects: 3, done. Counting objects: 100% (3/3), done. Writing objects: 100% (3/3), 246 bytes | 22.00 KiB/s, done. Total 3 (delta 0), reused 0 (delta 0) To https://github.com/peppe8o/demo.git [new branch] master -> master
Check back in your browser, by refreshing your Demo repository page:
Your README.md file is present and with text above provided. More info about formatting files can be found in GitHub basic writing guide docs.
More git interfacing commands can be found in general GitHub docs,
For some clarifications, credits goes to useful git-scm.com guide.
We are sorry that this post was not useful for you!
Let us improve this post!
Tell us how we can improve this post?