Files
homelab-optimized/docs/services/individual/mattermost.md
Gitea Mirror Bot fb00a325d1
Some checks failed
Documentation / Build Docusaurus (push) Failing after 5m14s
Documentation / Deploy to GitHub Pages (push) Has been skipped
Sanitized mirror from private repository - 2026-04-18 11:19:59 UTC
2026-04-18 11:19:59 +00:00

5.7 KiB

Mattermost

🟡 Communication Service

📋 Service Overview

Property Value
Service Name mattermost
Host homelab_vm
Category Communication
Difficulty 🟡
Docker Image mattermost/mattermost-team-edition:latest
Compose File homelab_vm/mattermost.yml
Directory homelab_vm

🎯 Purpose

Mattermost is an open-source, self-hostable online chat service with file sharing, search, and integrations.

🚀 Quick Start

Prerequisites

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

Deployment

# Navigate to service directory
cd homelab_vm

# Start the service
docker-compose up -d

# Check service status
docker-compose ps

# View logs
docker-compose logs -f mattermost

🔧 Configuration

Docker Compose Configuration

container_name: mattermost
depends_on:
  mattermost-db:
    condition: service_healthy
environment:
  MM_BLEVESETTINGS_INDEXDIR: /mattermost/bleve-indexes
  MM_SERVICESETTINGS_SITEURL: https://mm.crista.love
  MM_SQLSETTINGS_DATASOURCE: postgres://mattermostuser:changeME-strong@mattermost-db:5432/mattermost?sslmode=disable&connect_timeout=10
  MM_SQLSETTINGS_DRIVERNAME: postgres
  TZ: America/Los_Angeles
hostname: mattermost
image: mattermost/mattermost-team-edition:latest
ports:
- 8065:8065
restart: unless-stopped
security_opt:
- no-new-privileges:true
user: 0:0
volumes:
- /mnt/atlantis_docker/mattermost/config:/mattermost/config:rw
- /mnt/atlantis_docker/mattermost/data:/mattermost/data:rw
- /mnt/atlantis_docker/mattermost/logs:/mattermost/logs:rw
- /mnt/atlantis_docker/mattermost/plugins:/mattermost/plugins:rw
- /mnt/atlantis_docker/mattermost/client:/mattermost/client/plugins:rw
- /mnt/atlantis_docker/mattermost/indexes:/mattermost/bleve-indexes:rw

Environment Variables

Variable Value Description
TZ America/Los_Angeles Timezone setting
MM_SQLSETTINGS_DRIVERNAME postgres Configuration variable
MM_SQLSETTINGS_DATASOURCE postgres://mattermostuser:changeME-strong@mattermost-db:5432/mattermost?sslmode=disable&connect_timeout=10 Configuration variable
MM_BLEVESETTINGS_INDEXDIR /mattermost/bleve-indexes Configuration variable
MM_SERVICESETTINGS_SITEURL https://mm.crista.love Configuration variable

Port Mappings

Host Port Container Port Protocol Purpose
8065 8065 TCP Service port

Volume Mappings

Host Path Container Path Type Purpose
/mnt/atlantis_docker/mattermost/config /mattermost/config bind Configuration files
/mnt/atlantis_docker/mattermost/data /mattermost/data bind Application data
/mnt/atlantis_docker/mattermost/logs /mattermost/logs bind Log files
/mnt/atlantis_docker/mattermost/plugins /mattermost/plugins bind Data storage
/mnt/atlantis_docker/mattermost/client /mattermost/client/plugins bind Data storage
/mnt/atlantis_docker/mattermost/indexes /mattermost/bleve-indexes bind Data storage

🌐 Access Information

Service ports: 8065:8065

🔒 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

⚠️ No health check configured Consider adding a health check:

healthcheck:
  test: ["CMD", "curl", "-f", "http://localhost:PORT/health"]
  interval: 30s
  timeout: 10s
  retries: 3

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 mattermost

# Restart service
docker-compose restart mattermost

# Update service
docker-compose pull mattermost
docker-compose up -d mattermost

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

📚 Additional Resources

  • Official Documentation: Check the official docs for mattermost
  • Docker Hub: mattermost/mattermost-team-edition:latest
  • 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 homelab_vm


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: homelab_vm/mattermost.yml