Git

Projekty na Githubie - pierwsze kroki

Git jest obecnie najpopularniejszym i najważniejszym systemem kontroli wersji. Powstał ponad 10 lat temu do obsługi rozwoju jądra Linuksa i przez ten czas rozwinął się w cały ekosystem umożliwiający i ułatwiający rozwój oprogramowania. Jednym z elementów tego ekosystemu jest Github, witryna i społeczność używająca jej interfejsu do rozwoju i publikacji programów, skryptów, dokumentów itp. Wersja darmowa do niedawna pozwalała tylko na publiczne repozytoria, ale od 2019 są też dostępne repozytoria prywatne z ograniczeniem do trzech współpracowników. Wg wielu opinii zawartość konta na Gitbhubie jest ważnym elementem CV.

Porównanie gita z innymi systemami kontroli wersji można znaleźć na Wikipedii - Comparison of version-control software

Porownanie Githuba z innymi witrynami tego typu - Comparison of source-code-hosting facilities

Poniżej opis jak zacząć używanie Githuba i gita.

Jako edytor wybrałem VSC dla przykładu bo jest 1) dobry 2) powszechnie używany 3) darmowy, bez ograniczeń 4) dostępny dla wszystkich trzech ważnych systemów operacyjnych (Windows, Linuks. Mac) 5) bez konfiguracji jest przygotowany do gita

1. Założenie konta na Github.com

Jest to tak samo proste jak założenie konta na każdej innej witrynie, wybieramy nazwę użytkownika, podajemy konto pocztowe i wybieramy hasło. To wszystko.

Z ikonki użytkownika w prawym górnym rogu możemy wybrać widok profilu użytkownika, repozytoria, albo ustawienia. W repozytoriach mamy przycisk New, którym tworzymy nowe repozytorium.

2. Zainstalowanie gita na lokalnym komputerze

np.:

 apt-get install git

3. Inicjalizacja gita

W katalogu głównym użytkownika z linii poleceń:

 $ git init
hint: Using 'master' as the name for the initial branch. This default branch name
hint: is subject to change. To configure the initial branch name to use in all
hint: of your new repositories, which will suppress this warning, call:
hint: 
hint: 	git config --global init.defaultBranch <name>
hint: 
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
hint: 'development'. The just-created branch can be renamed via this command:
hint: 
hint: 	git branch -m <name>
Initialized empty Git repository in /user_path/.git/

