Ako nainštalovať GitBucket na Ubuntu 16.04

Táto príručka pokrýva základnú inštaláciu a nastavenie GitBucket pre inštanciu Vultr so systémom Ubuntu 16.04 a predpokladá, že príkazy vykonávate ako non-rootpoužívateľ.

Predpoklady

  • Inštancia servera Vultr s aspoň 1 GB pamäte RAM (menšie inštancie môžu fungovať, aj keď pomaly).
  • openjdk-8-jre Povinné, staršie verzie nebudú fungovať.
  • wget Používa sa na stiahnutie balíka GitBucket.
  • nginx Voliteľné poskytuje reverzný proxy server GitBucket
  • systemd Spravuje spustenie a zastavenie procesu GitBucket

Predpoklady inštalácie

GitBucket vyžaduje, aby bola na vašom serveri nainštalovaná Java 8 alebo novšia. Ak ste ešte nenainštalovali Java 8, najprv aktualizujte zoznam lokálnych balíkov.

sudo apt update

Potom nainštalujte balík Java 8 runtime.

sudo apt install openjdk-8-jre

Inštalácia GitBucket

Vytvorenie neprivilegovaného používateľa

Skôr ako budeme pokračovať, budeme musieť vytvoriť neprivilegovaného používateľa, ktorý bude spúšťať GitBucket. Spustenie GitBucket pod neprivilegovaným používateľom obmedzuje našu inštaláciu v zapisovaní mimo jej vlastného adresára údajov, čím sa posilňuje bezpečnosť vášho servera. Spustite nasledujúci príkaz na vytvorenie systémového užívateľa s názvom gitbucket.

sudo adduser --system gitbucket

Pretože sme vytvorili systémového užívateľa, predvolený shell je /bin/false, a ak pri spustení nezadáme ďalší argument shellu , vrátime sa späť do nášho aktuálneho shellu su. Prihláste sa k novovytvorenému používateľovi.

sudo su - gitbucket -s /bin/bash

Výzva vášho shellu by sa mala zmeniť a budete prihlásený do nového systémového používateľa.

Sťahovanie/aktualizácia GitBucket

Prejdite na stránku vydaní GitBucket a nájdite najnovšiu dostupnú verziu. Skopírujte adresu URL gitbucket.warbalíka, skontrolujte, či ste v domovskom adresári nového používateľa, a stiahnite si ho pomocou wget.

cd ~/
wget https://github.com/gitbucket/gitbucket/releases/download/4.18.0/gitbucket.war

Tento krok budete musieť zopakovať zakaždým, keď budete chcieť aktualizovať balík GitBucket.

Počiatočná konfigurácia GitBucket

Po stiahnutí balíka budeme musieť manuálne spustiť GitBucket, aby sme vykonali počiatočnú konfiguráciu.

java -jar gitbucket.war --port 8080

Ak je port 8080už obsadený iným procesom, môžete zmeniť port, na ktorom bude GitBucket počúvať. Táto príručka predpokladá, že GitBucket počúva na porte8080 .

Toto spustí GitBucket na verejnom sieťovom rozhraní vášho servera a bude počúvať na zadanom porte. Po chvíli by ste mali vidieť nasledujúcu správu.

INFO:oejs.Server:main: Started @15891ms

Ak používate bránu firewall spoločnosti Vultr , budete musieť otvoriť port, na ktorom GitBucket počúva, pretože brána firewall Vultr funguje ako biely zoznam a odmieta prenos, aby povolil porty, pokiaľ nie je uvedené inak.

