Preduvjeti
Korak 1: Instalirajte Nginx
Korak 2: Instalirajte Git
Korak 3: Instalirajte MariaDB poslužitelj baze podataka
Korak 4: Pripremite Gitea okruženje
Korak 5: Instalirajte Gitea
Korak 6: Stvorite servisnu datoteku da biste automatski pokrenuli Gitea
Korak 7: Konfigurirajte Nginx kao obrnuti proxy
Gitea je alternativni sustav za kontrolu verzija otvorenog koda s vlastitim hostom koji pokreće Git. Gitea je napisana na Golangu i lako je rješenje za hostiranje na bilo kojoj platformi.
Preduvjeti
- Nova instanca Vultr Debiana 9.
- Ne-root korisnik s
sudoprivilegijama.
- Nginx
- Git
- MariaDB
Korak 1: Instalirajte Nginx
Ažurirajte svoj popis paketa.
sudo apt update
Instalirajte Nginx.
sudo apt -y install nginx
Nakon što je instalacija dovršena, pokrenite sljedeće naredbe da biste pokrenuli i omogućili uslugu Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
Korak 2: Instalirajte Git
To se može učiniti sljedećom naredbom.
sudo apt -y install git
Korak 3: Instalirajte MariaDB poslužitelj baze podataka
Gitea podržava sljedeće poslužitelje baza podataka.
- MariaDB/MySQL
- PostgreSQL
- SQLite
- TiDB
Za ovaj vodič koristit ćemo MariaDB poslužitelj i klijent.
sudo apt -y install mariadb-server mariadb-client
Kada završite, provjerite je li MariaDB omogućen i pokrenut.
sudo systemctl enable mariadb.service
sudo systemctl start mariadb.service
Nakon toga, pokrenite naredbu u nastavku kako biste osigurali MariaDB poslužitelj kreiranjem root lozinke i onemogućavanjem udaljenog root pristupa.
sudo mysql_secure_installation
Kada se to od vas zatraži, odgovorite na pitanja u nastavku slijedeći vodič.
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
Ponovno pokrenite MariaDB.
sudo systemctl restart mariadb.service
Upišite naredbu u nastavku za prijavu na MariaDB konzolu.
sudo mysql -u root -p
Zatim upišite lozinku koju ste kreirali iznad za prijavu. Vidjet ćete MariaDB poruku dobrodošlice.
Napravite bazu podataka pod nazivom gitea.
CREATE DATABASE gitea;
Stvorite korisnika baze podataka pozvanog giteausers novom lozinkom.
CREATE USER 'giteauser'@'localhost' IDENTIFIED BY 'new_password_here';
Obavezno zamijenite new_password_herejakom i složenom lozinkom.
Zatim korisniku dodijelite puni pristup bazi podataka.
GRANT ALL ON gitea.* TO 'giteauser'@'localhost' IDENTIFIED BY 'user_password_here' WITH GRANT OPTION;
Konačno, spremite promjene i izađite.
FLUSH PRIVILEGES;
EXIT;
Korak 4: Pripremite Gitea okruženje
Stvorite korisnika za pokretanje Gitee.
sudo adduser --system --shell /bin/bash --gecos 'Git Version Control' --group --disabled-password --home /home/git git
Napravite potrebnu strukturu imenika.
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
Korak 5: Instalirajte Gitea
Gitea binarni program može se preuzeti izvođenjem sljedećih naredbi.
sudo wget -O gitea https://dl.gitea.io/gitea/1.5.0/gitea-1.5.0-linux-amd64
sudo chmod +x gitea
Kopirajte binarnu datoteku na globalnu lokaciju.
sudo cp gitea /usr/local/bin/gitea
Korak 6: Napravite servisnu datoteku za automatsko pokretanje Gitea
Izradite linux servisnu datoteku.
sudo touch /etc/systemd/system/gitea.service
Koristeći uređivač teksta po vašem izboru, otvorite ovu novostvorenu datoteku i popunite ako sljedećim.
[Unit]
Description=Gitea (Git with a cup of tea)
After=syslog.target
After=network.target
After=mariadb.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
Omogućite i pokrenite Gitea pri pokretanju.
sudo systemctl daemon-reload
sudo systemctl enable gitea
sudo systemctl start gitea
Provjerite radi li Gitea.
sudo systemctl status gitea
Izbrišite zadanu nginx konfiguracijsku datoteku.
sudo rm /etc/nginx/sites-enabled/default
Izradite konfiguraciju obrnutog proxyja za Gitea.
sudo touch /etc/nginx/sites-available/git
Popunite datoteku sljedećom konfiguracijom, provjerite jeste li zamijenili example.comimenom svoje domene ili IP adresom.
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;
}
}
Omogućite konfiguraciju obrnutog proxyja Gitea Nginx.
sudo ln -s /etc/nginx/sites-available/git /etc/nginx/sites-enabled/git
Zatim ponovno učitajte Nginx uslugu.
sudo systemctl reload nginx.service
Zatim otvorite svoj preglednik i pronađite ime poslužitelja ili IP adresu.
http://YOUR_SERVER_IP/install
Slijedite upute na zaslonu kako biste dovršili postavljanje Gitee.