IT - TOOLS
Handy tools for developers
Barcode Reader
Barcode generator
GTIN Validator
QR Code decoder
QR Code generator
QR Contact Info generator
WiFi QR Code generator
Bash Cheatsheet
CSS Selectors Cheatsheet
Common Regex Cheatsheet
Docker Cheatsheet
Docker Compose cheatsheet
Docker SWARM cheatsheet
Dockerfile cheatsheet
Git Semantic Commit Cheatsheet
Git cheatsheet
JSONPath Syntax Cheatsheet
Jq Cheatsheet
K8s Cheatsheet
Markdown Cheat Sheet
Nano CheatSheet
Nginx Cheatsheet
Regex cheatsheet
Sed cheatsheet
VIM Cheatsheet
XPath Syntax Cheatsheet
Base64 Hex array encoder/decoder
Base64 file converter
Base64 string encoder/decoder
Csv to Data
Data Storage Unit converter
Email normalizer
Energy Consumption and Expense Computer
Env Variables Format Converter
Excel to data
Integer base converter
Many Units Converter
Properties converter
Roman numeral converter
Text to UTF-8 binary
Text to Unicode
Torrent to Magnet
ULID generator
Unicode Characters to Java Entities Converter
AGE Cryptography
Ansible vault crypt decrypt
Bcrypt
CRC calculator
CSR Generator
Certificate/Key parser
ECDSA key pair generator
Ed25519 key pair generator
Encrypt / decrypt text
File Hasher
Hash text
Hmac generator
JWT Generator
JWT parser
Niceware Bytes to Passphrase
PGP encryption
PGP keygen
Paseto/PASERK Local
Paseto/PASERK Public/Private
RSA encryption
RSA key pair generator
RSA/DSA/ECDSA Signer and Verifier
SSL Certificate converter
X509 certificate generator
BMI Calculator
Credit Card Checker
Credit Card Number Generator
Currency Converter
IBAN validator and parser
IES Lighting Guidelines
ISBN Validator and Parser
ISO 3166 Country Codes Searcher
Luhn Validator
Phone parser and formatter
RMB Uppercase Converter
SLA calculator
Software licence compatibility
Unicode Search
VAT Numbers Validator
Chronometer
Countdown
Cron/Weekday Alarm
Date+Durations Calculator
Date-time converter
Days Calculator
Duration Calculator
ETA calculator
ICAL File Parser
ICAL Generator
TTL calculator
Time Alarm
Timezone Converter
Week Numbers Converter
Which Day?
iCal Merger
dBm mW Converter
ANSI Escape Tester
API Tester
Cli command editor
Code/Scripts Highlighter
Curl Converter
Data Faker
Database Connection String Builder
Django Secret Generator
Favicon Generator
HEX File Converter
Javascript Prettifier
Javascript Unobfuscator/Unpacker
Json to Protobuf
Json to SQL INSERT
Json to Typescript
Mailto Generator
Open graph meta generator
Pomodoro Timer
Quote Converter
SQL Minifier
SQL Parameters Generator
SQL prettify and format
Stacktrace prettier
String Escaper
Swagger UI tester
Docker Compose Format Converter
Docker Compose Validator
Docker Compose to Docker run converter
Docker Compose to Quadlets
Docker compose to kubernetes
Docker inspect to Docker run
Docker run to Docker compose converter
Docker run to Quadlets
Docker run to kubernetes
Traefik Docker Compose Maker
ActiveDirectory LDAP properties searcher
Bounce Email Parser
Cookies Parser
DMARC Report Analyzer
Email Parser
File Type Detector
Floating point number converter
GZip/Deflate converter
Hex Encoder/Decoder
Keycode info
MIME Encoding Converter
Middle-Endian Converter
MongoDB ObjectId Converter
Outlook MSG Parser
Outlook Safelink decoder
Parquet files Reader
Resistor Calculator
SMART Raw Converter
Sensitive data masker
Sharepoint Share Url Decoder
Snowflake ID extractor
TCPDump Generator
Text Charset Detector/Decoder
URL parser
Card Picker
Coin Flipper
Dice Roller
Fortune wheel
BIP39 passphrase generator
Diceware Password Generator
NanoIDs generator
Numeronym generator
OTP code generator
Passphrase Generator
Pin Code Generator
Random numbers generator
Token generator
UUID converter
UUIDs generator
Camera recorder
HEIC Converter
ICO/PNG converter
Image Color Inverter
Image Comparer
Image EXIF/Metadata/GPS/JPEG Quality reader
Image Formats Converter
Image resizer
Image to SVG (potrace)
OCRize image and PDF
Remove EXIF
Watermarker
CSV to JSON
JS to JSON converter
JSON Editor
JSON Flattener/Unflattener
JSON Linter
JSON Merger
JSON diff
JSON minify
JSON prettify and format
JSON sort master
JSON to C#
JSON to CSV
JSON to Data
JSON to Go
JSON to JS converter
JSON to Java Entity
JSON to TOML
JSON to TS
JSON to XML
JSON to YAML converter
JSON to object
Jq/JSONPath Tester
Json Escaper/Unescaper
Json Query
Json Size Analyzer
Json string converter
Json to PHP Code
Json to PHP-Array
Json to Python
Json to SQL DDL
Json to Schema
PHP-Array to JSON
Html to markdown
Markdown Editor
Markdown Table Prettifier
Markdown to DOCX
Markdown to HTML
Markdown toc generator
Paste as Markdown
Math Formats Converter
Math OCR
Math evaluator
Aspect Ratio Calculator
Benchmark builder
Geo distance calculator
Percentage calculator
Apache LogRotate Generator
BIMI DNS Generator
Basic auth generator
Chmod calculator
Crontab generator
Curl Command Generator
DKIM DNS Generator
DMARC DNS Generator
DNS Queries
DNSBL Checker
Data Transfer Rate Calculator
FStab Generator
FW command line generator
HAR Sanitizer
HDD calculator
HTAccess generator
Htpasswd/htaccess generator
IP Geo Location
IP Subnets Exclude Calculator
IPv4 address converter
IPv4 range expander
IPv4 subnet calculator
IPv4-6/IPRange/CIDR in IPRange/CIDR/IPMask
IPv4/6 Range to CIDR(s) Calculator
IPv6 ULA generator
Integers to IPv4/IPv6
Iptables Generator
Ipv4/6 CIDR to IP Range Calculator
Ipv6 address converter
Ipv6 subnet calculator
MAC Address Converter
MAC address generator
MAC address lookup
Microphone Tester
Multi link downloader
My IP Address
Nginx formatter
Option43 generator
Password strength analyser
Port Numbers
Punycode Converter
RAID Calculator
RAID Reliability Calculator
Random port generator
Rsync Generator
SIP Authorization
SPF DNS generator
WPA PSK generator
Websocket tester
Whois Checker
Wireguard Config Generator
X-VR-SpamCause Decoder
ZPOOL RAID calculator
ZPool Cheatsheet
Zxcvbn Password Strength
PDF Text Extractor
PDF signature checker
Pdf Concatener
Pdf Decrypt and Unlock
Pdf Encrypt
Pdf Linearize/FastWeb
Pdf Page Extractor
Angle Units Converter
Area Units Converter
Energy Units Converter
Force Units Converter
Illuminance Converter
Length Units Converter
Mass Units Converter
Power Converter
Pressure Units Converter
Temperature converter
Volume Units Converter
TOML Linter
TOML to JSON
TOML to YAML
AI Prompt Splitter
ASCII Art Text Generator
Case converter
Citation Generator
Distinct Words
Duplicate Lines Finder
Emoji picker
Extract text from HTML
Folder Structure Diagram
Font Compare
GPT Token Encoder/Decoder
GPT Token Estimator
Image to ASCII Art
Keyboard Layout Converter
Levenshtein Calculator
List converter
Lists Comparer
Lorem ipsum generator
Mermaid exporter
Morse Code Converter
Pack files for AI
Regex Tester
Rune converter
Sed Command generator
Smart Text Replacer and Linebreaker
Social Link Sharer
String obfuscator
Text Translator
Text diff
Text statistics
Text to NATO alphabet
Text to Unicode Names
Unicode Formatter
Unicode to GSM-7
CSS XPath Converter
Color Contrast Checker
Color Wheel
Color converter
Css prettifier
Device information
Encode/decode url formatted strings
Escape HTML entities
HTML Minifier
HTML WYSIWYG editor
HTTP status codes
Html Prettifier
Html cleaner
Image to CSS
MIME types
REM Pixel converter
SVG placeholder generator
Slugify string
UTM Url Generator
Url Cleaner
Url Fanger
Url Text Search Fragment Maker
User-agent parser
XML Linter
XML formatter
XML to JSON
XPath Tester
XSLT tester
YAML Flattener/Unflattener
YAML Merger
YAML prettify and format
YAML to JSON converter
YAML to TOML
IT-Tools v2025.10.19
© 2025 Khuong Dev
English
عربي
Dansk
Deutsch
English
Español
Français
Gaeilge
Italiano
한국인
Nederlands
Norwegian
Polski
Português
Русский
Türkçe
Українська
Tiếng Việt
中文
Buy me a coffee

