Files
homelab-optimized/docs/services/individual/mastodon-db.md
Gitea Mirror Bot cf7724c726
Some checks failed
Documentation / Build Docusaurus (push) Failing after 17m44s
Documentation / Deploy to GitHub Pages (push) Has been skipped
Sanitized mirror from private repository - 2026-04-06 09:21:56 UTC
2026-04-06 09:21:56 +00:00

4.2 KiB

Mastodon Db

🔴 Communication Service

📋 Service Overview

Property Value
Service Name mastodon-db
Host Atlantis
Category Communication
Difficulty 🔴
Docker Image postgres
Compose File Atlantis/mastodon.yml
Directory Atlantis

🎯 Purpose

Mastodon is a free and open-source self-hosted social networking service.

🚀 Quick Start

Prerequisites

  • Docker and Docker Compose installed
  • Basic understanding of REDACTED_APP_PASSWORD
  • Access to the host system (Atlantis)

Deployment

# Navigate to service directory
cd Atlantis

# Start the service
docker-compose up -d

# Check service status
docker-compose ps

# View logs
docker-compose logs -f mastodon-db

🔧 Configuration

Docker Compose Configuration

container_name: Mastodon-DB
environment:
  POSTGRES_DB: mastodon
  POSTGRES_PASSWORD: "REDACTED_PASSWORD"
  POSTGRES_USER: mastodonuser
healthcheck:
  interval: 10s
  retries: 10
  test:
  - CMD
  - pg_isready
  - -q
  - -d
  - mastodon
  - -U
  - mastodonuser
  timeout: 45s
hostname: mastodon-db
image: postgres
restart: always
security_opt:
- no-new-privileges:true
user: 1026:100
volumes:
- /volume1/docker/mastodon/db:/var/lib/postgresql/data

Environment Variables

Variable Value Description
POSTGRES_DB mastodon Configuration variable
POSTGRES_USER mastodonuser Configuration variable
POSTGRES_PASSWORD ***MASKED*** PostgreSQL password

Port Mappings

No ports exposed.

Volume Mappings

Host Path Container Path Type Purpose
/volume1/docker/mastodon/db /var/lib/postgresql/data bind Application data

🌐 Access Information

This service does not expose any web interfaces.

🔒 Security Considerations

  • Security options configured
  • Non-root user configured

📊 Resource Requirements

No resource limits configured

  • Minimum RAM: 512MB
  • Recommended RAM: 1GB+
  • CPU: 1 core minimum
  • Storage: Varies by usage

Resource Monitoring

Monitor resource usage with:

docker stats

🔍 Health Monitoring

Health check configured Test Command: CMD pg_isready -q -d mastodon -U mastodonuser Check Interval: 10s Timeout: 45s Retries: 10

Manual Health Checks

# Check container health
docker inspect --format='{{.State.Health.Status}}' CONTAINER_NAME

# View health check logs
docker inspect --format='{{range .State.Health.Log}}{{.Output}}{{end}}' CONTAINER_NAME

🚨 Troubleshooting

Common Issues

Service won't start

  • Check Docker logs: docker-compose logs service-name
  • Verify port availability: netstat -tulpn | grep PORT
  • Check file permissions on mounted volumes

Can't access web interface

  • Verify service is running: docker-compose ps
  • Check firewall settings
  • Confirm correct port mapping

Performance issues

  • Monitor resource usage: docker stats
  • Check available disk space: df -h
  • Review service logs for errors

Useful Commands

# Check service status
docker-compose ps

# View real-time logs
docker-compose logs -f mastodon-db

# Restart service
docker-compose restart mastodon-db

# Update service
docker-compose pull mastodon-db
docker-compose up -d mastodon-db

# Access service shell
docker-compose exec mastodon-db /bin/bash
# or
docker-compose exec mastodon-db /bin/sh

📚 Additional Resources

  • Official Documentation: Check the official docs for mastodon-db
  • Docker Hub: Official mastodon-db
  • Community Forums: Search for community discussions and solutions
  • GitHub Issues: Check the project's GitHub for known issues

Other services in the communication category on Atlantis


This documentation is auto-generated from the Docker Compose configuration. For the most up-to-date information, refer to the official documentation and the actual compose file.

Last Updated: 2025-11-17
Configuration Source: Atlantis/mastodon.yml