Joey Hafner
97e4cc547a
1. homelab [Gitea](https://gitea.jafner.tools/Jafner/homelab), [Github (docker_config)](https://github.com/Jafner/docker_config), [Github (wiki)](https://github.com/Jafner/wiki), [Github (cloud_tools)](https://github.com/Jafner/cloud_tools), [Github (self-hosting)](https://github.com/Jafner/self-hosting). - Rename? Jafner.net? Wouldn't that be `Jafner/Jafner.net/Jafner.net`? 2. Jafner.dev [Github](https://github.com/Jafner/Jafner.dev). 3. dotfiles [Gitea](https://gitea.jafner.tools/Jafner/dotfiles), [Github](https://github.com/Jafner/dotfiles). 4. nvgm [Gitea](https://gitea.jafner.tools/Jafner/nvgm) 5. pamidi [Gitea](https://gitea.jafner.tools/Jafner/pamidi), [Github](https://github.com/Jafner/pamidi) 6. docker-llm-amd [Gitea](https://gitea.jafner.tools/Jafner/docker-llm-amd) 7. doradash [Gitea](https://gitea.jafner.tools/Jafner/doradash) 8. clip-it-and-ship-it [Gitea (PyClipIt)](https://gitea.jafner.tools/Jafner/PyClipIt), [Github](https://github.com/Jafner/clip-it-and-ship-it). 9. razer battery led [Github](https://github.com/Jafner/Razer-BatteryLevelRGB) 10. 5etools-docker [Github](https://github.com/Jafner/5etools-docker) 11. jafner-homebrew [Github](https://github.com/Jafner/jafner-homebrew) |
||
---|---|---|
.. | ||
config | ||
scripts | ||
barbarian-wait-online.service | ||
fstab.txt | ||
host.env | ||
hosts.txt | ||
inxi.txt | ||
MDADM.md | ||
NUT.md | ||
README.md | ||
SHUTDOWN.md | ||
STARTUP.md |
Server
General-purpose server hosting a variety of Docker-based application stacks.
This server exists behind the jafner.net DDNS record.
Services
This server runs a bunch of stuff behind the jafner.net
domain.
For a living portal listing all user-facing services, go to https://home.jafner.net
This repository is automatically pushed to the host when a change is made to a file in this subdirectory.
Startup Procedure
- Make sure all configured network shares are mounted.
sudo mount -a
- Start infrastructure stacks.
cd ~/homelab/jafner-net/config/traefik && docker-compose up -d
cd ~/homelab/jafner-net/config/keycloak && docker-compose up -d
cd ~/homelab/jafner-net/config/ddns && docker-compose up -d
cd ~/homelab/jafner-net/config/monitoring && docker-compose up -d
- Check running containers.
docker ps
- Start application stacks.
for service in /home/joey/homelab/jafner-net/config/*; do echo "===== STARTING $service =====" && cd $service && docker-compose up -d; done
Sharing Files
For files smaller than 2 GB, use XBackBone.
For files greater than 2 GB, use one of the following:
- Mega - For transfers up to 400 GB
- SFTP - For transfers up to the free space of
/mnt/md0/sftp
- BitTorrent
System /etc/fstab
//joey-nas/media /mnt/nas/media cifs user=user,pass=resu,uid=1000,gid=1000,_netdev,vers=3.0 0 0
//joey-nas/Text/Calibre /mnt/nas/calibre cifs user=user,pass=resu,uid=1000,gid=1000,_netdev,vers=3.0 0 0
//joey-nas/torrenting /mnt/nas/torrenting cifs user=user,pass=resu,uid=1000,gid=1000,_netdev,vers=3.0 0 0
//joey-nas/backups /mnt/nas/backups cifs user=user,pass=resu,uid=1000,gid=1000,_netdev,vers=3.0 0 0
/dev/md0 /mnt/md0 ext4 defaults,nofail,discard 0 0
Boilerplates
Below are useful boilerplate files for configuring new services.
.env
## Generic
TZ=America/Los_Angeles # used by most images
PUID=1000 # used by LSIO images
PGID=1000 # used by LSIO images
ADMIN_EMAIL=joey@jafner.net
## Container volume mapping
DOCKER_DATA=/home/joey/data/<service>
# DOCKER_DATA=/mnt/md0/<service> # for services whose internal data may be large (e.g. modded minecraft servers with large world files)
DOCKER_CONFIG=/home/joey/homelab/jafner-net/config/<service>/config
## Additional volume mapping
MEDIA_DIR=/mnt/nas/media
VIDEO_DIR=/mnt/nas/media/Video
MOVIE_DIR=/mnt/nas/media/Video/Movies
SHOWS_DIR=/mnt/nas/media/Video/Shows
BOOKS_DIR=/mnt/nas/calibre
MUSIC_DIR=/mnt/nas/media/Audio/Music
DOWNLOAD_DIR=/mnt/nas/torrenting/<service|tracker> # e.g. /mnt/nas/torrenting/GGN or /mnt/nas/torrenting/jdownloader2
## SMTP Config
SMTP_HOST=smtp.gmail.com
SMTP_PORT=465
SMTP_USER=noreply@jafner.net
SMTP_PASS=
SMTP_SSL=true
SMTP_TLS=false
## Configure client to use SSL, not TLS
Web App docker-compose.yml
version: '3'
services:
<service>:
image:
container_name: <stack>_<service>
logging:
driver: loki
options:
loki-url: http://localhost:3100/loki/api/v1/push
loki-batch-size: "50"
loki-retries: "1"
loki-timeout: "2s"
keep-file: "true"
user: "1000:1000"
restart: "no"
environment:
PUID: ${PUID}
PGID: ${PGID}
volumes:
- ${DOCKER_DATA}/<service>:/path/to/data
labels:
- traefik.http.routers.<service>.rule=Host(`<service>.jafner.net`)
- traefik.http.routers.<service>.tls.certresolver=lets-encrypt
- traefik.http.routers.<service>.middlewares=<middlewares> # available middlewares are available in homelab/jafner-net/config/traefik/config/middlewares.yaml
- traefik.http.services.<service>.loadbalancer.server.port=<port>
networks:
- web
- <service>
depends_on:
- <service>_db
<service>_db:
image:
container_name: <service>_db
user: "1000:1000"
restart: "no"
networks:
- <service>
environment:
PUID: ${PUID}
PGID: ${PGID}
volumes:
- ${DOCKER_DATA}/db:/var/lib/mysql
labels:
- traefik.enable=false
networks:
web:
external: true
<service>: