docker-compose.yml 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. version: "3"
  2. services:
  3. dns-server:
  4. container_name: dns-server
  5. hostname: dns-server
  6. image: technitium/dns-server:latest
  7. # For DHCP deployments, use "host" network mode and remove all the port mappings, including the ports array by commenting them
  8. # network_mode: "host"
  9. ports:
  10. - "5380:5380/tcp" #DNS web console (HTTP)
  11. # - "53443:53443/tcp" #DNS web console (HTTPS)
  12. - "53:53/udp" #DNS service
  13. - "53:53/tcp" #DNS service
  14. # - "853:853/udp" #DNS-over-QUIC service
  15. # - "853:853/tcp" #DNS-over-TLS service
  16. # - "443:443/udp" #DNS-over-HTTPS service (HTTP/3)
  17. # - "443:443/tcp" #DNS-over-HTTPS service (HTTP/1.1, HTTP/2)
  18. # - "80:80/tcp" #DNS-over-HTTP service (use with reverse proxy or certbot certificate renewal)
  19. # - "8053:8053/tcp" #DNS-over-HTTP service (use with reverse proxy)
  20. # - "67:67/udp" #DHCP service
  21. environment:
  22. - DNS_SERVER_DOMAIN=dns-server #The primary domain name used by this DNS Server to identify itself.
  23. # - DNS_SERVER_ADMIN_PASSWORD=password #DNS web console admin user password.
  24. # - DNS_SERVER_ADMIN_PASSWORD_FILE=password.txt #The path to a file that contains a plain text password for the DNS web console admin user.
  25. # - DNS_SERVER_PREFER_IPV6=false #DNS Server will use IPv6 for querying whenever possible with this option enabled.
  26. # - DNS_SERVER_OPTIONAL_PROTOCOL_DNS_OVER_HTTP=false #Enables DNS server optional protocol DNS-over-HTTP on TCP port 8053 to be used with a TLS terminating reverse proxy like nginx.
  27. # - DNS_SERVER_RECURSION=AllowOnlyForPrivateNetworks #Recursion options: Allow, Deny, AllowOnlyForPrivateNetworks, UseSpecifiedNetworks.
  28. # - DNS_SERVER_RECURSION_DENIED_NETWORKS=1.1.1.0/24 #Comma separated list of IP addresses or network addresses to deny recursion. Valid only for `UseSpecifiedNetworks` recursion option.
  29. # - DNS_SERVER_RECURSION_ALLOWED_NETWORKS=127.0.0.1, 192.168.1.0/24 #Comma separated list of IP addresses or network addresses to allow recursion. Valid only for `UseSpecifiedNetworks` recursion option.
  30. # - DNS_SERVER_ENABLE_BLOCKING=false #Sets the DNS server to block domain names using Blocked Zone and Block List Zone.
  31. # - DNS_SERVER_ALLOW_TXT_BLOCKING_REPORT=false #Specifies if the DNS Server should respond with TXT records containing a blocked domain report for TXT type requests.
  32. # - DNS_SERVER_BLOCK_LIST_URLS= #A comma separated list of block list URLs.
  33. # - DNS_SERVER_FORWARDERS=1.1.1.1, 8.8.8.8 #Comma separated list of forwarder addresses.
  34. # - DNS_SERVER_FORWARDER_PROTOCOL=Tcp #Forwarder protocol options: Udp, Tcp, Tls, Https, HttpsJson.
  35. # - DNS_SERVER_LOG_USING_LOCAL_TIME=true #Enable this option to use local time instead of UTC for logging.
  36. volumes:
  37. - config:/etc/dns
  38. restart: unless-stopped
  39. sysctls:
  40. - net.ipv4.ip_local_port_range=1024 65000
  41. volumes:
  42. config: