MasterpieceDockerCompose/gitea/README.md

144 lines
3.8 KiB
Markdown
Raw Normal View History

2021-05-25 11:36:01 +02:00
# Gitea
2021-05-17 09:57:45 +02:00
<div align="center">
<img src="https://gitea.io/images/screenshot.png" />
</div>
2021-05-25 11:36:01 +02:00
## Descrizione
[Sito ufficiale](https://gitea.io/) - [Repo (Github)](https://github.com/go-gitea/gitea) - [Demo](https://try.gitea.io/) - [Docs](https://docs.gitea.io/)
2021-05-17 09:57:45 +02:00
Gitea è un server per repository git veloce, semplice e facile da configurare:
- Interfaccia web multilingua e configurabile
- Un'alternativa open-source a GitHub/GitLab/etc
2021-05-17 09:57:45 +02:00
- Supporta i maggiori database (SQLite, MySQL/MariaDB e PostgreSQL)
2021-05-25 11:36:01 +02:00
## Struttura file e cartelle
2021-05-17 09:57:45 +02:00
```
/home/
└── docker/
└── gitea/
├── data/
├── db/
├── .env
└── docker-compose.yml
2021-05-17 09:57:45 +02:00
```
2021-05-17 12:45:18 +02:00
* `data/` - cartella dove i dati di gitea vengono salvati
* `db/` - cartella dove i dati del database vengono salvati
* `.env` - file contenenti le variabili environment per il docker-compose
2021-05-17 12:45:18 +02:00
* `docker-compose.yml` - file usato per creare il container
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
**N.B. Tutti i file e le cartelle devono essere creati a mano.**
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
## Esempi
Semplice esempio per iniziare ad usare subito il container
2021-05-17 09:57:45 +02:00
### network
```bash
docker network create custom-bridge
```
oppure
```bash
podman network create custom-bridge
```
2021-05-25 11:36:01 +02:00
### docker-compose
2021-05-17 09:57:45 +02:00
`docker-compose.yml`
```yml
version: "3.8"
services:
db:
container_name: gitea-db
image: postgres:13-alpine
security_opt:
- no-new-privileges:true
networks:
- custom-bridge
2021-05-17 09:57:45 +02:00
restart: always
env_file: .env
volumes:
- ${POSTGRES_DATA:-/home/docker/gitea/db}:/var/lib/postgresql/data
- /etc/localtime:/etc/localtime:ro
healthcheck:
test: ["CMD", "pg_isready", "-U", "gitea"]
interval: 1m30s
timeout: 10s
retries: 3
start_period: 10s
git:
container_name: gitea
image: gitea/gitea:1.14.2
networks:
- custom-bridge
2021-05-17 09:57:45 +02:00
restart: unless-stopped
depends_on:
- db
ports:
2021-05-17 12:45:18 +02:00
- ${GITEA_WEBUI_PORT:-3000}:3000
2021-05-17 09:57:45 +02:00
- ${GITEA_SSH_PORT:-221}:22
env_file: .env
volumes:
- ${POSTGRES_DATA:-/home/docker/gitea/data}:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
2021-05-17 12:45:18 +02:00
healthcheck: # se modificate la porta dell'interfaccia web, ricordatevi di cambiarla anche qua sotto
test: ["CMD", "curl", "-Ssf", http://localhost:3000"]
interval: 1m30s
2021-05-17 09:57:45 +02:00
timeout: 10s
retries: 3
2021-05-17 12:45:18 +02:00
start_period: 1m
networks:
custom-bridge:
name: custom-bridge
driver: bridge
2021-05-17 09:57:45 +02:00
```
`.env`
```bash
# Generale
2021-05-17 11:57:31 +02:00
POSTGRES_DATA=/home/docker/gitea/db
GITEA_DATA=/home/docker/gitea/data
2021-05-17 12:45:18 +02:00
GITEA_WEBUI_PORT=3000
2021-05-17 11:57:31 +02:00
GITEA_SSH_PORT=221
2021-05-17 09:57:45 +02:00
# Postgres
2021-05-17 12:45:18 +02:00
POSTGRES_DB=gitea
2021-05-17 09:57:45 +02:00
POSTGRES_USER=gitea
POSTGRES_PASSWORD=gitea
# Gitea
GITEA__database__DB_TYPE=postgres
GITEA__database__HOST=db:5432
GITEA__database__NAME=gitea
GITEA__database__USER=gitea
GITEA__database__PASSWD=gitea
```
2021-05-25 11:36:01 +02:00
## Reverse proxy
Ancora non ho previsto l'uso di un reverse proxy (Vedi [Todo](#Todo))
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
## Aggiornamento
### Automatico
Usando [watchtower](../watchtower) il container si aggiorna automaticamente
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
### Manuale
1. `docker-compose pull`
2. `docker-compose up -d`
3. `docker image prune`
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
## Backup e ripristino
### Backup
Usate [borg](../borg_backup) per fare i backup giornalieri dell'intera cartella `gitea`
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
### Ripristino
Per una maggiore spiegazione sui passaggi da fare, controllate [qua](../borg_backup#user-content-controllare-la-cartella-dei-backup)
1. fermare il container `docker-compose down`
2. cancellare l'intera cartella `gitea`
3. dal backup copiare la cartella `gitea`
4. far ripartire il container `docker-compose up -d`
2021-05-17 09:57:45 +02:00
2021-05-25 11:36:01 +02:00
## Todo
2021-05-17 09:57:45 +02:00
Implementare:
2021-05-25 11:36:01 +02:00
- reverse proxy: **[caddy](https://caddyserver.com/)** o **[traefik](https://doc.traefik.io/traefik/)**