Cum se instalează Gitea pe Ubuntu 18.04

Gitea este un sistem alternativ de control al versiunilor open source, self-hosted, alimentat de git. Gitea este scris în Golang și este o soluție ușoară care poate fi găzduită pe orice platformă.

Cerințe preliminare

  • Nouă instanță Vultr Ubuntu 18.04 cu cel puțin 2 nuclee de procesor și 1 GB RAM
  • Utilizator non-root cu privilegii sudo.
  • Nginx
  • git
  • MariaDB

Pasul 1: Instalează Nginx

Actualizați instanța dvs. de server Vultr Ubuntu 18.04.

sudo apt update

Instalați Nginx.

sudo apt -y install nginx

Odată instalat Nginx, testați dacă funcționează sau nu, răsfoind pagina de test nginx din browser. Deschide-ți browserul web și indică-lhttp://example.com

Următoarele comenzi pot fi utilizate pentru a opri, reîncărca, reporni, verifica starea și a activa Nginx.

sudo systemctl stop nginx.service
sudo systemctl start nginx.service
sudo systemctl restart nginx.service
sudo systemctl reload nginx.service
sudo systemctl enable nginx.service

Pasul 2: Instalează Git

Instalați Git.

sudo apt -y install git

Odată instalat, verificați versiunea:

git --version
git version 2.17.1

Pasul 3: Instalează MariaDB Database Server

Gitea acceptă următoarele baze de date

  • MariaDB / MySQL
  • PostgreSQL
  • SQLite
  • TiDB

Pentru acest tutorial vom instala serverul și clientul MariaDB.

sudo apt -y install mariadb-server mariadb-client

După instalarea MariaDB, comenzile de mai jos pot fi folosite pentru a opri, porni, reporni, verifica starea și a-l activa.

sudo systemctl stop mariadb.service
sudo systemctl start mariadb.service
sudo systemctl restart mariadb.service
sudo systemctl status mariadb.service
sudo systemctl enable mariadb.service

După aceea, executați comanda de mai jos pentru a securiza serverul MariaDB creând o parolă rădăcină și interzicând accesul root la distanță.

sudo mysql_secure_installation

Când vi se solicită, răspundeți la întrebările de mai jos urmând ghidul.

Enter current password for root (enter for none): Just press the Enter
Set root password? [Y/n]: Y
New password: Enter password
Re-enter new password: Repeat password
Remove anonymous users? [Y/n]: Y
Disallow root login remotely? [Y/n]: Y
Remove test database and access to it? [Y/n]:  Y
Reload privilege tables now? [Y/n]:  Y

Reporniți MariaDB.

sudo systemctl restart mariadb.service

Pentru a testa dacă MariaDB este instalat, tastați comanda de mai jos pentru a vă conecta la serverul MariaDB

sudo mysql -u root -p

Apoi tastați parola creată mai sus pentru a vă autentifica. Veți vedea mesajul de bun venit MariaDB.

Creați o bază de date numită gitea.

CREATE DATABASE gitea;

Creați un utilizator de bază de date apelat giteausercu o nouă parolă.

CREATE USER 'giteauser'@'localhost' IDENTIFIED BY 'new_password_here';

Apoi acordați utilizatorului acces complet la baza de date.

GRANT ALL ON gitea.* TO 'giteauser'@'localhost' IDENTIFIED BY 'user_password_here' WITH GRANT OPTION;

În cele din urmă, salvați-vă modificările și ieșiți.

FLUSH PRIVILEGES;
EXIT;

Pasul 4: Pregătiți mediul Gitea

Creați un utilizator pentru a rula Gitea.

sudo adduser \
   --system \
   --shell /bin/bash \
   --gecos 'Git Version Control' \
   --group \
   --disabled-password \
   --home /home/git \
   git

Creați structura de director necesară.

sudo mkdir -p /var/lib/gitea/{custom,data,indexers,public,log}
sudo chown git:git /var/lib/gitea/{data,indexers,log}
sudo chmod 750 /var/lib/gitea/{data,indexers,log}
sudo mkdir /etc/gitea
sudo chown root:git /etc/gitea
sudo chmod 770 /etc/gitea

Pasul 5: Instalează Gitea

Binarul Gitea poate fi descărcat executând următoarele comenzi.

sudo wget -O gitea https://dl.gitea.io/gitea/1.5.0/gitea-1.5.0-linux-amd64 
sudo chmod +x gitea

Copiați binarul într-o locație globală.

sudo cp gitea /usr/local/bin/gitea

Pasul 6: Creați un fișier de service pentru a porni automat Gitea

Creați un fișier de servicii linux.

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

Populați fișierul cu următoarele.

[Unit]
Description=Gitea (Git with a cup of tea)
After=syslog.target
After=network.target
#After=mysqld.service
#After=postgresql.service
#After=memcached.service
#After=redis.service

[Service]
# Modify these two values and uncomment them if you have
# repos with lots of files and get an HTTP error 500 because
# of that
###
#LimitMEMLOCK=infinity
#LimitNOFILE=65535
RestartSec=2s
Type=simple
User=git
Group=git
WorkingDirectory=/var/lib/gitea/
ExecStart=/usr/local/bin/gitea web -c /etc/gitea/app.ini
Restart=always
Environment=USER=git HOME=/home/git GITEA_WORK_DIR=/var/lib/gitea
# If you want to bind Gitea to a port below 1024 uncomment
# the two values below
###
#CapabilityBoundingSet=CAP_NET_BIND_SERVICE
#AmbientCapabilities=CAP_NET_BIND_SERVICE

