Hoe GitLab Community Edition (CE) 11.x op Debian 9 te installeren

Sinds GitHub werd overgenomen door Microsoft, zijn nogal wat ontwikkelaars van plan geweest om hun eigen coderepository's van github.com te migreren naar een alternatieve, zelf-gehoste oplossing. GitLab Community Edition (CE) is de meest gebruikelijke keuze.

Als een geavanceerde en flexibele oplossing kan GitLab CE op verschillende manieren worden ingezet, maar alleen de officieel aanbevolen methode, de installatie van het Omnibus-pakket, wordt hierin behandeld.

Vereisten

  • Een nieuwe Vultr Debian 9 x64-serverinstantie met minimaal 4 GB geheugen. 8 GB of meer wordt aanbevolen voor het bedienen van maximaal 100 gebruikers. Stel dat het IPv4-adres is 203.0.113.1.
  • Een sudo-gebruiker .
  • Een domein gitlab.example.comverwijst naar de bovengenoemde instantie.

Opmerking: als u op uw eigen serverinstantie implementeert, moet u alle voorbeeldwaarden vervangen door echte waarden.

Stap 1: Voer basistaken uit voor het hosten van GitLab CE

Start een SSH-terminal en log in op uw Debian 9 x64-serverinstantie als sudo-gebruiker.

Voeg een swappartitie toe en pas de swappiness-instelling aan

Bij het inzetten van GitLab CE 11.x op een machine met 4 GB geheugen, is het vereist om een ​​swap-partitie van 4 GB in te stellen voor een soepele werking.

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

Opmerking: als u een andere servergrootte gebruikt, kan de grootte van de swappartitie variëren.

Voor systeemprestatiedoeleinden wordt aanbevolen om de swappiness-instelling van de kernel op een lage waarde te configureren, zoals 10:

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

De uitvoer van de catopdracht is 10.

Stel de hostnaam en de volledig gekwalificeerde domeinnaam (FQDN) van de machine in

Gebruik de volgende opdrachten om een ​​hostnaam gitlab, en een FQDN gitlab.example.com, voor de machine in te stellen:

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

U kunt de resultaten bevestigen:

hostname
hostname -f

Stel firewallregels in

Stel redelijke firewallregels in voor het runnen van een website:

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

Alle bovenstaande instellingen worden onmiddellijk van kracht. Gebruik de volgende opdracht om ze ter beoordeling op te sommen:

sudo iptables -L -n

Gebruik de iptable-persistenttool om alle bestaande iptables-regels in een bestand op te slaan /etc/iptables/rules.v4, waardoor alle iptables-regels blijvend zijn:

sudo apt install -y iptables-persistent

Tijdens de installatie wordt u gevraagd of u de huidige IPv4 / IPv6-regels wilt opslaan. Druk ENTERtweemaal om zowel de huidige IPv4- als IPv6-regels op te slaan in /etc/iptables/rules.v4en /etc/iptables/rules.v6.

Als u de IPv4-regels later probeert bij te werken, gebruikt u het volgende om uw update op te slaan:

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

Werk het systeem bij

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

Wanneer het systeem weer actief is, log dan opnieuw in als dezelfde sudo-gebruiker om verder te gaan.

Stap 2: Installeer de vereiste afhankelijkheden

Voordat u GitLab CE installeert, moet u de vereiste afhankelijkheden installeren:

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

Als u Postfix wilt gebruiken om meldingsberichten te verzenden, moet u Postfix installeren:

sudo apt install -y postfix

Tijdens de installatie kan er een configuratiescherm verschijnen:

  1. Druk TABop om de <OK>knop op het eerste scherm te markeren en druk vervolgens op ENTER.
  2. Selecteer Internet Siteen druk op ENTER.
  3. Voer voor het mail nameveld de FQDN van uw server in gitlab.example.comen druk op ENTER.
  4. Als er andere schermen verschijnen, druk dan ENTERop om de standaardinstellingen te accepteren.

Start en schakel de Postfix-service in:

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

Wijzig firewallregels voor 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'

Als Postfix is ​​geïnstalleerd, moet u Postfix configureren door het hoofdconfiguratiebestand te bewerken /etc/postfix/main.cfin overeenstemming met uw daadwerkelijke serverinstellingen.

Opmerking: naast de bovenstaande instructies, moet u een ondersteuningsticket indienen om het standaardblok van Vultr op SMTP-poort 25 te annuleren.

Als je een andere messaging-oplossing wilt gebruiken, sla je de installatie van Postfix over en kies je ervoor om een ​​externe SMTP-server te gebruiken nadat GitLab CE is geïnstalleerd.

Stap 3: Stel de GitLab APT-repo in en installeer vervolgens GitLab CE

Stel de GitLab CE APT-repository in op uw systeem:

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

Installeer vervolgens GitLab CE 11.x:

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

De installatie kan even duren.

Wijs ten slotte uw favoriete webbrowser aan http://gitlab.example.comen voer vervolgens een nieuw wachtwoord in wanneer daarom wordt gevraagd om de installatie te voltooien.

Gebruik vanaf nu de onderstaande gegevens om in te loggen als de beheerder:

  • Gebruikersnaam: root
  • Wachtwoord: <your-new-password>

Stap 4: Schakel HTTPS-toegang in door een Let's Encrypt SSL-certificaat te integreren

Voorlopig heb je GitLab CE 11.x op je serverinstantie geïnstalleerd en kunnen gebruikers de site al bezoeken met behulp van het HTTP-protocol. Om veiligheidsredenen wordt aanbevolen om HTTPS-toegang tot uw GitLab-server in te schakelen door een Let's Encrypt SSL-certificaat te integreren.

Gebruik de vieditor om het GitLab CE-configuratiebestand te openen:

sudo vi /etc/gitlab/gitlab.rb

Zoek de volgende twee regels:

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

Vervang ze dienovereenkomstig:

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

Opslaan en afsluiten:

:wq!

Configureer GitLab CE opnieuw met bijgewerkte instellingen:

sudo gitlab-ctl reconfigure

De herconfiguratie kan even duren.

Nadat de herconfiguratie is voltooid, worden alle gebruikers gedwongen om het HTTPS-protocol te gebruiken bij het openen van de GitLab-site.

Opmerking: na het overschakelen van HTTP naar HTTPS, kunnen verouderde cookies een GitLab 422-fout veroorzaken. Het wissen van cookies lost dit probleem op.



Leave a Comment

Stel NFS Share op Debian in

Stel NFS Share op Debian in

NFS is een netwerkgebaseerd bestandssysteem waarmee computers toegang hebben tot bestanden via een computernetwerk. Deze gids legt uit hoe u mappen via NF kunt weergeven

Couch CMS 2.0 installeren op een Debian 9 LAMP VPS

Couch CMS 2.0 installeren op een Debian 9 LAMP VPS

Gebruikt u een ander systeem? Couch CMS is een eenvoudig en flexibel, gratis en open source Content Management Systeem (CMS) waarmee webdesigners kunnen ontwerpen

Golang 1.8.3 installeren op CentOS 7, Ubuntu 16.04 en Debian 9

Golang 1.8.3 installeren op CentOS 7, Ubuntu 16.04 en Debian 9

Golang is een door Google ontwikkelde programmeertaal. Dankzij zijn veelzijdigheid, eenvoud en betrouwbaarheid is Golang uitgegroeid tot een van de meest bevolkte

Quassel instellen op Debian 9

Quassel instellen op Debian 9

IRC is populair bij ontwikkelaars en gebruikers van open source software. Een van de nadelen van IRC is dat wanneer u niet online bent, u importan kunt missen

Sudo gebruiken op Debian, CentOS en FreeBSD

Sudo gebruiken op Debian, CentOS en FreeBSD

Het gebruik van een sudo-gebruiker om toegang te krijgen tot een server en opdrachten uit te voeren op rootniveau is een veel voorkomende praktijk onder Linux en Unix-systeembeheerder. Het gebruik van een sud

Een Chroot opzetten op Debian

Een Chroot opzetten op Debian

Dit artikel leert u hoe u een chroot-gevangenis op Debian instelt. Ik neem aan dat u Debian 7.x gebruikt. Als u Debian 6 of 8 gebruikt, kan dit werken, bu

Hoe PiVPN op Debian te installeren

Hoe PiVPN op Debian te installeren

Inleiding Een gemakkelijke manier om een ​​VPN-server op Debian in te stellen, is met PiVPN. PiVPN is een installatieprogramma en wrapper voor OpenVPN. Het maakt simpele commandos voor je

Brotli bouwen vanuit de bron op Debian 9

Brotli bouwen vanuit de bron op Debian 9

Gebruikt u een ander systeem? Brotli is een nieuwe compressiemethode met een betere compressieverhouding dan Gzip. De broncode wordt openbaar gehost op Github. Thi

Hoe Neos CMS op Debian 9 te installeren

Hoe Neos CMS op Debian 9 te installeren

Gebruikt u een ander systeem? Neos is een Content Application Platform met een CMS en een applicatieframework als kern. Deze gids laat u zien hoe u kunt installeren

Stel Cacti in op Debian Jessie

Stel Cacti in op Debian Jessie

Introductie Cacti is een open source monitoring- en grafische tool die volledig is gebaseerd op RRD Data. Via Cacti kunt u bijna elk type apparaat volgen

Java 8 en DCEVM installeren op Debian 8 (Jessie)

Java 8 en DCEVM installeren op Debian 8 (Jessie)

Java is een platformonafhankelijke programmeertaal / virtuele machine. In deze tutorial installeren we de OpenJDK-implementatie van Java 8 op een Debian

Een netwerk van Minecraft-servers maken met BungeeCord op Debian 8, Debian 9 of CentOS 7

Een netwerk van Minecraft-servers maken met BungeeCord op Debian 8, Debian 9 of CentOS 7

Wat je nodig hebt Een Vultr VPS met minimaal 1 GB RAM. SSH-toegang (met root- / beheerdersrechten). Stap 1: BungeeCord installeren Eerste dingen eerst

Hoe TermRecord op Ubuntu 16.04 en Debian 9 te installeren

Hoe TermRecord op Ubuntu 16.04 en Debian 9 te installeren

Gebruikt u een ander systeem? TermRecord is een eenvoudige open source-tool geschreven in Python, waarmee terminalsessies kunnen worden opgeslagen op een gemakkelijk te delen, zelfvoorzienende site

Matomo Analytics op Debian installeren 9

Matomo Analytics op Debian installeren 9

Gebruikt u een ander systeem? Matomo (voorheen Piwik) is een open source analyseplatform, een open alternatief voor Google Analytics. Matomo source wordt gehost o

Monitor Debian Server Status met Munin

Monitor Debian Server Status met Munin

Munin is een monitoringtool om processen en bronnen in uw machine te onderzoeken en presenteert de informatie in grafieken via een webinterface. Gebruik de followin

Hoe ImpressPages CMS 5.0 op een Debian 9 LAMP VPS te installeren

Hoe ImpressPages CMS 5.0 op een Debian 9 LAMP VPS te installeren

Gebruikt u een ander systeem? ImpressPages CMS 5.0 is een eenvoudig en effectief, gratis en open source, gebruiksvriendelijk, op MVC gebaseerd Content Management Systeem (CMS)

Samba instellen met blokopslag op Debian 9

Samba instellen met blokopslag op Debian 9

Samba is een open source-oplossing waarmee gebruikers snelle en veilige bestands- en printshares kunnen instellen. In dit artikel zal ik bespreken hoe je Samba wit kunt instellen

IP-adresbereik toevoegen aan uw server (CentOS / Ubuntu / Debian)

IP-adresbereik toevoegen aan uw server (CentOS / Ubuntu / Debian)

Inleiding In deze zelfstudie behandelen we het proces van het toevoegen van een volledig IP-bereik / subnet aan een Linux-server met CentOS, Debian of Ubuntu. Het proces

Ansible installeren en configureren op Debian 9 voor gebruik met Windows Server

Ansible installeren en configureren op Debian 9 voor gebruik met Windows Server

Gebruikt u een ander systeem? Ansible is een open source-tool voor het automatiseren van taken. Het beheert de configuratie van uw Linux- en Windows-servers. Het werk

Ghost v0.11 LTS implementeren op Debian 8

Ghost v0.11 LTS implementeren op Debian 8

Gebruikt u een ander systeem? Ghost is een open source blogplatform dat sinds zijn populariteit aan populariteit wint onder ontwikkelaars en gewone gebruikers

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Ransomware-aanvallen nemen toe, maar kan AI helpen het nieuwste computervirus het hoofd te bieden? Is AI het antwoord? Lees hier weten is AI boezem of vloek

ReactOS: is dit de toekomst van Windows?

ReactOS: is dit de toekomst van Windows?

ReactOS, een open source en gratis besturingssysteem is hier met de nieuwste versie. Kan het voldoen aan de behoeften van moderne Windows-gebruikers en Microsoft uitschakelen? Laten we meer te weten komen over deze oude stijl, maar een nieuwere OS-ervaring.

Blijf verbonden via WhatsApp Desktop-app 24 * 7

Blijf verbonden via WhatsApp Desktop-app 24 * 7

WhatsApp heeft eindelijk de Desktop-app voor Mac- en Windows-gebruikers gelanceerd. Nu heb je eenvoudig toegang tot WhatsApp vanuit Windows of Mac. Beschikbaar voor Windows 8+ en Mac OS 10.9+

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Lees dit om te weten hoe kunstmatige intelligentie populair wordt onder de kleinschalige bedrijven en hoe het de kansen vergroot om ze te laten groeien en hun concurrenten voorsprong te geven.

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

Onlangs heeft Apple macOS Catalina 10.15.4 uitgebracht, een aanvullende update om problemen op te lossen, maar het lijkt erop dat de update meer problemen veroorzaakt die ertoe leiden dat mac-machines worden gemetseld. Lees dit artikel voor meer informatie

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

Wat is een logboekbestandssysteem en hoe werkt het?

Wat is een logboekbestandssysteem en hoe werkt het?

Onze computer slaat alle gegevens op een georganiseerde manier op, het zogenaamde Journaling-bestandssysteem. Het is een efficiënte methode waarmee de computer bestanden kan zoeken en weergeven zodra u op zoeken drukt.https://wethegeek.com/?p=94116&preview=true

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Naarmate de wetenschap zich snel ontwikkelt en veel van onze inspanningen overneemt, nemen ook de risico's toe om onszelf te onderwerpen aan een onverklaarbare singulariteit. Lees, wat singulariteit voor ons kan betekenen.

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

AI in de zorg heeft de afgelopen decennia grote sprongen gemaakt. De toekomst van AI in de gezondheidszorg groeit dus nog steeds met de dag.