Vaša inštalácia GitBucket by teraz mala byť online a prístupná z internetu. Pomocou webového prehliadača sa pripojte k verejnej adrese vášho servera (uistite sa, že zadáte port, na ktorom GitBucket beží, (tj http://203.0.113.0:8080alebo http://example.com:8080), a dostanete sa na domovskú stránku GitBucket.

Je však potrebné zmeniť heslo predvoleného účtu správcu. Ak to chcete urobiť, prihláste sa do účtu správcu pomocou Sign intlačidla v pravej hornej časti webového rozhrania. Predvolené prihlásenie pre účet správcu je rootpre meno používateľa a potom rootznova pre heslo. Po prihlásení sa tlačidlo nahradí ikonou profilu a rozbaľovacím zoznamom. Rozbaľte rozbaľovaciu ponuku a vyberte položku Account Settingsa potom nastavte nové, bezpečnejšie heslo v sprievodcovi nastavením účtu.

Po aktualizácii prihlasovacích údajov predvoleného administrátorského účtu a overení, že GitBucket sa spúšťa v tejto minimálnej konfigurácii, ukončite proces Java pomocou " CTRL+C" a zatvorte aktuálny shell pomocou exit.

Vytvorenie služby Systemd

V súčasnosti môžeme GitBucket spustiť iba tak, že pristúpime na náš server cez SSH a spustíme proces manuálne z prostredia shell. Našťastie je Ubuntu predbalené s Systemd, čo nám umožňuje vytvoriť službu, pomocou ktorej bude GitBucket automaticky spustený a spravovaný systémom.

Pomocou nano, vytvorte nový súbor jednotky v /etc/systemd/systemadresári.

sudo nano /etc/systemd/system/gitbucket.service

Potom skopírujte nasledujúci obsah do súboru.

[Unit]
Description=GitBucket
After=network.target
[Service]
ExecStart=/usr/bin/java -jar /home/gitbucket/gitbucket.war --port 8080
ExecStop=/bin/kill -SIGINT $MAINPID
Type=simple
User=gitbucket
[Install]
WantedBy=multi-user.target

Tento súbor jednotky definuje základné správanie pri spúšťaní a vypínaní pre GitBucket a spúšťa službu pod naším neprivilegovaným používateľom systému na lokálnom sieťovom rozhraní.

Ak ste zmenili číslo portu, na ktorom bude GitBucket počúvať, zmeňte --portargument ExecStartpríkazu.

Uložte (" CTRL+O") nový súbor jednotky a potom ukončite editor (" CTRL+X"). Na objavenie nového súboru jednotky budete musieť znova načítať Systemd.

sudo systemctl daemon-reload

Po opätovnom načítaní systému Systemd skontrolujte, či bola nová jednotka objavená a načítaná.

sudo systemctl status gitbucket

Mali by ste vidieť nasledujúci výstup.

gitbucket.service - GitBucket
   Loaded: loaded (/etc/systemd/system/gitbucket.service; disabled; vendor preset: enabled)
   Active: inactive (dead)

Nakoniec povoľte automatické spustenie novej jednotky pri spustení servera a potom prvýkrát spustite službu.

sudo systemctl enable gitbucket
sudo systemctl start gitbucket

Po spustení služby budete môcť znova pristupovať k GitBucket z vášho prehliadača pomocou adresy IP a čísla portu.

Konfigurácia reverzného proxy servera Nginx

Aj keď je možné sprístupniť GitBucket priamo cez port 8080, môžete zlepšiť výkon a nakonfigurovať funkcie, ako sú HTTP/2, šifrovanie TLS a pravidlá ukladania do vyrovnávacej pamäte, a to odhalením GitBucket cez Nginx.

Počiatočné nastavenie Nginx

Ak ste ešte nenainštalovali Nginx, aktualizujte zoznamy balíkov.

sudo apt update

Potom nainštalujte balík Nginx.

sudo apt install nginx

Po nainštalovaní Nginx skontrolujte, či máte prístup k webovému serveru cez IP adresu vášho servera bez čísla portu (napr. http://203.0.113.0alebo http://example.com). Ak bude úspešný, uvidíte predvolenú vstupnú stránku Nginx pre Ubuntu.

Vytvorenie reverzného proxy

Skopírujeme predvolenú konfiguráciu lokality /etc/nginx/sites-availableako východiskový bod pre reverzný proxy server.

sudo cp /etc/nginx/sites-available/default /etc/nginx/sites-available/gitbucket

Otvorte novovytvorený konfiguračný súbor pomocou nano.

sudo nano /etc/nginx/sites-available/gitbucket

Nájdite existujúci location /blok na linke 43.

location / {
  # First attempt to serve request as file, then
  # as directory, then fall back to displaying a 404.
  try_files $uri $uri/ =404;
}

V súčasnosti sa Nginx pokúsi vrátiť súbory, /var/www/htmlktoré sa zhodujú s prichádzajúcimi HTTPpožiadavkami. Toto správanie budeme musieť zmeniť konfiguráciou reverzného proxy v tomto bloku, ktorý bude namiesto toho posielať všetky HTTP požiadavky na náš server Nginx do inštancie GitBucket. Aktualizujte location /blok, aby sa zhodoval s nasledujúcim.

location / {
    proxy_pass              http://localhost:8080; # The address GitBucket is listening on
    proxy_set_header        Host $host;
    proxy_set_header        X-Real-IP $remote_addr;
    proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_connect_timeout   150;
    proxy_send_timeout      100;
    proxy_read_timeout      100;
    proxy_buffers           4 32k;

    client_max_body_size    512m; # Needed for large Git operations over HTTP
    client_body_buffer_size 128k;
}

Ak ste zmenili číslo portu, na ktorom bude GitBucket počúvať, aktualizujte proxy_passmožnosť tak, aby to odrážala.

Ak chcete povoliť našu novú konfiguráciu, budete musieť deaktivovať existujúcu predvolenú konfiguráciu v /etc/nginx/sites-enabled, potom symbolicky prepojiť našu novú konfiguráciu s /etc/nginx/sites-enablednasledujúcim.

sudo rm /etc/nginx/sites-enabled/default
sudo ln -s /etc/nginx/sites-available/gitbucket /etc/nginx/sites-enabled/gitbucket

Po povolení konfiguračného súboru skontrolujte prípadné chyby syntaxe.

sudo nginx -t

Potom reštartujte server Nginx, aby ste povolili našu novú konfiguráciu stránok.

sudo systemctl restart nginx

Teraz by ste mali mať prístup k inštalácii GitBucket na verejnej adrese vášho servera bez čísla portu.

Zabezpečenie procesu GitBucket z verejného internetu

V súčasnosti naša inštancia GitBucket počúva na verejnom sieťovom rozhraní nášho servera . To umožní používateľom obísť server proxy Nginx pripojením k adrese, na ktorej GitBucket momentálne počúva, čo je pravdepodobne nechcené. Aby sme to vyriešili, budeme musieť upraviť súbor jednotky, ktorý sme vytvorili predtým. Otvorte súbor jednotky pomocou nano.

sudo nano /etc/systemd/system/gitbucket.service

Pripojte --host 127.0.0.1k ExecStartpríkazu, podobne.

...
ExecStart=/usr/bin/java -jar /home/gitbucket/gitbucket.war --port 8080 --host 127.0.0.1
...

To spôsobí, že GitBucket bude akceptovať iba pripojenia na lokálnom sieťovom rozhraní nášho servera. Ešte raz uložte (" CTRL+O") súbor, zatvorte (" CTRL+X") editor, znova načítajte Systemd a reštartujte našu jednotku GitBucket.

sudo systemctl daemon-reload
sudo systemctl restart gitbucket

Ak používate bránu Vultr's Firewall, mali by ste tiež odstrániť všetky pravidlá portu, ktoré ste pridali na prístup k serveru GitBucket počas počiatočného nastavenia.


Leave a Comment

Install Plesk on CentOS 7

Install Plesk on CentOS 7

Using a Different System? Plesk is a proprietary web host control panel that allows users to administer their personal and/or clients websites, databases

Install Lets Encrypt SSL on One-Click WordPress App

Install Lets Encrypt SSL on One-Click WordPress App

Introduction Lets Encrypt is a certificate authority service that offers free TLS/SSL certificates. The process of installation is simplified by Certbot,

Ako nastaviť klasický server Tekkit na Ubuntu 16.10

Ako nastaviť klasický server Tekkit na Ubuntu 16.10

Používate iný systém? Čo je Tekkit Classic? Tekkit Classic je modpack pre hru, ktorú každý pozná a miluje; Minecraft. Obsahuje niektoré z ver

Creating a Jekyll Blog on Ubuntu 16.04

Creating a Jekyll Blog on Ubuntu 16.04

Using a Different System? Jekyll is a great alternative to WordPress for blogging or sharing content. It doesnt require any databases and it is very easy i

Ako nastaviť bezobslužné aktualizácie na Debian 9 (Stretch)

Ako nastaviť bezobslužné aktualizácie na Debian 9 (Stretch)

Používate iný systém? Ak si zakúpite server Debian, mali by ste mať vždy najnovšie bezpečnostné záplaty a aktualizácie, či už spíte alebo nie

Ako nainštalovať a nakonfigurovať PHP 7.0 alebo PHP 7.1 na Ubuntu 16.04

Ako nainštalovať a nakonfigurovať PHP 7.0 alebo PHP 7.1 na Ubuntu 16.04

PHP a súvisiace balíky sú najčastejšie používané komponenty pri nasadzovaní webového servera. V tomto článku sa naučíme, ako nastaviť PHP 7.0 alebo PHP 7.1 o

Ako nainštalovať Squid Proxy na CentOS

Ako nainštalovať Squid Proxy na CentOS

Squid je populárny bezplatný linuxový program, ktorý vám umožňuje vytvoriť webový proxy server na presmerovanie. V tejto príručke uvidíte, ako nainštalovať Squid na CentOS, aby vás zmenil

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Úvod Lighttpd je fork Apache, ktorého cieľom je byť oveľa menej náročný na zdroje. Je ľahký, odtiaľ jeho názov, a jeho použitie je celkom jednoduché. Installin

Tri bezplatné ovládacie panely servera (rýchla inštalácia)

Tri bezplatné ovládacie panely servera (rýchla inštalácia)

1. Virtualmin/Webmin Virtualmin je výkonný a flexibilný ovládací panel webhostingu pre systémy Linux a UNIX založený na známej webovej základni Open Source

Nastavenie aplikácie Yii na Ubuntu 14.04

Nastavenie aplikácie Yii na Ubuntu 14.04

Yii je rámec PHP, ktorý vám umožňuje rýchlejšie a jednoduchšie vyvíjať aplikácie. Inštalácia Yii na Ubuntu je jednoduchá, ako sa presne dozviete

Používanie obrazovky na Ubuntu 14.04

Používanie obrazovky na Ubuntu 14.04

Screen je aplikácia, ktorá umožňuje viacnásobné použitie terminálových relácií v rámci jedného okna. To vám umožňuje simulovať viacero okien terminálu, kde je to možné

Nastavte si svoj vlastný DNS server na Debian/Ubuntu

Nastavte si svoj vlastný DNS server na Debian/Ubuntu

Tento tutoriál vysvetľuje, ako nastaviť server DNS pomocou Bind9 na Debiane alebo Ubuntu. V celom článku podľa toho nahraďte názov vašej-domény.com. Pri th

Používanie Logrotate na správu protokolových súborov

Používanie Logrotate na správu protokolových súborov

Úvod Logrotate je nástroj pre Linux, ktorý zjednodušuje správu protokolových súborov. Zvyčajne beží raz denne prostredníctvom úlohy cron a spravuje základňu protokolov

Konfigurácia statickej siete a IPv6 na CentOS 7

Konfigurácia statickej siete a IPv6 na CentOS 7

VULTR nedávno vykonal zmeny na ich konci a všetko by teraz malo fungovať dobre po vybalení so zapnutým NetworkManagerom. Ak chcete deaktivovať

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Icinga2 je výkonný monitorovací systém a pri použití v modeli master-client môže nahradiť potrebu monitorovacích kontrol založených na NRPE. Hlavný klient

Nastavte Red5 Media Server na Ubuntu 16.04

Nastavte Red5 Media Server na Ubuntu 16.04

Používate iný systém? Red5 je mediálny server s otvoreným zdrojom implementovaný v jazyku Java, ktorý vám umožňuje spúšťať aplikácie Flash pre viacerých používateľov, ako napríklad živé vysielanie

Ako nainštalovať Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Ako nainštalovať Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Používate iný systém? Apache Cassandra je bezplatný a otvorený systém správy databáz NoSQL, ktorý je navrhnutý tak, aby poskytoval škálovateľnosť, vysokú

Ako nainštalovať Vanilla Forum na Ubuntu 16.04

Ako nainštalovať Vanilla Forum na Ubuntu 16.04

Používate iný systém? Vanilla forum je open source aplikácia fóra napísaná v PHP. Je plne prispôsobiteľný, ľahko použiteľný a podporuje externé

Ako nainštalovať Kanboard na Ubuntu 18.04 LTS

Ako nainštalovať Kanboard na Ubuntu 18.04 LTS

Používate iný systém? Úvod Kanboard je bezplatný a otvorený softvérový program na riadenie projektov, ktorý je navrhnutý tak, aby uľahčil a vizualizoval

Ako nainštalovať Kanboard na Debian 9

Ako nainštalovať Kanboard na Debian 9

Používate iný systém? Úvod Kanboard je bezplatný a otvorený softvérový program na riadenie projektov, ktorý je navrhnutý tak, aby uľahčil a vizualizoval

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.

Útoky DDOS: Stručný prehľad

Útoky DDOS: Stručný prehľad

Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.

Vývoj ukladania dát – Infografika

Vývoj ukladania dát – Infografika

Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.

Funkcionality vrstiev referenčnej architektúry veľkých dát

Funkcionality vrstiev referenčnej architektúry veľkých dát

Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac