lemmy ansible scripts configured for Rocky Linux ARM
Find a file
Keith Novak dc9e752865
Cleanup README.md (#79)
Formatting changes for readability. Added a note on how to do passwordless ssh, because it's been a while and I forgot how to do it :) I'm hoping it helps someone else.
2023-06-07 15:56:19 -04:00
examples Updating VERSION 2023-02-22 09:55:13 -05:00
files Use /etc to configure docker logging (#52) 2022-08-29 15:38:14 -04:00
templates Increase pictrs mem_limit (#73) 2023-06-06 12:29:48 -04:00
.gitignore Move password into domain folder. 2021-10-09 12:13:23 -04:00
.woodpecker.yml Adding woodpecker (#63) 2023-03-24 21:45:26 +01:00
ansible.cfg Adding a note about priviledges to README. (#18) 2021-11-26 12:36:37 +00:00
lemmy.yml Install latest docker/docker-compose via pip. Proposed as fix for #67 (#69) 2023-06-03 07:12:04 -04:00
LICENSE Adding AGPL license. Fixes #37 (#39) 2022-05-09 22:45:52 +00:00
README.md Cleanup README.md (#79) 2023-06-07 15:56:19 -04:00
uninstall.yml Removing extra from uninstall. 2021-10-12 13:03:21 -04:00
VERSION Updating VERSION 2023-06-01 11:42:02 -04:00

Lemmy-Ansible

This provides an easy way to install Lemmy on any server. It automatically sets up an nginx server, letsencrypt certificates, and email.

Requirements

To run this ansible playbook, you need to:

  • Have a server / VPS where lemmy will run.
  • Configure a DNS A Record to point at your server's IP address.
  • Make sure you can ssh to it, with a sudo user: ssh <your-user>@<your-domain>
  • Install Ansible on your local machine (do not install it on your destination server).

Install

  1. Clone this repo:

    git clone https://github.com/LemmyNet/lemmy-ansible.git
    cd lemmy-ansible
    
  2. Make a directory to hold your config:

    mkdir -p inventory/host_vars/<your-domain>

  3. Copy the sample configuration file:

    cp examples/config.hjson inventory/host_vars/<your-domain>/config.hjson

    Edit that file and change the config to your liking. Note: Do not edit anything inside the {{ }} braces.

    Here are all the config options.

  4. Copy the sample inventory hosts file:

    cp examples/hosts inventory/hosts

    Edit the inventory hosts file (inventory/hosts) to your liking.

  5. Copy the sample postgresql.conf

    cp examples/customPostgresql.conf inventory/host_vars/<your-domain>/customPostgresql.conf

    You can use the PGTune tool to tune your postgres to meet your server memory and CPU.

  6. Run the playbook:

    ansible-playbook -i inventory/hosts lemmy.yml

    Note: if you are not the root user or don't have password-less sudo, use this command:

    ansible-playbook -i inventory/hosts lemmy.yml --become --ask-become-pass

    Note: if you haven't set up ssh keys1, and ssh using a password, use the command:

    ansible-playbook -i inventory/hosts lemmy.yml --become --ask-pass --ask-become-pass

    Full ansible command-line docs

    If the command above fails, you may need to comment out this line In the ansible.cfg file:

    interpreter_python=/usr/bin/python3

Upgrading

  • Run git pull
  • Check out the Lemmy Releases Changelog to see if there are any config changes with the releases since your last.
  • Run ansible-playbook -i inventory/hosts lemmy.yml --become

Migrating your existing install to use this deploy

  • Follow this guide to backup your existing install.
  • Run docker-compose stop to stop lemmy.
  • Move your docker folders on the server to <lemmy_base_dir>/<your-domain>.
  • Copy your postgres password to inventory/host_vars/<your-domain>/passwords/postgres.
  • Follow the install guide above, making sure your config.hjson is the same as your backup.

Uninstall

ansible-playbook -i inventory/hosts uninstall.yml --become

License


  1. To create an ssh key pair with your host environment, you can follow the instructions here, and then copy the key to your host server. ↩︎