Article

Table of Contents
Theme:
Was this article helpful?
Try Vultr Today with

$50 Free on Us!

Want to contribute?

You could earn up to $600 by adding new articles.

How to Install Gitea on Ubuntu 18.04

Last Updated: Fri, Dec 7, 2018
Linux Guides Programming Server Apps Ubuntu

Gitea is an alternative open source, self-hosted version control system powered by git. Gitea is written in Golang and is a lightweight solution to be hosted on any platform.

Prerequisites

  • New Vultr Ubuntu 18.04 instance with at least 2 CPU cores and 1 GB RAM

  • Non-root user with sudo privileges.

  • Nginx

  • Git

  • MariaDB

Step 1: Install Nginx

Update your Vultr Ubuntu 18.04 Server instance.

sudo apt update

Install Nginx.

sudo apt -y install nginx

Once Nginx installed, test whether it is working or not by browsing the nginx test page in the browser. Open your web browser and point it to http://example.com

The following commands can be used to stop, reload, restart, check status and enable 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

Step 2: Install Git

Install Git.

sudo apt -y install git

Once installed, check the version:

git --version

git version 2.17.1

Step 3: Install MariaDB Database Server

Gitea supports the following databases

  • MariaDB/MySQL

  • PostgreSQL

  • SQLite

  • TiDB

For this tutorial we will install the MariaDB server and client.

sudo apt -y install mariadb-server mariadb-client

After installing MariaDB, the commands below can be used to stop, start, restart, check status and enable it.

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

After that, run the command below to secure the MariaDB server by creating a root password and disallowing remote root access.

sudo mysql_secure_installation

When prompted, answer the questions below by following the guide.

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

Restart MariaDB.

sudo systemctl restart mariadb.service

To test if MariaDB is installed, type the command below to logon to MariaDB server

sudo mysql -u root -p

Then type the password you created above to login. You will see the MariaDB welcome message.

Create a database called gitea.

CREATE DATABASE gitea;

Create a database user called giteauser with a new password.

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

Then grant the user full access to the database.

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

Finally, save your changes and exit.

FLUSH PRIVILEGES;

EXIT;

Step 4: Prepare the Gitea Environment

Create a user to run Gitea.

sudo adduser \

   --system \

   --shell /bin/bash \

   --gecos 'Git Version Control' \

   --group \

   --disabled-password \

   --home /home/git \

   git

Create the required directory structure.

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

Step 5: Install Gitea

Download the Gitea binary using the method on the official distribution page.

Copy the binary to a global location.

sudo cp gitea /usr/local/bin/gitea

Step 6: Create a service file to start Gitea automatically

Create a linux service file.

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

Populate the file with the following.

[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

Enable and start Gitea at boot.

sudo systemctl daemon-reload

sudo systemctl enable gitea

sudo systemctl start gitea

Run the status command.

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

Step 7: Configure Nginx as a reverse proxy

Delete the default nginx configuration file.

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

Create a reverse proxy configuration for Gitea.

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

Populate the file with the following configuration.

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;

    }

}

Enable the Gitea Nginx reverse proxy configuration.

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

Then reload the Nginx Service.

sudo systemctl reload nginx.service

Next, open your browser and browse to the server hostname or IP address.

http://example.com/install

Follow the onscreen instructions to complete the Gitea setup.

Want to contribute?

You could earn up to $600 by adding new articles.