Com instal·lar GitBucket a Ubuntu 16.04

Aquesta guia cobreix la instal·lació i la configuració bàsiques de GitBucket per a una instància Vultr que executa Ubuntu 16.04 i suposa que esteu executant ordres com a non-rootusuari.

Requisits previs

  • Una instància del servidor Vultr amb almenys 1 GB de RAM (les instàncies més petites poden funcionar, encara que lentament).
  • openjdk-8-jre Obligatori, les versions anteriors no funcionaran.
  • wget S'utilitza per descarregar el paquet GitBucket.
  • nginx Opcional, proporciona un servidor intermediari invers a GitBucket
  • systemd Gestiona l'inici i l'aturada del procés GitBucket

Instal·lació de requisits previs

GitBucket requereix que Java 8 o més recent estigui instal·lat al vostre servidor. Si encara no heu instal·lat Java 8, primer actualitzeu les llistes de paquets locals.

sudo apt update

A continuació, instal·leu el paquet de temps d'execució de Java 8.

sudo apt install openjdk-8-jre

Instal·lant GitBucket

Creació d'un usuari sense privilegis

Haurem de crear un usuari sense privilegis per executar GitBucket abans d'anar més lluny. L'execució de GitBucket amb un usuari sense privilegis restringeix la nostra instal·lació d'escriure fora del seu propi directori de dades, reforçant la seguretat del vostre servidor. Executeu l'ordre següent per crear un usuari del sistema anomenat gitbucket.

sudo adduser --system gitbucket

Com que hem creat un usuari del sistema , l'intèrpret d'ordres per defecte és /bin/false, i tornarem a l'intèrpret d'ordres actual tret que proporcionem un argument d'intèrpret d'ordres addicional quan executem su. Inicieu sessió amb l'usuari acabat de crear.

sudo su - gitbucket -s /bin/bash

L'indicador de l'intèrpret d'ordres hauria de canviar i iniciareu sessió al nou usuari del sistema.

Descàrrega/Actualització de GitBucket

Navegueu a la pàgina de versions de GitBucket i localitzeu la darrera versió disponible. Copieu l'URL del gitbucket.warpaquet, comproveu que esteu al directori inicial del nou usuari i descarregueu-lo amb wget.

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

Haureu de repetir aquest pas cada vegada que vulgueu actualitzar el paquet GitBucket.

Configuració inicial de GitBucket

Un cop descarregat el paquet, haurem d'iniciar GitBucket manualment per realitzar una configuració inicial.

java -jar gitbucket.war --port 8080

Si el port 8080ja l'ha pres un altre procés, podeu canviar el port que GitBucket escoltarà ara. Aquesta guia suposa que GitBucket està escoltant al port8080 .

Això iniciarà GitBucket a la interfície de xarxa pública del vostre servidor, escoltant al port especificat. Hauríeu de veure, al cap d'uns moments, el següent missatge.

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

Si utilitzeu el tallafoc de Vultr , haureu d'obrir el port que escolta GitBucket, ja que el tallafoc de Vultr funciona com una llista blanca, rebutjant el trànsit per permetre ports tret que s'especifiqui el contrari.

La vostra instal·lació de GitBucket ara hauria d'estar en línia i accessible des d'Internet. Utilitzant un navegador web, connecteu-vos a l'adreça pública del vostre servidor (assegureu-vos d'especificar el port on s'executa GitBucket, (és a dir, http://203.0.113.0:8080o http://example.com:8080), i arribareu a la pàgina d'inici de GitBucket.

Tanmateix, cal canviar la contrasenya del compte d'administrador predeterminat. Per fer-ho, inicieu sessió al compte d'administrador mitjançant el Sign inbotó de la part superior dreta de la interfície web. L'inici de sessió predeterminat per al compte d'administrador és rootper al nom d'usuari i, després, de rootnou per a la contrasenya. Un cop iniciat sessió, el botó es substituirà per una icona de perfil i un desplegable. Amplieu el menú desplegable i seleccioneu i Account Settings, a continuació, establiu una contrasenya nova i més segura a l'assistent de configuració del compte.