Docker Compose cheatsheet

Docker Compose format cheatsheet

Docker Compose is a powerful tool for defining and running multi-container Docker applications. It uses a YAML file (compose.yaml) to configure application services, networks, volumes, and more. This file allows developers to declaratively describe infrastructure and dependencies, making it easier to manage complex environments.

Whether you’re building a local dev stack or deploying to production, Compose simplifies orchestration and keeps your configuration readable and version-controlled.

📁 File Name

compose.yaml

✅ YAML Formatting Rules

  • Use 2 spaces for indentation (not tabs)
  • Keys and values are case-sensitive
  • Lists use - for each item
  • Strings with special characters should be quoted
  • Environment variables can be defined inline or via .env files

🧱 Basic Structure

services:
  service_name:
    image: image_name:tag
    build:
      context: .
      dockerfile: Dockerfile
    ports:
      - "host_port:container_port"
    volumes:
      - ./host_path:/container_path
    environment:
      - VAR_NAME=value
    depends_on:
      - other_service
    networks:
      - custom_network
networks:
  custom_network:
    driver: bridge
volumes:
  custom_volume:

⚙️ Services

Each service defines a container.

Common Service Options

services:
  web:
    image: nginx:latest
    build:
      context: ./app
      dockerfile: Dockerfile
    command: ["nginx", "-g", "daemon off;"]
    container_name: custom_name
    ports:
      - "8080:80"
    expose:
      - "80"
    environment:
      - DEBUG=true
    env_file:
      - .env
    volumes:
      - ./data:/data
    restart: always
    depends_on:
      - db
    networks:
      - frontend
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost"]
      interval: 30s
      timeout: 10s
      retries: 5

