2023-05-27 19:01:14 +02:00
---
title: 'Installation'
license: 'CC-BY-SA-4.0'
2023-05-28 08:13:57 +02:00
origin_url: 'https://github.com/DanielGibson/DanielGibson.github.io/blob/58362695f743a545d2530508ce42d5fe1eea84a9/content/post/setup-vps-with-wireguard-and-forgejo.md'
2023-05-27 19:01:14 +02:00
---
2023-08-05 11:48:30 +01:00
## Installation with Docker
2023-05-27 19:01:14 +02:00
Forgejo provides [container images ](https://codeberg.org/forgejo/-/packages/container/forgejo/versions ) for use with Docker or other containerization tools.
```shell
2023-07-25 20:31:10 +02:00
docker pull codeberg.org/forgejo/forgejo:1.20.1-0
2023-05-27 19:01:14 +02:00
```
2023-07-25 20:31:10 +02:00
The **1.20** tag is set to be the latest patch release, starting with [1.20.1-0 ](https://codeberg.org/forgejo/-/packages/container/forgejo/1.20.1-0 ). **1.20** will then be equal to **1.20.2-0** when it is released and so on.
2023-05-27 19:01:14 +02:00
2023-07-26 23:20:30 +01:00
Upgrading from **1.X** to **1.X+1** (for instance from **1.19** to **1.20** ) requires a [manual operation and human verification ](../upgrade/ ). However it is possible to use the **X.Y** tag (for instance **1.20** ) to get the latest point release automatically.
2023-05-27 19:01:14 +02:00
Here is a sample [docker-compose ](https://docs.docker.com/compose/install/ ) file:
```yaml
version: '3'
networks:
forgejo:
external: false
services:
server:
2023-07-25 20:31:10 +02:00
image: codeberg.org/forgejo/forgejo:1.20
2023-05-27 19:01:14 +02:00
container_name: forgejo
environment:
- USER_UID=1000
- USER_GID=1000
restart: always
networks:
- forgejo
volumes:
- ./forgejo:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
ports:
- '3000:3000'
- '222:22'
```
Note that the volume should be owned by the user/group with the UID/GID specified in the config file.
If you don't give the volume correct permissions, the container may not start.
2023-08-05 11:48:30 +01:00
### Databases
2023-05-27 19:01:14 +02:00
2023-05-28 00:41:32 +02:00
In the following each database is shown as part of a `docker-compose` example file, with a `diff like` presentation that highlights additions to the example above.
2023-08-05 11:48:30 +01:00
#### MySQL database
2023-05-27 19:01:14 +02:00
```yaml
version: "3"
networks:
forgejo:
external: false
services:
server:
2023-07-25 20:31:10 +02:00
image: codeberg.org/forgejo/forgejo:1.20
2023-05-27 19:01:14 +02:00
container_name: forgejo
environment:
- USER_UID=1000
- USER_GID=1000
+ - FORGEJO__database__DB_TYPE=mysql
+ - FORGEJO__database__HOST=db:3306
+ - FORGEJO__database__NAME=forgejo
+ - FORGEJO__database__USER=forgejo
+ - FORGEJO__database__PASSWD=forgejo
restart: always
networks:
- forgejo
volumes:
- ./forgejo:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
ports:
- "3000:3000"
- "222:22"
+ depends_on:
+ - db
+
+ db:
+ image: mysql:8
+ restart: always
+ environment:
+ - MYSQL_ROOT_PASSWORD=forgejo
+ - MYSQL_USER=forgejo
+ - MYSQL_PASSWORD=forgejo
+ - MYSQL_DATABASE=forgejo
+ networks:
+ - forgejo
+ volumes:
+ - ./mysql:/var/lib/mysql
```
2023-08-05 11:48:30 +01:00
#### PostgreSQL database
2023-05-27 19:01:14 +02:00
```yaml
version: "3"
networks:
forgejo:
external: false
services:
server:
2023-07-25 20:31:10 +02:00
image: codeberg.org/forgejo/forgejo:1.20
2023-05-27 19:01:14 +02:00
container_name: forgejo
environment:
- USER_UID=1000
- USER_GID=1000
+ - FORGEJO__database__DB_TYPE=postgres
+ - FORGEJO__database__HOST=db:5432
+ - FORGEJO__database__NAME=forgejo
+ - FORGEJO__database__USER=forgejo
+ - FORGEJO__database__PASSWD=forgejo
restart: always
networks:
- forgejo
volumes:
- ./forgejo:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
ports:
- "3000:3000"
- "222:22"
+ depends_on:
+ - db
+
+ db:
+ image: postgres:14
+ restart: always
+ environment:
+ - POSTGRES_USER=forgejo
+ - POSTGRES_PASSWORD=forgejo
+ - POSTGRES_DB=forgejo
+ networks:
+ - forgejo
+ volumes:
+ - ./postgres:/var/lib/postgresql/data
```
2023-08-05 11:48:30 +01:00
## Installation from binary
2023-05-27 19:01:14 +02:00
2023-08-05 11:48:30 +01:00
### Install Forgejo and git, create git user
2023-05-27 19:01:14 +02:00
2023-05-28 08:56:34 +02:00
> **NOTE:** this guide assumes that you'll host on the server with the domain git.example.com.
2023-05-28 00:45:11 +02:00
2023-05-27 23:54:04 +02:00
First, download the Forgejo binary for your CPU architecture and maybe verify the GPG signature,
2023-07-26 23:20:30 +01:00
as described on [the Forgejo download page ](/download/ ).
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
Next, copy the downloaded Forgejo binary to `/usr/local/bin/` (renaming it to just "forgejo")
2023-05-28 08:56:34 +02:00
and make it executable:
> **NOTE:** when a line starts with #, it means the command 'foo --bar' must be run as root (or with sudo).
2023-07-25 20:31:10 +02:00
`# cp forgejo-1.20.1-0-linux-amd64 /usr/local/bin/forgejo`
2023-05-27 19:01:14 +02:00
`# chmod 755 /usr/local/bin/forgejo`
2023-05-27 23:54:04 +02:00
Make sure `git` and `git-lfs` are installed:
2023-05-27 19:01:14 +02:00
`# apt install git git-lfs`
2023-05-27 23:54:04 +02:00
Create a user `git` on the system. Forgejo will run as that user, and when accessing git through ssh
(which is the default), this user is part of the URL _(for example in
2023-05-28 00:45:11 +02:00
`git clone git@git.example.com:YourOrg/YourRepo.git` the `git` before the `@` is the user you'll create now)._
2023-05-27 23:54:04 +02:00
On **Debian, Ubuntu** and their derivates that's done with:
2023-05-27 19:01:14 +02:00
```
# adduser --system --shell /bin/bash --gecos 'Git Version Control' \
--group --disabled-password --home /home/git git
```
2023-05-27 23:54:04 +02:00
On **Linux distributions not based on Debian/Ubuntu** (this should at least work with Red Hat derivates
2023-05-28 00:20:34 +02:00
like Fedora, CentOS etc.), run this instead:
2023-05-27 19:01:14 +02:00
```
# groupadd --system git
# adduser --system --shell /bin/bash --comment 'Git Version Control' \
--gid git --home-dir /home/git --create-home git
```
2023-08-05 11:48:30 +01:00
### Create directories Forgejo will use
2023-05-27 19:01:14 +02:00
Now create the directories Forgejo will use and set access rights appropriately:
2023-05-27 23:54:04 +02:00
`# mkdir /var/lib/forgejo`
`# chown git:git /var/lib/forgejo && chmod 750 /var/lib/forgejo`
2023-05-27 19:01:14 +02:00
_This is the directory Forgejo will store its data in, including your git repos._
2023-05-27 23:54:04 +02:00
`# mkdir /etc/forgejo`
`# chown root:git /etc/forgejo && chmod 770 /etc/forgejo`
2023-05-28 00:20:34 +02:00
_This is the directory Forgejo's config, called `app.ini` , is stored in. Initially it needs to
2023-05-27 23:54:04 +02:00
be writable by Forgejo, but after the installation you can make it read-only for Forgejo because
then it shouldn't modify it anymore._
2023-05-27 19:01:14 +02:00
2023-08-05 11:48:30 +01:00
### Optional: Set up database
2023-05-27 19:01:14 +02:00
When using sqlite as Forgejos database, nothing needs to be done here.
2023-05-27 23:54:04 +02:00
If you need a more powerful database, you can use MySQL/MariaDB or PostgreSQL (apparently sqlite
2023-05-28 00:20:34 +02:00
is good enough for at least 10 users, but might even suffice for more).
2023-05-27 19:01:14 +02:00
2023-07-26 23:20:30 +01:00
See [Forgejos Database Preparation guide ](../database-preparation/ ) for
2023-05-28 00:20:34 +02:00
setup instructions.
2023-05-27 19:01:14 +02:00
2023-08-05 11:48:30 +01:00
### Install systemd service for Forgejo
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
Forgejo provides a
[systemd service script ](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/contrib/systemd/forgejo.service ).
Download it to the correct location:
`# wget -O /etc/systemd/system/forgejo.service https://codeberg.org/forgejo/forgejo/raw/branch/forgejo/contrib/systemd/forgejo.service`
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
If you're _not_ using sqlite, but MySQL or MariaDB or PostgreSQL, you'll have to edit that file
(`/etc/systemd/system/forgejo.service` ) and uncomment the corresponding `Wants=` and `After=` lines.
2023-05-28 00:20:34 +02:00
Otherwise it _should_ work as it is.
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
Now enable and start the Forgejo service, so you can go on with the installation:
`# systemctl enable forgejo.service`
2023-05-27 19:01:14 +02:00
`# systemctl start forgejo.service`
2023-08-05 11:48:30 +01:00
### Forgejos web-based configuration
2023-05-27 19:01:14 +02:00
2023-05-30 08:55:36 +02:00
You should now be able to access Forgejo in your local web browser, so open http://git.example.com:3000/.
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
If it doesn't work:
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
- Make sure the forgejo service started successfully by checking the output of
`# systemctl status forgejo.service`
If that indicates an error but the log lines underneath are too incomplete to tell what caused it,
`# journalctl -n 100 --unit forgejo.service`
2023-05-27 19:01:14 +02:00
will print the last 100 lines logged by Forgejo.
2023-05-28 00:20:34 +02:00
You should be greeted by Forgejo's "Initial Configuration" screen.
2023-05-27 19:01:14 +02:00
The settings should be mostly self-explanatory, some hints:
2023-05-27 23:54:04 +02:00
- Select the correct database (SQLite3, or if you configured something else in the
2023-05-28 00:20:34 +02:00
"Set up database" step above, select that and set the corresponding options)
2023-05-28 00:45:11 +02:00
- **Server Domain** should be `git.example.com` (or whatever you're actually using),
2023-05-30 15:33:06 +02:00
**Forgejo Base URL** should be `http://git.example.com:3000` (assuming you won't change HTTP_PORT a different value than 3000)
2023-05-27 23:54:04 +02:00
- Check the **Server and Third-Party Service Settings** settings for settings that look relevant
for you.
2023-05-28 00:20:34 +02:00
- It may make sense to create the administrator account right now (**Administrator Account Settings**),
2023-05-27 23:54:04 +02:00
even more so if you disabled self-registration.
2023-05-28 00:20:34 +02:00
- Most settings can be changed in `/etc/forgejo/app.ini` later, so don't worry about them too much.
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
Once you're done configuring, click `Install Forgejo` and a few seconds later you should be
on the dashboard (if you created an administrator account) or at the login/register screen, where you
can create an account to then get to the dashboard.
2023-05-27 19:01:14 +02:00
2023-05-28 08:56:34 +02:00
So far, so good, but we're not quite done yet - some manual configuration in the app.ini is needed.
2023-05-27 19:01:14 +02:00
2023-08-05 11:48:30 +01:00
### Further configuration in Forgejo's app.ini
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
Stop the forgejo service:
2023-05-27 19:01:14 +02:00
`# systemctl stop forgejo.service`
2023-05-27 23:54:04 +02:00
While at it, make `/etc/forgejo/` and the `app.ini` read-only for the git user (Forgejo doesn't
write to it after the initial configuration):
2023-05-27 19:01:14 +02:00
`# chmod 750 /etc/forgejo && chmod 640 /etc/forgejo/app.ini`
Now (as root) edit `/etc/forgejo/app.ini`
2023-05-27 23:54:04 +02:00
> **NOTE:** You'll probably find the
2023-07-26 23:20:30 +01:00
> [Configuration Cheat Sheet](../config-cheat-sheet/) and the
2023-05-27 23:54:04 +02:00
> [Example app.ini](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/custom/conf/app.example.ini)
> that contains all options incl. descriptions helpful.
2023-05-27 19:01:14 +02:00
2023-05-28 00:20:34 +02:00
The following changes are recommended if dealing with many large files:
2023-05-27 19:01:14 +02:00
2023-05-27 23:54:04 +02:00
- Forgejo allows uploading files to git repos through the web interface.
By default the **file size for uploads**
is limited to 3MB per file, and 5 files at once. To increase it, under the `[repository]` section,
add a `[repository.upload]` section with a line like `FILE_MAX_SIZE = 4095`
(that would be 4095MB, about 4GB) and `MAX FILES = 20`
It'll look somehow like this:
```ini
...
[repository]
ROOT = /var/lib/forgejo/data/forgejo-repositories
[repository.upload]
;; max size for files to the repo via web interface, in MB,
;; defaults to 3 (this sets a limit of about 4GB)
FILE_MAX_SIZE = 4095
;; by default 5 files can be uploaded at once, increase to 20
MAX_FILES = 20
[server]
...
```
Similar restrictions restrictions exist for attachments to issues/pull requests, configured
2023-05-28 00:29:01 +02:00
in the [`[attachment]` sections](../config-cheat-sheet/#issue -and-pull-request-attachments-attachment)
2023-05-27 23:54:04 +02:00
`MAX_SIZE` (default 4MB) and `MAX_FILES` (default 5) settings.
- By default **LFS data uploads expire** after 20 minutes - this can be too short for big files,
slow connections or slow LFS storage (git-lfs seems to automatically restart the upload then -
which means that it can take forever and use lots of traffic)..
If you're going to use LFS with big uploads, increase thus limit, by adding a line
`LFS_HTTP_AUTH_EXPIRY = 180m` (for 180 minutes) to the `[server]` section.
- Similarly there are timeouts for all kinds of git operations, that can be too short.
2023-05-28 00:20:34 +02:00
Increasing all those git timeouts by adding a `[git.timeout]` section
2023-05-27 23:54:04 +02:00
below the `[server]` section:
```ini
;; Git Operation timeout in seconds
;; increase the timeouts, so importing big repos (and presumably
;; pushing large files?) hopefully won't fail anymore
[git.timeout]
DEFAULT = 3600 ; Git operations default timeout seconds
MIGRATE = 6000 ; Migrate external repositories timeout seconds
MIRROR = 3000 ; Mirror external repositories timeout seconds
CLONE = 3000 ; Git clone from internal repositories timeout seconds
PULL = 3000 ; Git pull from internal repositories timeout seconds
GC = 600 ; Git repository GC timeout seconds
```
2023-05-28 00:20:34 +02:00
They are increased by a factor 10 (by adding a 0 at the end); probably not all these timeouts
need to be increased (and if, then maybe not this much)... use your own judgement.
2023-05-27 23:54:04 +02:00
- By default LFS files are stored in the filesystem, in `/var/lib/forgejo/data/lfs` .
In the `[lfs]` section you can change the `PATH = ...` line to store elsewhere, but you can also
2023-05-28 00:20:34 +02:00
configure Forgejo to store the files in an S3-like Object-Storage.
2023-05-28 08:56:34 +02:00
- If you want to use the systemwide sendmail, enable sending E-Mails by changing the `[mailer]` section like this:
2023-05-27 23:54:04 +02:00
```ini
[mailer]
2023-05-28 00:20:34 +02:00
;; send mail with systemwide "sendmail"
2023-05-27 23:54:04 +02:00
ENABLED = true
PROTOCOL = sendmail
FROM = "Forgejo Git" < noreply @yourdomain .com >
```
2023-08-03 18:21:09 +02:00
- By default Forgejo will listen to the port 3000 but that can be [changed to 80 with HTTP_PORT ](../config-cheat-sheet/ ) like this:
2023-05-30 15:23:16 +02:00
```ini
[server]
HTTP_PORT = 80
```
2023-05-27 23:54:04 +02:00
When you're done editing the app.ini, save it and start the forgejo service again:
2023-05-27 19:01:14 +02:00
`# systemctl start forgejo.service`
2023-05-27 23:54:04 +02:00
You can test sending a mail by clicking the user button on the upper right of the Forgejo page
("Profile and Settings"), then `Site Administration` , then `Configuration` and under
`Mailer Configuration` type in your mail address and click `Send Testing Email` .
2023-08-05 11:48:30 +01:00
### General hints for using Forgejo
2023-05-27 23:54:04 +02:00
Sometimes you may want/need to use the Forgejo
2023-08-27 02:57:23 +01:00
[command line interface ](../command-line/ ).
2023-05-27 23:54:04 +02:00
Keep in mind that:
- You need to **run it as `git` user** , for example with `$ sudo -u git forgejo command --argument`
- You need to specify the **Forgejo work path** , either with the `--work-path /var/lib/forgejo`
(or `-w /var/lib/forgejo` ) commandline option or by setting the `FORGEJO_WORK_DIR` environment variable
(`$ export FORGEJO_WORK_DIR=/var/lib/forgejo` ) before calling `forgejo`
- You need to specify the path to the config (app.ini) with `--config /etc/forgejo/app.ini`
(or `-c /etc/forgejo/app.ini` ).
So all in all your command might look like:
`$ sudo -u git forgejo -w /var/lib/forgejo -c /etc/forgejo/app.ini admin user list`
> **_For convenience_**, you could create a `/usr/local/bin/forgejo.sh` with the following contents:
>
> ```sh
> #!/bin/sh
> sudo -u git forgejo -w /var/lib/forgejo -c /etc/forgejo/app.ini "$@"
> ```
>
> and make it executable:
> `# chmod 755 /usr/local/bin/forgejo.sh`
>
> Now if you want to call `forgejo` on the commandline (for the default system-wide installation
> in `/var/lib/forgejo`), just use e.g. `$ forgejo.sh admin user list` instead of the long
> line shown above.
You can always call forgejo and its subcommands with `-h` or `--help` to make it output usage
information like available options and (sub)commands, for example
`$ forgejo admin user -h`
to show available subcommands to administrate users on the commandline.