co utworzy katalog .git (będą tam repozytoria lokalne i cała konfiguracja lokalnego repozytorium.

$ git config --global init.defaultBranch main

4. Plik konfiguracyjny

Jest to ~/.gitconfig 8.1 Customizing Git - Git Configuration oraz trochę nowsza dokumentacja na Githubie Getting started with Git.

5. Konfiguracja

W linii poleceń można ustawić trzy podstawowe, niezbędne rzeczy (jeżeli po config damy parametr —global, tworzy ustawienie dla wszystkich kont):

 user: $ git config --global user.name "user"
 user: $ git config --global user.email "user@mail.com"
 user: $ git config --global core.editor code
 user: $ git config --list

Ostatnie polecenie pokazuje treść pliku konfiguracyjnego, warto ją sprawdzić, dlatego, że np. bardzo często użytkownicy popełniają literówkę i zamiast user.email wpisują user.mail czego git nie akceptuje ani nie koryguje.

6. Utworzenie klucza SSH

4.3 Git on the Server - Generating Your SSH Public Key:

 cd ~/.ssh

sprawdzamy czy nie ma już pliku klucza; dokumentacja Gita wciąż mówi o starym standardzie czyli id_rsa.

 user:~/.ssh$ ls
 authorized_keys

Jeżeli nie ma to zgodnie z Generating a new SSH key and adding it to the ssh-agent gdzie address@email to adres maila skonfigurowany w Githubie, a user_path to ścieżka dostępu do katalogu użytkownika; tutaj jak widać dwukrotnie jesteśmy pytani: najpierw o lokalizację klucza, najlepiej Enterem zakceptować domyślną, a potem o frazę hasła, jeżeli jej nie potrzebujemy również można Enterem przejść dalej:

user:~$ ssh-keygen -t ed25519 -C "address@email"
Generating public/private ed25519 key pair.
Enter file in which to save the key (/user_path/.ssh/id_ed25519): 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /user_path/.ssh/id_ed25519
Your public key has been saved in /user_path/.ssh/id_ed25519.pub
The key fingerprint is:
SHA256:du1Nez66NrqZJqetj+DGhT2cthuTRlDpCezA9snCsjw address@email
The key's randomart image is:
+--[ED25519 256]--+
|    . .  ..      |
|     + o..       |
|    o =.+ .      |
|   . o =.o .     |
|  . o . S.o . .  |
|   E   o.O.. o . |
|    . ..o=o . o .|
|      .ooo=ooo + |
|      .. =OB+o+ o|
+----[SHA256]-----+

Na maila dostaniemy od Githuba komunikat z informacją o zarejestrownaym nowym kluczu, będzie tam jego fingerprint.

Wyjaśnienie czym jest randomart What is randomart produced by ssh-keygen?.

Wygląd kluczy pozostawiłem, ale oczywiście znaki są pozamieniane, pamiętajmy, że każdy klucz prywatny jest tajemnicą, jeżeli nie mamy pewności jaki to jest traktujemy go jak prywatny i nawet publiczny ujawniamy tylko tam gdzie jest to potrzebne.

7. Umieszczenie klucza na Githubie

Po wejściu do ./ssh zobaczymy dwa nowoutworzone pliki: id_ed25519 i id_ed25519.pub. To pliki kluczy, ten drugi to jak samo rozszerzenie wskazuje plik klucza publicznego. W poprzedniej wersji nazywał się id_rsa.pub. Warto pamiętać o archiwizacji tych plików podczas reinstalacji systemu. Kopiujemy zawartość klucza publicznego do Github / Settings / SSH ad GPG keys i zapisujemy. Jeżeli nie ma żadnego komunikatu błędu oznacza to, że został zaakceptowany. Zawsze będzie można go skasować i zamienić na inny.

8. Utworzenie repozytorium na Githubie i lokalnej kopii repozytorium

W utworzeniu repozytorium pomaga następująca ściąga z Githuba:

Jeżeli wybieramy uwierzytelnianie przez SSH:

Quick setup — if you’ve done this kind of thing before

git@github.com:tdudkowski/txts.git

Get started by creating a new file or uploading an existing file. We recommend every repository include a README, LICENSE, and .gitignore.

…or create a new repository on the command line

echo "# txts" >> README.md
git init
git add README.md
git commit -m "first commit"
git branch -M main
git remote add origin git@github.com:tdudkowski/txts.git
git push -u origin main

…or push an existing repository from the command line

git remote add origin git@github.com:tdudkowski/txts.git
git branch -M main
git push -u origin main

Dennis “Git detect dubious ownership in repository” XSalsa20bonito

 Get started by creating a new file or uploading an existing file. We recommend every repository include a README, LICENSE, and .gitignore.

 …or create a new repository on the command line
 echo "# repository-name" >> README.md
 git init
 git add README.md
 git commit -m "first commit"
 git remote add origin git@github.com:username/repository-name.git
 git push -u origin master
 …or push an existing repository from the command line
 git remote add origin git@github.com:username/repository-name.git
 git push -u origin master
 …or import code from another repository

Jeżeli mamy jakieś repozytoria na Githubie i tworzymy lokalną kopię na komputerze. Tworzenie takiej kopii nie wymaga uwierzytelnienia. Wystarczy polecenie, które tworzy kopię repozytorium w katalogu .git:

 user:~/.git$ git clone git@github.com:user/RepoName

9. Edycja

Uruchamiamy VSC i otwieramy katalog .git. Od razu widać nowe opcje i inny wygląd listy katalogów i plików, wybieramy z danego repozytorium pliki do edycji i dokonujemy zmian.

10. Commit

Linia poleceń jest już w Code, ale wszystko jedno której użyjemy. Commit można zrobić na dwa sposoby, tak jak opisano w tym artykule: Start a new git repository, możemy użyć HTTPS co będzie za każdym razem wymagać podania hasła:

 https://github.com/username/new_repo

Lub SSH, które zapisuje klucz

 git@github.com:username/new_repo

11. .gitignore

Pozostaje jeszcze do rozwiązania jeden problem, otóż VSC pokazuje tysiące oczekujących zmian. Żeby ograniczyć gita tylko do jego własnego katalogu potrzebujemy pliku .gitignore - Git - gitignore Documentation. W najprostszej podanej w dokumentacji formie wyklucza wszystkie katalogi, ograniczając działanie gita do jednego:

 # exclude everything except directory user/.git
 /*
 !/user
 /user/*
 !/user/.git

Odnośniki

Git

Git - artykuły

Youtube

.gitignore

Narzędzia

Git GUI

Po polsku

Github

Github YT

Github CLI

Narzędzia zbudowane w Githubie

Gitlab

Hasła

Github Pages

CI/CD