🏗️ Build Options

build:
  context: ./dir
  dockerfile: Dockerfile
  args:
    build_arg: value
  target: build-stage
  • build: Tells Compose how to build the image.
    • context: is the directory containing the Dockerfile and source code.
    • dockerfile: lets you specify a custom Dockerfile name or path.

📦 Volumes

volumes:
  data_volume:
    driver: local
    driver_opts:
      type: none
      device: /path/on/host
      o: bind

Mounting Volumes

volumes:
  - data_volume:/app/data
  - ./local:/container/path
  • volumes: Mounts host directories or named volumes into the container.
    • ./src:/app/src mounts the local src folder into the container at /app/src.

🌐 Networks

networks:
  frontend:
    driver: bridge
  backend:
    driver: overlay
  • networks: Connects the service to one or more custom networks. Enables service discovery and isolation.

Assigning Networks to Services

services:
  app:
    networks:
      - frontend
      - backend

🌐 Ports

    ports:
      - "3000:3000"
  • ports: Maps container ports to host ports. Format is "host:container". Useful for exposing services to your local machine.

🔐 Secrets (Docker Swarm only)

secrets:
  db_password:
    file: ./db_password.txt

services:
  db:
    secrets:
      - db_password

🔑 Configs (Docker Swarm only)

configs:
  my_config:
    file: ./config.txt

services:
  app:
    configs:
      - source: my_config
        target: /etc/config.txt

🧪 Healthcheck

healthcheck:
  test: ["CMD", "curl", "-f", "http://localhost"]
  interval: 30s
  timeout: 10s
  retries: 3
  start_period: 5s
  • healthcheck: Defines how Docker checks if the container is healthy.
    • test: is the command to run
    • interval: how often to run the check
    • timeout: how long to wait for a response
    • retries: how many failures before marking unhealthy

🔄 Restart Policies

restart: no         # Never restart
restart: always     # Always restart
restart: on-failure # Restart on failure
restart: unless-stopped

🧬 Environment Variables

environment:
  - VAR1=value1
  - VAR2=value2
env_file:
  - .env
  • environment: Sets environment variables inside the container. Useful for configuration.
  • env_file: Loads environment variables from a file. Keeps secrets and config separate from the Compose file.

Command

    command: npm start
  • command: Overrides the default command defined in the Dockerfile. Useful for customizing container behavior.

Dependencies

    depends_on:
      - db
  • depends_on: Specifies service startup order. In Compose, this does not wait for the service to be “ready”—just started.

🧹 Clean Up

docker compose down         # Stop and remove containers, networks, volumes
docker compose down -v      # Also remove named volumes

🚀 Commands

CommandDescription
docker compose upStart services
docker compose up -dStart in detached mode
docker compose downStop and remove services
docker compose buildBuild images
docker compose psList containers
docker compose logsView logs
docker compose exec <service> <cmd>Run command in container
docker compose configValidate and view config

🧠 Mounting GPU / iGPU

Docker Compose supports GPU access via the device_requests field (Compose v3.8+ and Docker 19.03+).

✅ NVIDIA GPU Example

