Sanitized mirror from private repository - 2026-03-29 13:33:25 UTC
This commit is contained in:
203
docs/services/individual/mattermost.md
Normal file
203
docs/services/individual/mattermost.md
Normal file
@@ -0,0 +1,203 @@
|
||||
# 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
|
||||
```bash
|
||||
# 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
|
||||
```yaml
|
||||
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
|
||||
|
||||
### Recommended Resources
|
||||
- **Minimum RAM**: 512MB
|
||||
- **Recommended RAM**: 1GB+
|
||||
- **CPU**: 1 core minimum
|
||||
- **Storage**: Varies by usage
|
||||
|
||||
### Resource Monitoring
|
||||
Monitor resource usage with:
|
||||
```bash
|
||||
docker stats
|
||||
```
|
||||
|
||||
## 🔍 Health Monitoring
|
||||
|
||||
⚠️ No health check configured
|
||||
Consider adding a health check:
|
||||
```yaml
|
||||
healthcheck:
|
||||
test: ["CMD", "curl", "-f", "http://localhost:PORT/health"]
|
||||
interval: 30s
|
||||
timeout: 10s
|
||||
retries: 3
|
||||
```
|
||||
|
||||
### Manual Health Checks
|
||||
```bash
|
||||
# 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
|
||||
```bash
|
||||
# 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](https://hub.docker.com/r/mattermost/mattermost-team-edition:latest)
|
||||
- **Community Forums**: Search for community discussions and solutions
|
||||
- **GitHub Issues**: Check the project's GitHub for known issues
|
||||
|
||||
## 🔗 Related Services
|
||||
|
||||
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`
|
||||
Reference in New Issue
Block a user