18
0
Fork 0

(WIP) Documentation Gitea

This commit is contained in:
Ludovic Poujol 2018-10-24 22:27:08 +02:00
parent 2b6aafc45c
commit bce06827ae
1 changed files with 208 additions and 0 deletions

208
HowtoGitea.md Normal file
View File

@ -0,0 +1,208 @@
---
title: Howto Gitea
categories: sysadmin git forge
...
* Site officiel : <https://gitea.io/>
[Gitea](https://gitea.io/) est un fork de gogs, une solution d'hébergement de code avec git.
## Installation
Malheureusement, gitea n'est pas distribué sous forme de paquet Debian. Une alternative est donc d'utiliser directement les binaires produits par les développeurs de Gitea. Ils sont récupérables sur <https://dl.gitea.io/gitea/>.
~~~
# cd /usr/local/bin
# wget https://dl.gitea.io/gitea/1.5.2/gitea-1.5.2-linux-amd64
# chmod +x gitea-1.5.2-linux-amd64
# ln -s gitea-1.5.2-linux-amd64 gitea
# mkdir /etc/gitea/
# gitea --version
Gitea version 1.5.2 built with: bindata, sqlite
~~~
**Note** : Même si gitea peut fonctionner de manière autonome avec SQLite, à partir d'une certaine taille/utilisation, il est préférable de basculer vers un moteur de base de données tel que [HowtoMySQL]() ou [HowtoPostgreSQL]() et d'ajouter [HowtoRedis]() pour le cache/sessions.
## Configuration
Dans la suite de cette documentation, on se place dans le cas d'une instance simple, fonctionnant avec l'utilisateur **git**. On part du principe que : MySQL est déjà installé, et que le compte pour l'application existe déjà.
Au final, on va se retrouver avec la hiérarchie suivante :
~~~
$ tree /home/git
├── internals
│   ├── custom << Fichiers de customisation de l'interface web de gitea
│   └── data << Toutes les données de gitea (autres que les dépôts git)
│   ├── avatars
│   ├── indexers
│   ├── lfs
│   └── sessions
├── log << Journaux applicatifs
│   ├── gitea.log
│   ├── http.log
│   ├── serv.log
│   └── xorm.log
└── repositories << Données des dépôts git
└── foo
└── hello_world.git
~~~
Lors de la première exécution de gitea, une page d'installation va demander tous les paramètres nécessaires pour initialiser l'instance. Celle-ci va aussi permettre de créer le premier compte administrateur.
### /etc/gitea/git.ini
On doit initialiser le fichier de configuration de gitea avec les commandes suivantes.
A noter qu'on ne laisse les droits d'écritures uniquement pour l'installation.
~~~
# touch /etc/gitea/git.ini
# chown root:git /etc/gitea/git.ini
# chmod g+rw /etc/gitea/git.ini
~~~
On ajoute aussi quelques réglages initiaux, pour que l'interface de gitea soit directement fonctionnelle :
~~~
# cat /etc/gitea/git.ini
APP_NAME = Gitea
RUN_USER = git
RUN_MODE = prod
[server]
PROTOCOL = unix
DOMAIN = gitea.example.org
HTTP_ADDR = /home/git/gitea.sock
UNIX_SOCKET_PERMISSION = 660
OFFLINE_MODE = true
SSH_DOMAIN = gitea.example.org
ROOT_URL = https://gitea.example.org/
~~~
### systemd
~~~
# cat /etc/systemd/system/gitea@.service
[Unit]
Description=Gitea (Git with a cup of tea)
After=syslog.target
After=network.target
After=mysqld.service
[Service]
User=git
Group=git
Type=simple
RestartSec=2s
Restart=always
WorkingDirectory=/home/git
ExecStart=/usr/local/bin/gitea web --config /etc/gitea/git.ini
Environment=GITEA_WORK_DIR=/home/git/internals
[Install]
WantedBy=multi-user.target
~~~
### MySQL
~~~
# mysqladmin create git
# mysql
mysql> GRANT ALL PRIVILEGES ON git.* TO 'git'@localhost IDENTIFIED BY 'PASSWORD';
~~~
Côté gitea.ini, la base de donnée MySQL se configure avec la section ci-dessous.
**Note** : La page d'installation va remplir cette section de la configuration automatiquement.
~~~
[database]
DB_TYPE = mysql
HOST = /run/mysqld/mysqld.sock
NAME = git
USER = git
PASSWD = PASSWORD
~~~
### Nginx
~~~
# cat /etc/nginx/sites-enabled/git
upstream gitea_git {
server unix:/home/git/gitea.sock;
}
server {
listen 0.0.0.0:80;
listen [::]:80;
listen 0.0.0.0:443 ssl http2;
listen [::]:443 ssl http2;
server_name gitea.evolix.org;
include /etc/nginx/ssl/git.conf;
include /etc/nginx/letsencrypt.conf;
if ( $scheme = http ) {
return 301 https://$server_name$request_uri;
}
location / {
proxy_pass http://gitea_git;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_read_timeout 10;
}
}
~~~
### Redis
*TODO*
## Avancé
### Multiples instances
On peut très bien faire du multi-instance. On peut ainsi basculer sur une unité systemd avec paramètre comme :
~~~
# cat /etc/systemd/system/gitea@.service
[Unit]
Description=Gitea (Git with a cup of tea) for %i
After=syslog.target
After=network.target
After=mysqld.service
[Service]
User=%i
Group=%i
Type=simple
RestartSec=2s
Restart=always
WorkingDirectory=/home/%i
ExecStart=/usr/local/bin/gitea web --config /etc/gitea/%i.ini
Environment=GITEA_WORK_DIR=/home/%i/internals
[Install]
WantedBy=multi-user.target
~~~