89 lines
2.9 KiB
YAML
89 lines
2.9 KiB
YAML
|
|
services:
|
|||
|
|
telemt:
|
|||
|
|
image: whn0thacked/telemt-docker:latest
|
|||
|
|
container_name: telemt
|
|||
|
|
restart: unless-stopped
|
|||
|
|
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
# Root user requirement for binding privileged ports (<1024)
|
|||
|
|
# The default image runs as 'nonroot' to minimize attack vectors.
|
|||
|
|
# Uncomment the line below to run as root ONLY if you need to bind
|
|||
|
|
# to port 443 and encounter 'os error 13'.
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
# user: "root"
|
|||
|
|
|
|||
|
|
# Telemt uses RUST_LOG for verbosity (optional)
|
|||
|
|
environment:
|
|||
|
|
RUST_LOG: "info"
|
|||
|
|
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
# API Configuration writes (Atomic Config Save)
|
|||
|
|
# The API performs atomic writes (creates a .tmp file and renames it).
|
|||
|
|
# To allow the API to save changes to the config, we MUST mount the
|
|||
|
|
# ENTIRE directory (not just the file) and ensure it is writable.
|
|||
|
|
# We override the default command to point to the mounted file.
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
command: ["/etc/telemt/telemt.toml"]
|
|||
|
|
volumes:
|
|||
|
|
- ./telemt-config:/etc/telemt
|
|||
|
|
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
# Host network mode: the container uses the host's network stack
|
|||
|
|
# directly. The "ports" section is IGNORED in this mode — Telemt
|
|||
|
|
# binds to host ports as specified in telemt.toml.
|
|||
|
|
#
|
|||
|
|
# To use Docker-managed port mapping instead, comment out
|
|||
|
|
# "network_mode: host" and uncomment the "ports" section below.
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
#network_mode: host
|
|||
|
|
|
|||
|
|
ports:
|
|||
|
|
- "9443:443/tcp"
|
|||
|
|
# # If you enable metrics_port=9090 in config:
|
|||
|
|
- "127.0.0.1:9090:9090/tcp"
|
|||
|
|
|
|||
|
|
# Hardening
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
# ⚠️ If you uncommented `user: "root"` above to bind to port 443,
|
|||
|
|
# you MUST comment out the two lines below, as they prevent
|
|||
|
|
# gaining the necessary privileges for binding restricted ports.
|
|||
|
|
# ---------------------------------------------------------------
|
|||
|
|
security_opt:
|
|||
|
|
- no-new-privileges:true
|
|||
|
|
cap_drop:
|
|||
|
|
- ALL
|
|||
|
|
cap_add:
|
|||
|
|
- NET_BIND_SERVICE
|
|||
|
|
read_only: true
|
|||
|
|
tmpfs:
|
|||
|
|
- /tmp:rw,nosuid,nodev,noexec,size=16m
|
|||
|
|
|
|||
|
|
# Resource limits (optional)
|
|||
|
|
deploy:
|
|||
|
|
resources:
|
|||
|
|
limits:
|
|||
|
|
cpus: "0.50"
|
|||
|
|
memory: 256M
|
|||
|
|
reservations:
|
|||
|
|
cpus: "0.25"
|
|||
|
|
memory: 128M
|
|||
|
|
|
|||
|
|
# File descriptor limits (critical for a high-load server!)
|
|||
|
|
ulimits:
|
|||
|
|
nofile:
|
|||
|
|
soft: 65536
|
|||
|
|
hard: 65536
|
|||
|
|
|
|||
|
|
logging:
|
|||
|
|
driver: json-file
|
|||
|
|
options:
|
|||
|
|
max-size: "10m"
|
|||
|
|
max-file: "3"
|
|||
|
|
|
|||
|
|
networks:
|
|||
|
|
overlay_net: # Изменено: в старой версии используется дефис, а не прямой ключ
|
|||
|
|
|
|||
|
|
networks:
|
|||
|
|
overlay_net:
|
|||
|
|
external: true
|