services:
  gpu-app:
    image: nvidia/cuda:11.0-base
    deploy:
      resources:
        reservations:
          devices:
            - driver: nvidia
              count: all
              capabilities: [gpu]

✅ Intel iGPU (via VAAPI or OpenCL)

services:
  igpu-app:
    image: intel/openvino
    devices:
      - /dev/dri:/dev/dri

🔧 Make sure your host has the necessary drivers and runtime (e.g., NVIDIA Container Toolkit or Intel Media SDK).

🔄 Compose vs Swarm YAML Differences

FeatureDocker Compose (compose.yaml)Docker Swarm (stack.yml)
restart✅ Supported❌ Not supported
depends_on✅ Supported❌ Not supported
deploy❌ Ignored✅ Required for replicas
build✅ Supported❌ Not supported
volumes (bind)✅ Supported✅ Supported
configs/secrets❌ Ignored✅ Supported
healthcheck✅ Supported✅ Supported

🧠 Tip: Use compose.yaml for local development and stack.yml for Swarm deployments.

🧬 Profiles (Compose v3.9+)

Profiles allow conditional inclusion of services based on the active profile. This is useful for separating dev/test/staging environments.

✅ Defining Profiles

services:
  web:
    image: nginx
    profiles:
      - default

  debug:
    image: busybox
    command: top
    profiles:
      - debug

✅ Activating Profiles

docker compose --profile debug up

✅ Notes

  • Services without a profiles key are always included.
  • Multiple profiles can be activated simultaneously.
  • Useful for feature toggles, optional services, or environment-specific setups.

⚔️ YAML Differences: Docker Compose vs Docker Swarm Mode

Docker Compose and Docker Swarm both use YAML files to define services, but they serve different purposes and support different features. Compose is optimized for local development and testing, while Swarm is designed for production-grade orchestration across clusters.

🧭 Purpose

ModeUse Case
ComposeLocal development, testing
SwarmCluster deployment, scaling

🧩 Key Differences in YAML Structure

FeatureCompose (compose.yaml)Swarm (stack.yml)
build:✅ Supported❌ Ignored
restart:✅ Supported❌ Ignored
depends_on:✅ Supported❌ Ignored
deploy:❌ Ignored✅ Required for scaling, placement
configs:❌ Ignored✅ Supported
secrets:❌ Ignored✅ Supported
healthcheck:✅ Supported✅ Supported
volumes: (bind)✅ Supported✅ Supported
networks:✅ Supported✅ Supported
profiles:✅ Supported (v3.9+)❌ Not supported

🔧 Compose-Only Features

These features are useful for local development but are ignored in Swarm:

build:

services:
  app:
    build:
      context: .
      dockerfile: Dockerfile
  • Compose builds images locally.
  • Swarm requires pre-built images pushed to a registry.

restart:

restart: unless-stopped
  • Compose uses this to auto-restart containers.
  • Swarm uses deploy.restart_policy instead.

depends_on:

depends_on:
  - db
  • Compose starts services in order.
  • Swarm ignores this; use healthchecks and wait-for-it scripts.

🛡️ Swarm-Only Features

These features are exclusive to Swarm and ignored by Compose:

deploy:

services:
  app:
    deploy:
      replicas: 3
      placement:
        constraints:
          - node.role == manager
      restart_policy:
        condition: on-failure
  • Controls scaling, placement, and restart behavior in a cluster.

configs: and secrets:

configs:
  app_config:
    file: ./config.yml

secrets:
  db_password:
    file: ./password.txt
  • Used to securely distribute configuration and secrets across nodes.

placement: (inside deploy)

placement:
  constraints:
    - node.labels.env == production
  • Assigns services to specific nodes based on labels.

🧪 Healthchecks (Supported in Both)

healthcheck:
  test: ["CMD", "curl", "-f", "http://localhost"]
  interval: 30s
  timeout: 10s
  retries: 3
  • Works in both Compose and Swarm.
  • In Swarm, health status can influence service rescheduling.

📦 Volume Differences

TypeComposeSwarm
Bind mount✅✅
Named volume✅✅
External volume✅✅
Volume driver options✅✅

Swarm requires external volumes to be pre-created on all nodes.

🧠 Summary

Feature CategoryComposeSwarm
Local builds✅❌
Cluster scaling❌✅
Secrets/configs❌✅
Profiles✅❌
Restart policies✅✅ (via deploy)
Service dependencies✅❌

🧭 Tip: Use compose.yaml for development and stack.yml for Swarm. You can split your configuration into multiple files or use tools like kompose to convert Kubernetes manifests.

📚 Resources

  • Compose File Reference
  • Docker CLI Reference
  • NVIDIA GPU Support
  • Intel GPU Support