docker 容器无法解析 dns-server 容器中定义的主机名

docker 容器无法解析 dns-server 容器中定义的主机名

dns 服务器容器

version: "3"
services:
  dns-server:
    container_name: dns-server
    hostname: dns-server
    image: technitium/dns-server:latest
    # For DHCP deployments, use "host" network mode and remove all the port mappings, including the ports array by commenting them
    # network_mode: "host"
    ports:
      - "5380:5380/tcp" #DNS web console (HTTP)
      - "53443:53443/tcp" #DNS web console (HTTPS)
      - "53:53/udp" #DNS service
      - "53:53/tcp" #DNS service
      # - "853:853/udp" #DNS-over-QUIC service
      # - "853:853/tcp" #DNS-over-TLS service
      # - "443:443/udp" #DNS-over-HTTPS service (HTTP/3)
      # - "443:443/tcp" #DNS-over-HTTPS service (HTTP/1.1, HTTP/2)
      # - "80:80/tcp" #DNS-over-HTTP service (use with reverse proxy or certbot certificate renewal)
      # - "8053:8053/tcp" #DNS-over-HTTP service (use with reverse proxy)
      # - "67:67/udp" #DHCP service
    environment:
      - DNS_SERVER_DOMAIN=dns-server #The primary domain name used by this DNS Server to identify itself.
      - DNS_SERVER_ADMIN_PASSWORD=password #DNS web console admin user password.
      # - 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.
      # - DNS_SERVER_PREFER_IPV6=false #DNS Server will use IPv6 for querying whenever possible with this option enabled.
      - DNS_SERVER_WEB_SERVICE_HTTP_PORT=5380 #The TCP port number for the DNS web console over HTTP protocol.
      - DNS_SERVER_WEB_SERVICE_HTTPS_PORT=53443 #The TCP port number for the DNS web console over HTTPS protocol.
      - DNS_SERVER_WEB_SERVICE_ENABLE_HTTPS=true #Enables HTTPS for the DNS web console.
      - DNS_SERVER_WEB_SERVICE_USE_SELF_SIGNED_CERT=false #Enables self signed TLS certificate for the DNS web console.
      # - 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.
      # - DNS_SERVER_RECURSION=AllowOnlyForPrivateNetworks #Recursion options: Allow, Deny, AllowOnlyForPrivateNetworks, UseSpecifiedNetworks.
      # - 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.
      # - 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.
      - DNS_SERVER_ENABLE_BLOCKING=false #Sets the DNS server to block domain names using Blocked Zone and Block List Zone.
      # - 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.
      # - DNS_SERVER_BLOCK_LIST_URLS= #A comma separated list of block list URLs.
      - DNS_SERVER_FORWARDERS=1.1.1.1, 8.8.8.8 #Comma separated list of forwarder addresses.
      # - DNS_SERVER_FORWARDER_PROTOCOL=Tcp #Forwarder protocol options: Udp, Tcp, Tls, Https, HttpsJson.
      - DNS_SERVER_LOG_USING_LOCAL_TIME=true #Enable this option to use local time instead of UTC for logging.
    volumes:
      - config:/etc/dns
    networks:
      - dns-network
    restart: unless-stopped
    sysctls:
      - net.ipv4.ip_local_port_range=1024 65000

volumes:
    config:

networks:
  dns-network:
    name: dns-network
    driver: bridge

gitea 容器

version: "3"

networks:
  gitea-network:
    name: dns-network
    external: true

services:
  server:
    image: gitea/gitea:1.17.3
    container_name: gitea
    environment:
      - USER_UID=1000
      - USER_GID=1000
      - GITEA__database__DB_TYPE=mysql
      - GITEA__database__HOST=db:3306
      - GITEA__database__NAME=gitea
      - GITEA__database__USER=gitea
      - GITEA__database__PASSWD=gitea
    restart: always
    networks:
      - gitea-network
    volumes:
      - ./gitea:/data
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
    ports:
      - "3000:3000"
      - "222:22"
    depends_on:
      - db

  db:
    image: mysql:8
    restart: always
    environment:
      - MYSQL_ROOT_PASSWORD=gitea
      - MYSQL_USER=gitea
      - MYSQL_PASSWORD=gitea
      - MYSQL_DATABASE=gitea
    networks:
      - gitea-network
    volumes:
      - ./mysql:/var/lib/mysql

詹金斯容器

version: '3'

services:
  jenkins:
    image: jenkins/jenkins:lts
    container_name: jenkins
    user: root
    ports:
      - "35000:8080"
    volumes:
      - jenkins_home:/var/jenkins_home
      - /home/david/docker-jenkins/run.sh:/var/jenkins_home/run.sh
      - /home/david/docker-jenkins/ssh-keys:/var/jenkins_home/.ssh
    networks:
      - jenkins-network

networks:
  jenkins-network:
    name: dns-network
    external: true

volumes:
  jenkins_home:

我试过了

  • dns: dns-server
  • dns: 127.0.0.1
  • dns: 192.168.2.170
  • dns: 172.21.0.2(dns 服务器容器 IP)

其次是sudo docker compose down && sudo docker compose up -d

但它从来没有解决jenkins.webdevgitea.webdev192.168.2.170在dns服务器设置

dns 服务器运行正常。

在此处输入图片描述 在此处输入图片描述 在此处输入图片描述

这一切都在 Ubuntu VM 内部,我的 Windows 主机以 192.168.2.170 作为主 DNS,并且可以很好地解析 jenkins.webdev 和 gitea.webdev。

编辑:更新了我的 docker-compose.yml 文件以反映当前状态,我尝试停止所有容器,然后:

  • 在 dns-server 撰写文件中创建网络
networks:
  dns-network:
    name: dns-network
    driver: bridge
  • 将该网络添加到 jenkins 和 gitea 作曲家文件中
networks:
  gitea-network:
    name: dns-network
    external: true

services:
  server:
     networks:
      - gitea-network
  dns: dns-server

仍然不起作用,在 gitea 容器中我可以 ping dns-server,并且显示的 ip 是正确的,但如果我 ping webdev、gitea.webdev 或 jenkins.webdev,我会得到ping: bad address

我可以 pingjenkinsgitea,并且我可以看到本地 IP,但jenkins.webdevgitea.webdev指向我192.168.2.170在 dns-server 中定义的主机 IP 是bad address,如果我尝试使用jenkins或 ,gitea我会得到Delivery: Post "https://jenkins/gitea-webhook/post": dial tcp 172.20.0.5:443: connect: connection refused

相关内容