Jak skonfigurować prywatny serwer Git na swoim hostingu internetowym

Zarządzanie kodem i współpraca z członkami zespołu są kluczowe dla każdego projektu rozwojowego. Podczas gdy platformy takie jak GitHub i GitLab są popularne, skonfigurowanie własnego prywatnego serwera Git na hostingu internetowym może dać Ci większą kontrolę nad projektami, zapewnić prywatność i potencjalnie zaoszczędzić na kosztach. Ten samouczek przeprowadzi Cię przez kroki konfiguracji prywatnego serwera Git na hostingu internetowym.

1. Dlaczego warto założyć prywatny serwer Git?

Zanim przejdziesz do konfiguracji, ważne jest, aby zrozumieć korzyści wynikające z posiadania własnego serwera Git:

  • Prywatność: Twój kod pozostaje całkowicie prywatny i pod Twoją kontrolą.
  • Dostosowywanie: Dostosuj serwer do swoich konkretnych potrzeb i przepływów pracy.
  • Brak ograniczeń dotyczących użytkowników: Unikaj ograniczeń dotyczących liczby prywatnych repozytoriów i współpracowników.
  • Opłacalność: W przypadku zespołów składających się z wielu użytkowników samodzielne hostingowanie może być bardziej opłacalne niż płatne plany na popularnych platformach.

2. Wymagania wstępne

Zanim zaczniesz, upewnij się, że masz następujące rzeczy:

  • VPS lub serwer dedykowany: Hosting współdzielony zazwyczaj nie zapewnia niezbędnego dostępu i zasobów do skonfigurowania serwera Git.
  • Dostęp SSH: Aby zainstalować i skonfigurować serwer Git, potrzebny jest dostęp SSH do serwera.
  • Podstawowa wiedza o systemie Linux: Znajomość wiersza poleceń i systemu Linux jest niezbędna.

3. Instalowanie Git na serwerze

Najpierw musisz zainstalować Git na swoim serwerze. Wykonaj następujące kroki:

  1. Aktualizuj serwer: Run the following command to ensure your server’s package list is up to date:
    sudo apt-get update
  2. Zainstaluj Git: Install Git by running:
    sudo apt-get zainstaluj git
  3. Sprawdź instalację: Check that Git has been installed correctly by typing:
    git --wersja

4. Tworzenie użytkownika Git

Dobrą praktyką jest utworzenie osobnego użytkownika do zarządzania repozytoriami Git:

  1. Utwórz nowego użytkownika: Run the following command to create a user named ‘git’:
    sudo dodajużytkownika git
  2. Skonfiguruj dostęp SSH: Add your SSH key to the new user’s authorized keys to enable secure access:
    sudo mkdir /home/git/.ssh
    sudo touch /home/git/.ssh/authorized_keys
    sudo nano /home/git/.ssh/authorized_keys

    Wklej swój publiczny klucz SSH do pliku author_keys, a następnie zapisz i wyjdź.

  3. Ustaw uprawnienia: Adjust permissions for the SSH directory:
    sudo chown -R git:git /home/git/.ssh
    sudo chmod 700 /home/git/.ssh
    sudo chmod 600 /home/git/.ssh/authorized_keys

5. Tworzenie repozytorium

Teraz możesz utworzyć swoje pierwsze repozytorium Git:

  1. Utwórz katalog dla repozytoriów: Log in as the ‘git’ user and create a directory for your repositories:
    sudo su - git
    mkdir repos
    cd repos
  2. Zainicjuj repozytorium: Create a new Git repository by running:
    git init --bare twój-projekt.git

    W ten sposób powstaje puste repozytorium, które jest idealne dla zdalnych repozytoriów, do których kod jest wysyłany i z których jest pobierany.

6. Klonowanie i przesyłanie do repozytorium

Po skonfigurowaniu repozytorium możesz je sklonować na komputer lokalny i przesłać do niego kod:

  1. Klonuj repozytorium: On your local machine, run:
    git clone git@your-server-ip:/home/git/repos/your-project.git
  2. Dodaj pliki i zatwierdź: Add your files to the repository, commit them, and push the changes:
    cd your-project
    echo "# Your Project" >> README.md
    git add .
    git commit -m "Initial commit"
    git push origin master

7. Zarządzanie wieloma repozytoriami

Jeśli planujesz hostować wiele repozytoriów, możesz po prostu powtórzyć kroki tworzenia repozytoriów dla każdego projektu:

  • Utwórz nowy katalog dla każdego repozytorium w katalogu /home/git/repos/.
  • Zainicjuj każde nowe repozytorium poleceniem git init --bare your-new-project.git.
  • Uzyskaj dostęp i zarządzaj każdym repozytorium niezależnie poprzez SSH.

8. Zabezpieczanie serwera Git

Bezpieczeństwo jest krytycznym aspektem hostingu prywatnego serwera Git. Oto kilka kroków w celu zwiększenia bezpieczeństwa:

  • Wyłącz uwierzytelnianie hasłem: Skonfiguruj protokół SSH tak, aby zezwalał wyłącznie na uwierzytelnianie za pomocą klucza, edytując plik /etc/ssh/sshd_config i ustawiając opcję PasswordAuthentication no.
  • Konfiguracja zapory sieciowej: Użyj narzędzi takich jak UFW, aby zezwolić tylko na niezbędne porty (np. SSH) i zablokować inne.
  • Regularne kopie zapasowe: Wdrażaj regularne kopie zapasowe swoich repozytoriów, aby zapobiegać utracie danych.

9. Konfigurowanie interfejsów internetowych (opcjonalnie)

Jeśli wolisz zarządzać repozytoriami za pomocą interfejsu internetowego, możesz zainstalować oprogramowanie takie jak GitWeb lub Gitea:

  • GitWeb: Prosty interfejs internetowy umożliwiający przeglądanie repozytoriów Git.
  • Gitea: Samodzielnie hostowana usługa Git, która zapewnia przyjazny dla użytkownika interfejs podobny do GitHub.

Obie opcje wymagają dodatkowej konfiguracji i ustawień, ale mogą znacznie zwiększyć użyteczność serwera Git.

Wniosek

Skonfigurowanie prywatnego serwera Git na hostingu internetowym zapewnia pełną kontrolę nad kodem, zapewnia prywatność i umożliwia dostosowanie do Twojego przepływu pracy. Postępując zgodnie z tym przewodnikiem, możesz tworzyć i zarządzać własnymi repozytoriami Git, zapewniając, że Twój proces rozwoju pozostanie bezpieczny i wydajny.