Install with Docker
Make sure you have both docker and docker-compose(>=2.0
) installed. On Ubuntu, just run apt install docker-compose-v2 docker.io
. On Debian, you need to install Docker using their official installation instructions and custom apt
repo.
Create a folder for the lemmy files. the location doesnt matter. You can put this anywhere you want, for example under /srv/
:
mkdir lemmy
cd lemmy
Then download default config files:
wget https://raw.githubusercontent.com/LemmyNet/lemmy-docs/main/assets/docker-compose.yml
wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/examples/config.hjson -O lemmy.hjson
wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/templates/nginx_internal.conf
wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/files/proxy_params
Edit docker-compose.yml
and lemmy.hjson
to replace all occurrences of {{ domain }}
with your actual Lemmy domain, {{ postgres_password }}
with a random password and {{lemmy_port}}
with 10633
.
Also edit nginx_internal.conf
and replace {{ nginx_internal_resolver }}
with 127.0.0.11
(use 10.89.0.1
for RedHat distributions).
If you'd like further customization, have a look at the config file named lemmy.hjson
, and adjust it accordingly.
Database tweaks
To optimize your database, add this file.
You can input your system specs, using this tool: https://pgtune.leopard.in.ua/
wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/examples/customPostgresql.conf
Folder permissions
Set the correct permissions for pictrs folder:
mkdir -p volumes/pictrs
sudo chown -R 991:991 volumes/pictrs
Finally, run:
docker compose up -d
lemmy-ui is accessible on the server at http://localhost:{{ lemmy_port }}
Reverse Proxy / Webserver
Here's an optional nginx reverse proxy template, which you can place in /etc/nginx/sites-enabled
Alternatively, you can use any other web server such as caddy as a simple reverse proxy.
Be sure to edit the {{ }}
to match your domain and port.
If you're using this, you will need to set up Let's Encrypt. See those instructions below.
wget https://raw.githubusercontent.com/LemmyNet/lemmy-ansible/main/templates/nginx.conf
If you've set up Let's Encrypt and your reverse proxy, you can go to https://{{ domain }}
Let's Encrypt
You should also setup TLS, for example with Let's Encrypt. Here's a guide for setting up letsencrypt on Ubuntu.
For federation to work, it is important that you do not change any headers that form part of the signature. This includes the Host
header - you may need to refer to the documentation for your proxy server to pass through the Host
header unmodified.
Updating
To update to the newest version, it is usually enough to change the version numbers in docker-compose.yml
, eg dessalines/lemmy:0.19.4
to dessalines/lemmy:0.19.5
. If additional steps are required, these are explained in the respective release announcement. After changing the versions, run these commands:
docker compose pull
docker compose up -d