[Install]
WantedBy=multi-user.target

Activați și porniți Gitea la pornire.

sudo systemctl daemon-reload
sudo systemctl enable gitea
sudo systemctl start gitea

Executați comanda de stare.

sudo systemctl status gitea

● gitea.service - Gitea (Git with a cup of tea)
  Loaded: loaded (/etc/systemd/system/gitea.service; enabled; vendor preset: en
  Active: active (running) since Wed 2018-10-10 14:15:28 CDT; 19ms ago
 Main PID: 17769 (gitea)
   Tasks: 4 (limit: 2321)
  CGroup: /system.slice/gitea.service
       ├─17769 /usr/local/bin/gitea web -c /etc/gitea/app.ini
       └─17774 /usr/local/bin/gitea web -c /etc/gitea/app.ini

Pasul 7: Configurați Nginx ca proxy invers

Ștergeți fișierul de configurare implicit nginx.

sudo rm /etc/nginx/sites-enabled/default

Creați o configurație proxy inversă pentru Gitea.

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

Populați fișierul cu următoarea configurație.

upstream gitea {
    server 127.0.0.1:3000;
}

server {
    listen 80 default_server;
    listen [::]:80 default_server;
    server_name example.com;
    root /var/lib/gitea/public;
    access_log off;
    error_log off;

    location / {
      try_files maintain.html $uri $uri/index.html @node;
    }

    location @node {
      client_max_body_size 0;
      proxy_pass http://localhost:3000;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header Host $http_host;
      proxy_set_header X-Forwarded-Proto $scheme;
      proxy_max_temp_file_size 0;
      proxy_redirect off;
      proxy_read_timeout 120;
    }
}

Activați configurația proxy inversă Gitea Nginx.

sudo ln -s /etc/nginx/sites-available/git /etc/nginx/sites-enabled

Apoi reîncărcați serviciul Nginx.

sudo systemctl reload nginx.service

Apoi, deschideți browserul și navigați la numele de gazdă sau adresa IP a serverului.

http://example.com/install

Urmați instrucțiunile de pe ecran pentru a finaliza configurația Gitea.

Lasă un comentariu

O perspectivă asupra a 26 de tehnici de analiză a datelor mari: partea 1

O perspectivă asupra a 26 de tehnici de analiză a datelor mari: partea 1

O perspectivă asupra a 26 de tehnici de analiză a datelor mari: partea 1

Funcționalitățile straturilor arhitecturii de referință pentru Big Data

Funcționalitățile straturilor arhitecturii de referință pentru Big Data

Citiți blogul pentru a cunoaște diferitele straturi din Arhitectura Big Data și funcționalitățile acestora în cel mai simplu mod.

6 lucruri extrem de nebunești despre Nintendo Switch

6 lucruri extrem de nebunești despre Nintendo Switch

Mulți dintre voi cunoașteți Switch care va fi lansat în martie 2017 și noile sale funcții. Pentru cei care nu știu, am pregătit o listă de funcții care fac din „Switch” un „gadget obligatoriu”.

Promisiuni tehnologice care sunt încă nelivrate

Promisiuni tehnologice care sunt încă nelivrate

Aștepți ca giganții tehnologiei să-și îndeplinească promisiunile? vezi ce a ramas nelivrat.

Cum poate AI să ducă automatizarea proceselor la următorul nivel?

Cum poate AI să ducă automatizarea proceselor la următorul nivel?

Citiți asta pentru a afla cum devine populară inteligența artificială în rândul companiilor la scară mică și cum crește probabilitățile de a le face să crească și de a le oferi concurenților avantaje.

Singularitatea tehnologică: un viitor îndepărtat al civilizației umane?

Singularitatea tehnologică: un viitor îndepărtat al civilizației umane?

Pe măsură ce Știința Evoluează într-un ritm rapid, preluând multe dintre eforturile noastre, crește și riscurile de a ne supune unei Singularități inexplicabile. Citiți, ce ar putea însemna singularitatea pentru noi.

CAPTCHA: Cât timp poate rămâne o tehnică viabilă pentru distincția uman-AI?

CAPTCHA: Cât timp poate rămâne o tehnică viabilă pentru distincția uman-AI?

CAPTCHA a devenit destul de dificil de rezolvat pentru utilizatori în ultimii ani. Va fi capabil să rămână eficient în detectarea spam-ului și a botului în viitor?

Telemedicină și îngrijire medicală la distanță: viitorul este aici

Telemedicină și îngrijire medicală la distanță: viitorul este aici

Ce este telemedicina, îngrijirea medicală la distanță și impactul acesteia asupra generației viitoare? Este un loc bun sau nu în situația de pandemie? Citiți blogul pentru a găsi o vedere!

Te-ai întrebat vreodată cum câștigă hackerii bani?

Te-ai întrebat vreodată cum câștigă hackerii bani?

Poate ați auzit că hackerii câștigă mulți bani, dar v-ați întrebat vreodată cum câștigă acești bani? sa discutam.

Actualizarea suplimentului macOS Catalina 10.15.4 cauzează mai multe probleme decât rezolvă

Actualizarea suplimentului macOS Catalina 10.15.4 cauzează mai multe probleme decât rezolvă

Recent, Apple a lansat macOS Catalina 10.15.4 o actualizare suplimentară pentru a remedia problemele, dar se pare că actualizarea provoacă mai multe probleme care duc la blocarea mașinilor Mac. Citiți acest articol pentru a afla mai multe