Jak zainstalować GitLab Community Edition (CE) 11.x na Debian 9

Ponieważ GitHub został przejęty przez Microsoft, wielu programistów planowało migrację własnych repozytoriów kodów z github.com do alternatywnego rozwiązania hostowanego samodzielnie. GitLab Community Edition (CE) jest najczęstszym wyborem.

Jako wyrafinowane i elastyczne rozwiązanie, GitLab CE może być wdrażany przy użyciu różnych metod, ale omawiany jest tu tylko oficjalnie zalecany sposób, instalacja pakietu Omnibus.

Wymagania wstępne

  • Świeża instancja serwera Vultr Debian 9 x64 z co najmniej 4 GB pamięci. 8 GB lub więcej jest zalecane do obsługi do 100 użytkowników. Powiedz, że jego adres IPv4 to 203.0.113.1.
  • Użytkownik sudo .
  • Domena gitlab.example.comjest wskazywana na wspomnianą wyżej instancję.

Uwaga: W przypadku wdrażania na własnej instancji serwera należy zastąpić wszystkie przykładowe wartości rzeczywistymi.

Krok 1: Wykonaj podstawowe zadania dotyczące hostingu GitLab CE

Uruchom terminal SSH i zaloguj się do instancji serwera Debian 9 x64 jako użytkownik sudo.

Dodaj partycję wymiany i popraw ustawienie swapiness

Podczas wdrażania GitLab CE 11.x na komputerze z 4 GB pamięci konieczne jest skonfigurowanie partycji wymiany 4 GB w celu zapewnienia płynnego działania.

sudo dd if=/dev/zero of=/swapfile count=4096 bs=1M
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
echo '/swapfile   none    swap    sw    0   0' | sudo tee -a /etc/fstab
free -m

Uwaga: Jeśli używasz innego rozmiaru serwera, rozmiar partycji wymiany może się różnić.

Dla celów wydajności systemu zaleca się skonfigurowanie ustawienia zamiany jądra na niską wartość, taką jak 10:

echo 'vm.swappiness=10' | sudo tee -a /etc/sysctl.conf
sudo sysctl -p
cat /proc/sys/vm/swappiness

Wyjście catpolecenia będzie 10.

Skonfiguruj nazwę hosta urządzenia i pełną nazwę domeny (FQDN)

Użyj następujących poleceń, aby skonfigurować nazwę hosta gitlabi nazwę FQDN gitlab.example.comdla urządzenia:

sudo hostnamectl set-hostname gitlab
sudo sed -i "1 i\203.0.113.1 gitlab.example.com gitlab" /etc/hosts

Możesz potwierdzić wyniki:

hostname
hostname -f

Skonfiguruj reguły zapory

Skonfiguruj rozsądne reguły zapory do uruchamiania witryny:

sudo iptables -F
sudo iptables -X
sudo iptables -Z
sudo iptables -A INPUT -s $(echo $(w -h ${USER}) | cut -d " " -f3) -p tcp --dport 22 -j ACCEPT
sudo iptables -A INPUT -i lo -j ACCEPT
sudo iptables -A INPUT -d 127.0.0.0/8 -j REJECT
sudo iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
sudo iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
sudo iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP
sudo iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 443 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 22 -j ACCEPT
sudo iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
sudo iptables -P INPUT DROP
sudo iptables -P OUTPUT ACCEPT
sudo iptables -P FORWARD DROP

Wszystkie powyższe ustawienia zaczną obowiązywać natychmiast. Użyj następującego polecenia, aby wyświetlić je do przeglądu:

sudo iptables -L -n

Użyj iptable-persistentnarzędzia, aby zapisać wszystkie istniejące reguły iptables w pliku /etc/iptables/rules.v4, dzięki czemu wszystkie reguły iptables będą trwałe:

sudo apt install -y iptables-persistent

Podczas instalacji zostaniesz zapytany, czy chcesz zapisać aktualne reguły IPv4 / IPv6. Naciśnij ENTERdwukrotnie, aby zapisać bieżące reguły IPv4 i IPv6 w /etc/iptables/rules.v4i /etc/iptables/rules.v6.

Jeśli spróbujesz później zaktualizować reguły IPv4, użyj następujących poleceń, aby zapisać aktualizację:

sudo bash -c 'iptables-save > /etc/iptables/rules.v4'

Zaktualizuj system

sudo apt update
sudo apt upgrade -y && sudo shutdown -r now

