Kako namestiti GitLab Community Edition (CE) 11.x na Debian 9

Odkar je GitHub kupil Microsoft, je kar nekaj razvijalcev načrtovalo selitev lastnih repozitorijev kode z github.com na alternativno rešitev, ki jo gosti sami. GitLab Community Edition (CE) je najpogostejša izbira.

GitLab CE je kot sofisticirano in prilagodljivo rešitev mogoče uvesti z različnimi metodami, vendar bo tukaj zajeta le uradno priporočena metoda, namestitev paketa Omnibus.

Predpogoji

  • Nov primerek strežnika Vultr Debian 9 x64 z vsaj 4 GB pomnilnika. 8 GB ali več je priporočeno za oskrbo do 100 uporabnikov. Recimo, da je njegov naslov IPv4 203.0.113.1.
  • Uporabnik sudo .
  • Domena, gitlab.example.comki je usmerjena na zgoraj omenjeni primer.

Opomba: Pri uvajanju na lastnem primerku strežnika se prepričajte, da ste zamenjali vse vzorčne vrednosti z dejanskimi.

1. korak: Izvedite osnovne naloge za gostovanje GitLab CE

Zaženite terminal SSH in se prijavite v svoj primerek strežnika Debian 9 x64 kot uporabnik sudo.

Dodajte izmenjalno particijo in prilagodite nastavitev zamenjave

Pri uvajanju GitLab CE 11.x na stroju s 4 GB pomnilnika je potrebno nastaviti izmenjalno particijo 4 GB za nemoteno delovanje.

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

Opomba: Če uporabljate drugo velikost strežnika, se lahko velikost izmenjalne particije razlikuje.

Za namene delovanja sistema je priporočljivo, da konfigurirate nastavitev zamenjave jedra na nizko vrednost, kot je 10:

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

Izhod catukaza bo 10.

Nastavite ime gostitelja naprave in popolnoma kvalificirano ime domene (FQDN)

Uporabite naslednje ukaze za nastavitev imena gostitelja gitlab, in FQDN gitlab.example.com, za napravo:

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

Rezultate lahko potrdite:

hostname
hostname -f

Nastavite pravila požarnega zidu

Nastavite razumna pravila požarnega zidu za zagon spletnega mesta:

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

Vse zgornje nastavitve začnejo veljati takoj. Uporabite naslednji ukaz, da jih navedete za pregled:

sudo iptables -L -n

Z iptable-persistentorodjem shranite vsa obstoječa pravila iptables v datoteko /etc/iptables/rules.v4, tako da bodo vsa pravila iptables obstojna:

sudo apt install -y iptables-persistent

Med namestitvijo boste pozvani, ali želite shraniti trenutna pravila IPv4/IPv6. ENTERDvakrat pritisnite, da shranite trenutna pravila IPv4 in IPv6 v /etc/iptables/rules.v4in /etc/iptables/rules.v6.

Če poskušate pozneje posodobiti pravila IPv4, uporabite naslednje, da shranite posodobitev:

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

Posodobite sistem

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

Ko se sistem znova zažene, se znova prijavite kot isti uporabnik sudo, da nadaljujete.

2. korak: Namestite zahtevane odvisnosti

Preden namestite GitLab CE, morate namestiti potrebne odvisnosti:

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

Če želite uporabljati Postfix za pošiljanje obvestil z obvestili, morate namestiti Postfix:

sudo apt install -y postfix

Med namestitvijo se lahko prikaže konfiguracijski zaslon:

  1. Pritisnite, TABda označite <OK>gumb na prvem zaslonu, nato pritisnite ENTER.
  2. Izberite Internet Sitein pritisnite ENTER.
  3. Za mail namepolje vnesite FQDN strežnika gitlab.example.com, in pritisnite ENTER.
  4. Če se prikažejo drugi zasloni, pritisnite , ENTERda sprejmete privzete nastavitve.

Zaženite in omogočite storitev Postfix:

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

Spremenite pravila požarnega zidu za 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'

Ko imate nameščen Postfix, morate konfigurirati Postfix tako, da uredite njegovo glavno konfiguracijsko datoteko /etc/postfix/main.cfv skladu z dejanskimi nastavitvami strežnika.

