trashposs/docs/docker.md

49 lines
2.3 KiB
Markdown
Raw Normal View History

2024-04-06 22:37:46 +02:00
# 🐳 Running a TrashPoss server with Docker
## Pre-built docker container
2024-04-06 23:55:59 +02:00
[trashposs/trashposs](iceshrimp.dev/Crimekillz/trashposs)
2022-12-16 23:34:27 +01:00
## `docker-compose`
There is a `docker-compose.yml` in the root of the project that you can use to build the container from source
- .config/docker.env (**db config settings**)
2024-04-06 22:37:46 +02:00
- .config/default.yml (**TrashPoss server settings**)
2022-12-16 23:34:27 +01:00
## Configuring
Rename the files:
2023-03-23 22:45:33 +01:00
`cp .config/example.yml .config/default.yml`
`cp .config/example.env .config/docker.env`
then edit them according to your environment.
You can configure `docker.env` with anything you like, but you will have to pay attention to the `default.yml` file:
2023-06-02 21:16:36 +02:00
- `url` should be set to the URL you will be hosting the web interface for the server at.
2024-04-06 23:55:59 +02:00
- `host`, `db`, `user`, `pass` will have to be configured in the `PostgreSQL configuration` section - `host` is the name of the postgres container (eg: *trashposs_db_1*), and the others should match your `docker.env`.
- `host`will need to be configured in the *Redis configuration* section - it is the name of the redis container (eg: *trashposs_redis_1*)
2023-03-23 22:45:33 +01:00
- `auth` will need to be configured in the *Sonic* section - cannot be the default `SecretPassword`
2022-12-13 05:22:39 +01:00
Everything else can be left as-is.
## Running docker-compose
2022-12-16 23:34:27 +01:00
2024-04-06 23:55:59 +02:00
The [prebuilt container for trashposs](https://iceshrimp.dev/Crimekillz/-/packages/container/trashposs/latest) is fairly large, and may take a few minutes to download and extract using docker.
2022-12-13 05:22:39 +01:00
Copy `docker-compose.yml` and the `config/` to a directory, then run the **docker-compose** command:
`docker-compose up -d`.
2024-04-06 22:37:46 +02:00
NOTE: This will take some time to come fully online, even after download and extracting the container images, and it may emit some error messages before completing successfully. Specifically, the `db` container needs to initialize and so isn't available to the `web` container right away. Only once the `db` container comes online does the `web` container start building and initializing the TrashPoss tables.
2024-04-06 22:37:46 +02:00
Once the server is up you can use a web browser to access the web interface at `http://serverip:3000` (where `serverip` is the IP of the server you are running the TrashPoss server on).
2022-12-16 23:34:27 +01:00
## Docker for development
```sh
cd dev/
docker-compose build
docker-compose run --rm web pnpm run init
2022-12-16 23:34:27 +01:00
docker-compose up -d
```