Gdy system uruchomi się ponownie, zaloguj się ponownie jako ten sam użytkownik sudo, aby przejść dalej.

Krok 2: Zainstaluj wymagane zależności

Przed zainstalowaniem GitLab CE musisz zainstalować wymagane zależności:

sudo apt install -y curl openssh-server ca-certificates

Ponadto, jeśli chcesz używać Postfix do wysyłania powiadomień, musisz zainstalować Postfix:

sudo apt install -y postfix

Podczas instalacji może pojawić się ekran konfiguracji:

  1. Naciśnij, TABaby podświetlić <OK>przycisk na pierwszym ekranie, a następnie naciśnij ENTER.
  2. Wybierz Internet Sitei naciśnij ENTER.
  3. W mail namepolu wpisz nazwę FQDN serwera gitlab.example.comi naciśnij ENTER.
  4. Jeśli pojawią się inne ekrany, naciśnij, ENTERaby zaakceptować ustawienia domyślne.

Uruchom i włącz usługę Postfix:

sudo systemctl enable postfix.service
sudo systemctl start postfix.service

Zmodyfikuj reguły zapory dla Postfix:

sudo iptables -A INPUT -i eth0 -p tcp --dport 25 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 143 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 993 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 110 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 995 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo bash -c 'iptables-save > /etc/iptables/rules.v4'

Po zainstalowaniu Postfix musisz skonfigurować Postfix, edytując jego główny plik konfiguracyjny /etc/postfix/main.cfzgodnie z aktualnymi ustawieniami serwera.

Uwaga: oprócz powyższych instrukcji musisz przesłać zgłoszenie do pomocy technicznej, aby anulować domyślny blok Vultr na porcie SMTP 25.

Alternatywnie, jeśli chcesz użyć innego rozwiązania do przesyłania wiadomości, po prostu pomiń instalację Postfix i wybierz użycie zewnętrznego serwera SMTP po zainstalowaniu GitLab CE.

Krok 3: Zainstaluj repozytorium GitLab APT, a następnie zainstaluj GitLab CE

Skonfiguruj repozytorium GitLab CE APT w swoim systemie:

cd
curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash

Następnie zainstaluj GitLab CE 11.x:

sudo EXTERNAL_URL="http://gitlab.example.com" apt install -y gitlab-ce

Instalacja może chwilę potrwać.

Na koniec wskaż swoją ulubioną przeglądarkę internetową http://gitlab.example.com, a następnie prześlij nowe hasło, gdy pojawi się monit o zakończenie instalacji.

Od teraz użyj poniższych poświadczeń, aby zalogować się jako administrator:

  • Nazwa Użytkownika: root
  • Hasło: <your-new-password>

Krok 4: Włącz dostęp HTTPS poprzez zintegrowanie certyfikatu Let's Encrypt SSL

Na razie pomyślnie zainstalowałeś GitLab CE 11.x na instancji serwera, a użytkownicy mogą już odwiedzać witrynę przy użyciu protokołu HTTP. Ze względów bezpieczeństwa zaleca się włączenie dostępu HTTPS do serwera GitLab poprzez zintegrowanie certyfikatu Let's Encrypt SSL.

Użyj viedytora, aby otworzyć plik konfiguracyjny GitLab CE:

sudo vi /etc/gitlab/gitlab.rb

Znajdź następujące dwie linie:

external_url 'http://gitlab.example.com'
# letsencrypt['contact_emails'] = [] # This should be an array of email addresses to add as contacts

Wymień je odpowiednio:

external_url 'https://gitlab.example.com'
letsencrypt['contact_emails'] = ['[email protected]']

Zapisz i wyjdź:

:wq!

Ponownie skonfiguruj GitLab CE przy użyciu zaktualizowanych ustawień:

sudo gitlab-ctl reconfigure

Ponowna konfiguracja może chwilę potrwać.

Po zakończeniu rekonfiguracji wszyscy użytkownicy będą zmuszeni do korzystania z protokołu HTTPS podczas uzyskiwania dostępu do witryny GitLab.

Uwaga: po zmianie z HTTP na HTTPS, starsze pliki cookie mogą powodować błąd GitLab 422. Wyczyszczenie plików cookie rozwiązuje ten problem.



Leave a Comment

Skonfiguruj udział NFS na Debianie

Skonfiguruj udział NFS na Debianie

NFS to oparty na sieci system plików, który umożliwia komputerom dostęp do plików w sieci komputerowej. Ten przewodnik wyjaśnia, w jaki sposób możesz udostępniać foldery w NF

Jak zaktualizować CentOS 7, Ubuntu 16.04 i Debian 8

Jak zaktualizować CentOS 7, Ubuntu 16.04 i Debian 8

Podczas konfigurowania nowego serwera Linux zaleca się aktualizację jądra systemu i innych pakietów do najnowszej stabilnej wersji. W tym artykule

Korzystanie z widoków MySQL w Debianie 7

Korzystanie z widoków MySQL w Debianie 7

Wprowadzenie MySQL ma świetną funkcję znaną jako widoki. Widoki są przechowywane zapytania. Pomyśl o nich jako o aliasie dla długiego zapytania. W tym przewodniku

Konfigurowanie chroota w Debianie

Konfigurowanie chroota w Debianie

W tym artykule dowiesz się, jak skonfigurować więzienie chroot w Debianie. Zakładam, że używasz Debiana 7.x. Jeśli używasz Debiana 6 lub 8, może to działać, bu

Jak zainstalować PiVPN na Debianie

Jak zainstalować PiVPN na Debianie

Wprowadzenie Prostym sposobem na skonfigurowanie serwera VPN na Debianie jest PiVPN. PiVPN to instalator i opakowanie dla OpenVPN. Tworzy proste polecenia dla ciebie

Jak budować Brotli ze źródła na Debianie 9

Jak budować Brotli ze źródła na Debianie 9

Używasz innego systemu? Brotli to nowa metoda kompresji z lepszym współczynnikiem kompresji niż Gzip. Jego kod źródłowy jest publicznie hostowany na Github. Cześć

Zainstaluj Lynis na Debianie 8

Zainstaluj Lynis na Debianie 8

Wprowadzenie Lynis to bezpłatne narzędzie do kontroli systemu typu open source, które jest używane przez wielu administratorów systemu do sprawdzania integralności i ulepszania systemów. ja

Jak zainstalować BlogoText CMS na Debian 9 LAMP VPS

Jak zainstalować BlogoText CMS na Debian 9 LAMP VPS

Używasz innego systemu? BlogoText CMS to prosty i lekki, bezpłatny i otwarty system zarządzania treścią (CMS) oraz minimalistyczny silnik blogów

Jak zainstalować InvoicePlane na Debianie 9

Jak zainstalować InvoicePlane na Debianie 9

Używasz innego systemu? InvoicePlane to darmowa i otwarta aplikacja do fakturowania. Jego kod źródłowy można znaleźć w tym repozytorium Github. Ten przewodnik

Jak zainstalować Backdrop CMS 1.8.0 na Debian 9 LAMP VPS

Jak zainstalować Backdrop CMS 1.8.0 na Debian 9 LAMP VPS

Używasz innego systemu? Tło CMS 1.8.0 to prosty i elastyczny, przyjazny dla urządzeń mobilnych, bezpłatny i otwarty system zarządzania treścią (CMS), który pozwala nam

Zainstaluj Plesk na Debianie 7 (Wheezy)

Zainstaluj Plesk na Debianie 7 (Wheezy)

Używasz innego systemu? Plesk to zastrzeżony panel kontrolny hosta internetowego, który umożliwia użytkownikom administrowanie osobistymi i / lub klienckimi stronami internetowymi, bazami danych

Jak zainstalować BookStack na Debianie 9

Jak zainstalować BookStack na Debianie 9

Używasz innego systemu? BookStack to prosta, hostowana i łatwa w użyciu platforma do organizowania i przechowywania informacji. BookStack jest w pełni darmowy i otwarty

Jak zainstalować Pagekit 1.0 CMS na Debian 9 LAMP VPS

Jak zainstalować Pagekit 1.0 CMS na Debian 9 LAMP VPS

Używasz innego systemu? Pagekit 1.0 CMS to piękny, modułowy, rozszerzalny i lekki, bezpłatny i otwarty system zarządzania treścią (CMS) z

Jak zainstalować Subrion 4.1 CMS na Debian 9 LAMP VPS

Jak zainstalować Subrion 4.1 CMS na Debian 9 LAMP VPS

Używasz innego systemu? Subrion 4.1 CMS to potężny i elastyczny system zarządzania treścią typu open source (CMS), który zapewnia intuicyjny i przejrzysty kontekst

Instalowanie Sponge i Minecraft Forge na Debianie 9

Instalowanie Sponge i Minecraft Forge na Debianie 9

Używasz innego systemu? Sponge to projekt typu open source, który rozszerza możliwości serwerów Minecraft poprzez wtyczki. W połączeniu z modding AP

Lepsze narzędzia monitorowania dla Ubuntu i CentOS

Lepsze narzędzia monitorowania dla Ubuntu i CentOS

Wprowadzenie Systemy Linux są domyślnie dostarczane z narzędziami do monitorowania, takimi jak top, df i du, które pomagają monitorować procesy i miejsce na dysku. Często jednak są

Skonfiguruj Firefox Sync Server na Debian 9 lub Ubuntu 16.04

Skonfiguruj Firefox Sync Server na Debian 9 lub Ubuntu 16.04

Używasz innego systemu? Firefox Sync to funkcja synchronizacji przeglądarki, która umożliwia udostępnianie danych i preferencji (takich jak zakładki, historia

Jak zainstalować CMS z października 1.0 na Debianie 9 LAMP VPS

Jak zainstalować CMS z października 1.0 na Debianie 9 LAMP VPS

Używasz innego systemu? 1.0 października CMS to prosty i niezawodny, bezpłatny i otwarty system zarządzania treścią (CMS) oparty na platformie Laravel

Jak zainstalować X-Cart 5 na Debianie 10

Jak zainstalować X-Cart 5 na Debianie 10

Używasz innego systemu? X-Cart to niezwykle elastyczna platforma eCommerce typu open source z mnóstwem funkcji i integracji. Kod źródłowy X-Cart jest hostem

Monitoruj status serwera Debian za pomocą Munin

Monitoruj status serwera Debian za pomocą Munin

Munin to narzędzie do monitorowania procesów i zasobów w maszynie oraz prezentuje informacje na wykresach za pośrednictwem interfejsu internetowego. Użyj następujących

Funkcjonalności warstw architektury referencyjnej Big Data

Funkcjonalności warstw architektury referencyjnej Big Data

Przeczytaj blog, aby w najprostszy sposób poznać różne warstwy w architekturze Big Data i ich funkcjonalności.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Chcesz zobaczyć rewolucyjne wynalazki Google i jak te wynalazki zmieniły życie każdego człowieka dzisiaj? Następnie czytaj na blogu, aby zobaczyć wynalazki Google.

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Whatsapp w końcu uruchomił aplikację Desktop dla użytkowników komputerów Mac i Windows. Teraz możesz łatwo uzyskać dostęp do Whatsapp z systemu Windows lub Mac. Dostępne dla Windows 8+ i Mac OS 10.9+

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

Energia jądrowa jest zawsze pogardzana, nigdy jej nie szanujemy z powodu przeszłych wydarzeń, ale nie zawsze jest zła. Przeczytaj post, aby dowiedzieć się więcej na ten temat.

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Koncepcja autonomicznych samochodów, które wyjadą na drogi za pomocą sztucznej inteligencji, to marzenie, które mamy już od jakiegoś czasu. Ale pomimo kilku obietnic nigdzie ich nie widać. Przeczytaj ten blog, aby dowiedzieć się więcej…

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Wzrasta liczba ataków ransomware, ale czy sztuczna inteligencja może pomóc w radzeniu sobie z najnowszym wirusem komputerowym? Czy AI jest odpowiedzią? Przeczytaj tutaj, wiedz, że sztuczna inteligencja jest zmorą lub zgubą

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

Sztuczna inteligencja nie jest dla ludzi nową nazwą. Ponieważ sztuczna inteligencja jest włączona do każdego strumienia, jednym z nich jest opracowywanie narzędzi zwiększających ludzką wydajność i dokładność. Skorzystaj z tych niesamowitych narzędzi uczenia maszynowego i uprość swoje codzienne zadania.

Wgląd w 26 technik analizy Big Data: część 2

Wgląd w 26 technik analizy Big Data: część 2

Zawsze potrzebujemy Big Data Analytics do efektywnego zarządzania danymi. W tym artykule omówiliśmy kilka technik analizy Big Data. Sprawdź ten artykuł.

Ataki DDOS: krótki przegląd

Ataki DDOS: krótki przegląd

Czy jesteś również ofiarą ataków DDOS i nie masz pewności co do metod zapobiegania? Przeczytaj ten artykuł, aby rozwiązać swoje pytania.