Opomba: Poleg zgornjih navodil morate predložiti prijavnico za podporo, da prekličete privzeti blok Vultr na vratih SMTP 25.

Če pa želite uporabiti drugo rešitev za sporočanje, preprosto preskočite namestitev Postfixa in se odločite za uporabo zunanjega strežnika SMTP po namestitvi GitLab CE.

3. korak: Nastavite repo GitLab APT in nato namestite GitLab CE

Nastavite repozitorij GitLab CE APT na vašem sistemu:

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

Nato namestite GitLab CE 11.x:

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

Namestitev lahko traja nekaj časa.

Na koncu usmerite svoj najljubši spletni brskalnik na http://gitlab.example.comin nato vnesite novo geslo, kot ste pozvani, da dokončate namestitev.

Od zdaj naprej uporabite spodnje poverilnice za prijavo kot skrbnik:

  • Uporabniško ime: root
  • geslo: <your-new-password>

4. korak: Omogočite dostop HTTPS z integracijo certifikata Let's Encrypt SSL

Za zdaj ste uspešno namestili GitLab CE 11.x na vaš primerek strežnika in uporabniki lahko že obiščejo spletno mesto s protokolom HTTP. Zaradi varnostnih razlogov je priporočljivo omogočiti dostop HTTPS do vašega strežnika GitLab z integracijo certifikata Let's Encrypt SSL.

Uporabite viurejevalnik, da odprete konfiguracijsko datoteko GitLab CE:

sudo vi /etc/gitlab/gitlab.rb

Poiščite naslednji dve vrstici:

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

Ustrezno jih zamenjajte:

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

Shrani in zapusti:

:wq!

Ponovno konfigurirajte GitLab CE z uporabo posodobljenih nastavitev:

sudo gitlab-ctl reconfigure

Ponovna konfiguracija lahko traja nekaj časa.

Ko bo rekonfiguracija opravljena, bodo vsi uporabniki pri dostopu do spletnega mesta GitLab prisiljeni uporabljati protokol HTTPS.

Opomba: Po prehodu s HTTP na HTTPS lahko starejši piškotki povzročijo napako GitLab 422. Brisanje piškotkov odpravlja to težavo.


Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Uporaba drugega sistema? Če kupite strežnik Debian, morate vedno imeti najnovejše varnostne popravke in posodobitve, ne glede na to, ali spite ali ne

Nastavite svoj DNS strežnik na Debian/Ubuntu

Nastavite svoj DNS strežnik na Debian/Ubuntu

Ta vadnica pojasnjuje, kako nastaviti strežnik DNS z uporabo Bind9 v Debianu ali Ubuntuju. V celotnem članku ustrezno nadomestite your-domain-name.com. Ob th

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

V tem članku bomo videli, kako prevesti in namestiti Nginx mainline iz uradnih virov Nginxa z modulom PageSpeed, ki vam omogoča

Kako namestiti Kanboard na Debian 9

Kako namestiti Kanboard na Debian 9

Uporaba drugega sistema? Uvod Kanboard je brezplačen in odprtokodni program za vodenje projektov, ki je zasnovan za olajšanje in vizualizacijo

Kako namestiti Giteo na Debian 9

Kako namestiti Giteo na Debian 9

Uporaba drugega sistema? Gitea je alternativni odprtokodni sistem za nadzor različic, ki ga poganja Git. Gitea je napisana v Golangu in je

Namesti Lynis na Debian 8

Namesti Lynis na Debian 8

Uvod Lynis je brezplačno, odprtokodno orodje za revizijo sistema, ki ga uporabljajo številni sistemski skrbniki za preverjanje integritete in utrjevanje svojih sistemov. jaz

Kako namestiti Thelia 2.3 na Debian 9

Kako namestiti Thelia 2.3 na Debian 9

Uporaba drugega sistema? Thelia je odprtokodno orodje za ustvarjanje spletnih strani e-poslovanja in upravljanje spletnih vsebin, napisanih v PHP. Izvorna koda Thelia i

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Kaj potrebujete Vultr VPS z vsaj 1 GB RAM-a. SSH dostop (z root/administrativnimi pravicami). 1. korak: Namestitev BungeeCord Najprej najprej

