Compare commits
5 Commits
ee32bfb73b
..
master
| Author | SHA1 | Date | |
|---|---|---|---|
| 2ffbd08f84 | |||
| bea83f5b03 | |||
| 5c4367cf7b | |||
| 9043105edb | |||
| 69d5fc0b16 |
+14
@@ -7,12 +7,26 @@ loolwsd.xml
|
||||
# Service folders
|
||||
**/bundesdata_web_app/
|
||||
**/data/
|
||||
**/data*/
|
||||
**/db/
|
||||
**/mariadb/
|
||||
**/redis/
|
||||
**/html/
|
||||
**/volumes/
|
||||
**/config/
|
||||
**/config*/
|
||||
**/ollama/
|
||||
|
||||
# Game Servers
|
||||
## Sons Of The Forest
|
||||
**/game/
|
||||
|
||||
## V Rising
|
||||
**/persistent-data/
|
||||
**/server-data/
|
||||
|
||||
# tar files
|
||||
*.tar
|
||||
|
||||
# SFTP for moving mod files
|
||||
**/sftp/
|
||||
|
||||
@@ -0,0 +1,40 @@
|
||||
FROM rust:1.85.0-alpine3.20 AS builder
|
||||
|
||||
ARG ANKI_VERSION
|
||||
|
||||
RUN apk update && apk add --no-cache build-base protobuf && rm -rf /var/cache/apk/*
|
||||
|
||||
RUN cargo install --git https://github.com/ankitects/anki.git \
|
||||
--tag ${ANKI_VERSION} \
|
||||
--root /anki-server \
|
||||
--locked \
|
||||
anki-sync-server
|
||||
|
||||
FROM alpine:3.21.0
|
||||
|
||||
# Default PUID and PGID values (can be overridden at runtime). Use these to
|
||||
# ensure the files on the volume have the permissions you need.
|
||||
ENV PUID=1000
|
||||
ENV PGID=1000
|
||||
|
||||
COPY --from=builder /anki-server/bin/anki-sync-server /usr/local/bin/anki-sync-server
|
||||
|
||||
RUN apk update && apk add --no-cache bash su-exec && rm -rf /var/cache/apk/*
|
||||
|
||||
|
||||
EXPOSE 8080
|
||||
|
||||
COPY entrypoint.sh /entrypoint.sh
|
||||
RUN chmod +x /entrypoint.sh
|
||||
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
CMD ["anki-sync-server"]
|
||||
|
||||
# This health check will work for Anki versions 24.08.x and newer.
|
||||
# For older versions, it may incorrectly report an unhealthy status, which should not be the case.
|
||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||
CMD wget -qO- http://127.0.0.1:8080/health || exit 1
|
||||
|
||||
VOLUME /anki_data
|
||||
|
||||
LABEL maintainer="Jean Khawand <jk@jeankhawand.com>"
|
||||
@@ -0,0 +1,32 @@
|
||||
networks:
|
||||
default:
|
||||
name: traefik_default
|
||||
external: true
|
||||
|
||||
services:
|
||||
anki-syncserver:
|
||||
container_name: anki-syncserver
|
||||
build:
|
||||
dockerfile: Dockerfile
|
||||
args:
|
||||
- ANKI_VERSION=25.09
|
||||
env_file: live.env
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "8080:8080"
|
||||
environment:
|
||||
- SYNC_USER1=${USER_NAME}:${USER_PASSWORD}
|
||||
volumes:
|
||||
- ./data:/anki-sync-server-data
|
||||
labels:
|
||||
# Watchtower
|
||||
- "com.centurylinklabs.watchtower.enable=true"
|
||||
# Routes
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.anki.entrypoints=websecure"
|
||||
- "traefik.http.routers.anki.rule=Host(`anki.${DOMAIN}`)"
|
||||
- "traefik.http.routers.anki.tls=true"
|
||||
- "traefik.http.routers.anki.tls.certresolver=myresolver"
|
||||
- "traefik.http.services.anki.loadbalancer.server.port=8080"
|
||||
networks:
|
||||
- default
|
||||
@@ -0,0 +1,30 @@
|
||||
#!/bin/sh
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
set -o pipefail
|
||||
|
||||
# Default PUID and PGID if not provided
|
||||
export PUID=${PUID:-1000}
|
||||
export PGID=${PGID:-1000}
|
||||
|
||||
# These values are fixed and cannot be overwritten from the outside for
|
||||
# convenience and safety reasons
|
||||
export SYNC_PORT=8080
|
||||
export SYNC_BASE=/anki_data
|
||||
|
||||
# Check if group exists, create if not
|
||||
if ! getent group anki-group > /dev/null 2>&1; then
|
||||
addgroup -g "$PGID" anki-group
|
||||
fi
|
||||
|
||||
# Check if user exists, create if not
|
||||
if ! id -u anki > /dev/null 2>&1; then
|
||||
adduser -D -H -u "$PUID" -G anki-group anki
|
||||
fi
|
||||
|
||||
# Fix ownership of mounted volumes
|
||||
mkdir -p /anki_data
|
||||
chown anki:anki-group /anki_data
|
||||
|
||||
# Run the provided command as the `anki` user
|
||||
exec su-exec anki "$@"
|
||||
@@ -0,0 +1,7 @@
|
||||
# Anki Syncserver
|
||||
ANKI_VERSION=25.09
|
||||
USER_NAME=admin
|
||||
USER_PASSWORD=password
|
||||
|
||||
# Traefik
|
||||
DOMAIN=sporada.eu
|
||||
@@ -0,0 +1,3 @@
|
||||
# must be ended with a new line "LF" (Unix) and not "CRLF" (Windows)
|
||||
@hourly occ preview:pre-generate
|
||||
# An empty line is required at the end of this file for a valid cron file.
|
||||
@@ -0,0 +1,54 @@
|
||||
networks:
|
||||
default:
|
||||
name: traefik_default
|
||||
external: true
|
||||
|
||||
services:
|
||||
ollama:
|
||||
container_name: ollama
|
||||
restart: unless-stopped
|
||||
image: ollama/ollama:latest
|
||||
labels:
|
||||
# Watchtower
|
||||
- "com.centurylinklabs.watchtower.enable=true"
|
||||
# Traefik
|
||||
# - "traefik.enable=true"
|
||||
# - "traefik.http.routers.ollama.rule=Host(`ollama.${DOMAIN}`)"
|
||||
# - "traefik.http.routers.ollama.entrypoints=websecure"
|
||||
# - "traefik.http.routers.ollama.tls.certresolver=myresolver"
|
||||
# - "traefik.http.routers.ollama.tls=true"
|
||||
# - "traefik.http.services.ollama.loadbalancer.server.port=11434"
|
||||
# Basic auth
|
||||
# - "traefik.http.middlewares.test-auth.basicauth.users=${OLLAMA_USER}:${OLLAMA_PASSWORD_HASH}"
|
||||
|
||||
networks:
|
||||
- default
|
||||
volumes:
|
||||
- "./ollama/ollama:/root/.ollama"
|
||||
|
||||
ollama-webui:
|
||||
image: ghcr.io/open-webui/open-webui:main
|
||||
container_name: ollama-webui
|
||||
volumes:
|
||||
- ./ollama/ollama-webui:/app/backend/data
|
||||
depends_on:
|
||||
- ollama
|
||||
environment:
|
||||
- OLLAMA_BASE_URLS=http://ollama:11434
|
||||
- ENV=prod
|
||||
- WEBUI_AUTH=True
|
||||
- ENABLE_LOGIN_FORM=True
|
||||
- WEBUI_NAME=${WEBUI_NAME}
|
||||
- WEBUI_URL=https://chat.${DOMAIN}
|
||||
- WEBUI_SECRET_KEY=${SECRET}
|
||||
extra_hosts:
|
||||
- host.docker.internal:host-gateway
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- default
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.chat.rule=Host(`chat.${DOMAIN}`)"
|
||||
- "traefik.http.routers.chat.entrypoints=websecure"
|
||||
- "traefik.http.routers.chat.tls.certresolver=myresolver"
|
||||
- "traefik.http.services.chat.loadbalancer.server.port=8080"
|
||||
@@ -0,0 +1,2 @@
|
||||
# Traefik
|
||||
DOMAIN=domain.com
|
||||
@@ -0,0 +1,16 @@
|
||||
services:
|
||||
sons-of-the-forest-dedicated-server:
|
||||
container_name: sons-of-the-forest-dedicated-server
|
||||
image: jammsen/sons-of-the-forest-dedicated-server:latest
|
||||
restart: always
|
||||
environment:
|
||||
PUID: 1000
|
||||
PGID: 1000
|
||||
ALWAYS_UPDATE_ON_START: true
|
||||
SKIP_NETWORK_ACCESSIBILITY_TEST: true
|
||||
ports:
|
||||
- 8766:8766/udp
|
||||
- 27016:27016/udp
|
||||
- 9700:9700/udp
|
||||
volumes:
|
||||
- ./game:/sonsoftheforest
|
||||
@@ -75,7 +75,7 @@ services:
|
||||
WATCHTOWER_NO_STARTUP_MESSAGE: "false"
|
||||
WATCHTOWER_SCHEDULE: "0 30 12 * * *" # Everyday at 12:30
|
||||
DOCKER_HOST: tcp://socket-proxy:2375
|
||||
image: containrrr/watchtower:latest
|
||||
image: nickfedor/watchtower:latest
|
||||
labels:
|
||||
- "com.centurylinklabs.watchtower.enable=true"
|
||||
networks:
|
||||
|
||||
@@ -0,0 +1,22 @@
|
||||
services:
|
||||
vrising:
|
||||
image: trueosiris/vrising
|
||||
environment:
|
||||
- TZ=Europe/Paris
|
||||
- SERVERNAME=vrising-TrueOsiris
|
||||
volumes:
|
||||
- type: bind
|
||||
source: ./server-data
|
||||
target: /mnt/vrising/server
|
||||
bind:
|
||||
create_host_path: true
|
||||
- type: bind
|
||||
source: ./persistent-data
|
||||
target: /mnt/vrising/persistentdata
|
||||
bind:
|
||||
create_host_path: true
|
||||
ports:
|
||||
- '9876:9876/udp'
|
||||
- '9877:9877/udp'
|
||||
restart: unless-stopped
|
||||
network_mode: bridge
|
||||
Reference in New Issue
Block a user