Després d'haver actualitzat les credencials del compte d'administrador predeterminat i verificat que GitBucket s'inicia amb aquesta configuració mínima, mateu el procés Java amb " CTRL+C" i tanqueu l'intèrpret d'ordres actual amb exit.

Creació del servei Systemd

Actualment, només podem executar GitBucket accedint al nostre servidor mitjançant SSH i iniciant el procés des d'un shell manualment. Afortunadament, Ubuntu ve preempaquetat amb Systemd, la qual cosa ens permet crear un servei amb el qual GitBucket s'iniciarà i mantindrà automàticament el sistema.

Amb nano, creeu un fitxer d'unitat nou al /etc/systemd/systemdirectori.

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

A continuació, copieu el contingut següent al fitxer.

[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

Aquest fitxer d'unitat defineix el comportament bàsic d'inici i tancament de GitBucket i executa el servei sota el nostre usuari del sistema sense privilegis a la interfície de xarxa només local.

Si heu canviat el número de port que escoltarà GitBucket, canvieu l' --portargument de l' ExecStartordre.

Deseu (" CTRL+O") el nou fitxer de la unitat i, a continuació, sortiu de l'editor (" CTRL+X"). Haureu de tornar a carregar Systemd perquè es descobreixi el nou fitxer de la unitat.

sudo systemctl daemon-reload

Després que Systemd s'hagi tornat a carregar, verifiqueu que la nova unitat s'ha descobert i carregat.

sudo systemctl status gitbucket

Hauríeu de veure la següent sortida.

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

Finalment, habiliteu que la nova unitat s'iniciï automàticament quan s'iniciï el vostre servidor i, a continuació, inicieu el servei per primera vegada.

sudo systemctl enable gitbucket
sudo systemctl start gitbucket

Un cop iniciat el servei, podreu tornar a accedir a GitBucket des del vostre navegador mitjançant l'adreça IP i el número de port.

Configuració del servidor intermediari invers Nginx

Tot i que es pot exposar GitBucket directament a través del port 8080, podeu millorar el rendiment i configurar funcions com ara HTTP/2, xifratge TLS i regles de memòria cau exposant GitBucket a través de Nginx.

Configuració inicial de Nginx

Si encara no heu instal·lat Nginx, actualitzeu les llistes de paquets.

sudo apt update

A continuació, instal·leu el paquet Nginx.

sudo apt install nginx

Un cop instal·lat Nginx, verifiqueu que podeu accedir al servidor web mitjançant l'adreça IP del vostre servidor sense el número de port (és a dir, http://203.0.113.0o http://example.com). Si té èxit, veureu la pàgina de destinació predeterminada de Nginx per a Ubuntu.

Creació del proxy invers

Copiarem la configuració del lloc predeterminada /etc/nginx/sites-availablecom a punt de partida per al servidor intermediari invers.

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

Obriu el fitxer de configuració acabat de crear amb nano.

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

Localitzeu el location /bloc existent a la línia 43.

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

Actualment, Nginx intentarà retornar fitxers situats en els /var/www/htmlquals coincideixin amb les HTTPsol·licituds entrants . Haurem de canviar aquest comportament configurant un servidor intermediari invers en aquest bloc, que enviarà totes les sol·licituds HTTP fetes al nostre servidor Nginx a la instància de GitBucket. Actualitzeu el location /bloc perquè coincideixi amb el següent.

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;
}

Si heu canviat el número de port on escoltarà GitBucket, actualitzeu l' proxy_passopció per reflectir-ho.

Per habilitar la nostra nova configuració, haureu de desactivar la configuració predeterminada existent a /etc/nginx/sites-enabled, i després enllaçar simbòlicament la nostra nova configuració a /etc/nginx/sites-enabledtravés del següent.

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

Un cop habilitat el fitxer de configuració, comproveu si hi ha errors de sintaxi.

sudo nginx -t

A continuació, reinicieu el servidor Nginx per habilitar la nostra nova configuració del lloc.

sudo systemctl restart nginx

Ara hauríeu de poder accedir a la vostra instal·lació de GitBucket a l'adreça pública del vostre servidor sense un número de port.

Assegurar el procés GitBucket des d'Internet pública