Kako namestiti Golang 1.8.3 na CentOS 7, Ubuntu 16.04 in Debian 9

Kako namestiti Golang 1.8.3 na CentOS 7, Ubuntu 16.04 in Debian 9

Golang je programski jezik, ki ga je razvil Google. Zahvaljujoč svoji vsestranskosti, preprostosti in zanesljivosti je Golang postal eden najbolj priljubljenih

Ponastavite korensko geslo MySQL na Debian/Ubuntu

Ponastavite korensko geslo MySQL na Debian/Ubuntu

Če ste pozabili korensko geslo MySQL, ga lahko ponastavite tako, da sledite korakom v tem članku. Postopek je precej preprost in deluje na njih

Nastavitev Counter Strike: Source v Debianu

Nastavitev Counter Strike: Source v Debianu

V tem priročniku bomo postavili strežnik iger Counter Strike: Source na Debian 7. Ti ukazi so bili preizkušeni v Debianu 7, vendar bi morali delovati tudi o

Kako namestiti Unturned 2.2.5 na Debian 8

Kako namestiti Unturned 2.2.5 na Debian 8

V tem priročniku se boste naučili, kako nastaviti strežnik Unturned 2.2.5 na Vultr VPS z Debianom 8. Opomba: To je urejena različica Unturned, ki ne

Kako namestiti Cachet na Debian 8

Kako namestiti Cachet na Debian 8

V tej vadnici se boste naučili, kako namestiti Cachet v Debian 8. Cachet je zmogljiv odprtokodni sistem strani s stanjem. Namestitev Ta vadnica se nadaljuje

Samodejno varnostno kopirajte več baz podatkov MySQL ali MariaDB

Samodejno varnostno kopirajte več baz podatkov MySQL ali MariaDB

Uvod V tem zapisu si oglejte, kako varnostno kopirati več baz podatkov MySQL ali MariaDB, ki se nahajajo na istem računalniku z uporabo bash skripta po meri.

Nastavitev Chroota v Debianu

Nastavitev Chroota v Debianu

Ta članek vas bo naučil, kako nastaviti chroot jail v Debianu. Predvidevam, da uporabljate Debian 7.x. Če uporabljate Debian 6 ali 8, bo to morda delovalo, bu

How to Install Reader Self 3.5 RSS Reader on a Debian 9 LAMP VPS

How to Install Reader Self 3.5 RSS Reader on a Debian 9 LAMP VPS

Using a Different System? Reader Self 3.5 is a simple and flexible, free and open source, self-hosted RSS reader and Google Reader alternative. Reader Sel

Kako namestiti Backdrop CMS 1.8.0 na Debian 9 LAMP VPS

Kako namestiti Backdrop CMS 1.8.0 na Debian 9 LAMP VPS

Uporaba drugega sistema? Backdrop CMS 1.8.0 je preprost in prilagodljiv, mobilnim prijazen, brezplačen in odprtokoden sistem za upravljanje vsebine (CMS), ki nam omogoča

Kako namestiti SteamCMD na vaš VPS

Kako namestiti SteamCMD na vaš VPS

V tej vadnici bomo namestili SteamCMD. SteamCMD lahko uporabite za prenos in namestitev številnih strežnikov za igre Steam, kot je Counter-Strike: Global Offensiv

Nadgradite Python na Debian

Nadgradite Python na Debian

Kot morda veste, se skladišča Debian posodabljajo zelo počasi. V času pisanja sta izdani različici Pythona na 2.7.12 in 3.5.2, vendar v skladišču Debian 8

Kako nastaviti Sambo z blokovnim pomnilnikom v Debianu 9

Kako nastaviti Sambo z blokovnim pomnilnikom v Debianu 9

Samba je odprtokodna rešitev, ki uporabnikom omogoča hitro in varno nastavitev skupne rabe datotek in tiska. V tem članku bom obravnaval, kako nastaviti Samba wit

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več