Actualment, la nostra instància de GitBucket està escoltant a la interfície de xarxa pública del nostre servidor . Això permetrà als usuaris evitar el servidor intermediari Nginx connectant-se a l'adreça que GitBucket està escoltant actualment, cosa que probablement no és desitjada. Haurem de modificar el fitxer de la unitat que hem creat anteriorment per resoldre-ho. Obriu el fitxer de la unitat amb nano.

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

Afegiu --host 127.0.0.1a l' ExecStartordre, així.

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

Això farà que GitBucket només accepti connexions a la interfície de xarxa local del nostre servidor. Una vegada més, deseu (" CTRL+O") el fitxer, tanqueu (" CTRL+X") l'editor, torneu a carregar Systemd i reinicieu la nostra unitat GitBucket.

sudo systemctl daemon-reload
sudo systemctl restart gitbucket

Si utilitzeu el tallafoc de Vultr, també hauríeu d'eliminar qualsevol regla de port que hàgiu afegit per accedir al servidor GitBucket durant la configuració inicial.


Leave a Comment

Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Introducció Lets Encrypt és un servei d'autoritat de certificació que ofereix certificats TLS/SSL gratuïts. El procés d'instal·lació està simplificat per Certbot,

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Utilitzeu un sistema diferent? Què és Tekkit Classic? Tekkit Classic és un modpack per al joc que tothom coneix i estima; Minecraft. Conté algunes de la ver

Creació dun bloc Jekyll a Ubuntu 16.04

Creació dun bloc Jekyll a Ubuntu 16.04

Utilitzeu un sistema diferent? Jekyll és una gran alternativa a WordPress per crear blocs o compartir contingut. No requereix cap base de dades i és molt fàcil

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Utilitzeu un sistema diferent? Si compres un servidor Debian, sempre hauríeu de tenir els darrers pedaços i actualitzacions de seguretat, tant si esteu adormit com si no.

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

PHP i els paquets relacionats són els components més utilitzats quan es desplega un servidor web. En aquest article, aprendrem a configurar PHP 7.0 o PHP 7.1 o

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Tres panells de control de servidor gratuïts (instal·lació ràpida)

Tres panells de control de servidor gratuïts (instal·lació ràpida)

1. Virtualmin/Webmin Virtualmin és un tauler de control d'allotjament web potent i flexible per a sistemes Linux i UNIX basat en la coneguda base web de codi obert

Configuració duna aplicació Yii a Ubuntu 14.04

Configuració duna aplicació Yii a Ubuntu 14.04

Yii és un framework PHP que permet desenvolupar aplicacions de manera més ràpida i senzilla. Instal·lar Yii a Ubuntu és senzill, ja que aprendràs exactament

Ús de Screen a Ubuntu 14.04

Ús de Screen a Ubuntu 14.04

Screen és una aplicació que permet l'ús múltiple de sessions de terminal dins d'una finestra. Això us permet simular diverses finestres de terminal on es fa

Configura el teu propi servidor DNS a Debian/Ubuntu

Configura el teu propi servidor DNS a Debian/Ubuntu

Aquest tutorial explica com configurar un servidor DNS amb Bind9 a Debian o Ubuntu. Al llarg de l'article, substituïu el vostre-nom-domini.com en conseqüència. Al th

Ús de Logrotate per gestionar fitxers de registre

Ús de Logrotate per gestionar fitxers de registre

Introducció Logrotate és una utilitat Linux que simplifica l'administració dels fitxers de registre. Normalment s'executa un cop al dia mitjançant un treball cron i gestiona la base de registres

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Configura Red5 Media Server a Ubuntu 16.04

Configura Red5 Media Server a Ubuntu 16.04

Utilitzeu un sistema diferent? Red5 és un servidor multimèdia de codi obert implementat a Java que us permet executar aplicacions Flash multiusuari com ara la transmissió en directe.

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

En aquest article, veurem com compilar i instal·lar la línia principal de Nginx des de les fonts oficials de Nginx amb el mòdul PageSpeed, que us permet

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Vanilla Forum a Ubuntu 16.04

Com instal·lar Vanilla Forum a Ubuntu 16.04

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació