docker-compose部署coredns如何实现自建DNS服务
作者:学亮编程手记
本文介绍了如何在内网中使用自建的CoreDNS服务进行域名解析,通过配置Corefile和hosts文件,实现内部域名解析,无需在互联网上注册域名,使用docker-compose运行CoreDNS,并通过修改resolv.conf文件配置DNS服务
docker-compose部署coredns实现自建DNS服务
在系统应用中,经常会遇到需要使用 https 域名通讯的需要,在内网中,我们不需要正式在互联网上注册域名,自建一个 dns 服务就能很好的解决问题。
基本应用
本文内网为使用 docker 运行一个 coredns 服务的代码示例:
- docker-compose.yml 片段内容如下:
version: '3.7' services: coredns: image: coredns/coredns:1.10.0 container_name: coredns ports: - 53:53/udp volumes: - ./coredns/Corefile:/Corefile
- 脚本中 Corefile 文件内容如下:
.:53 { hosts { 192.168.1.11 test.com 192.168.1.12 test1.com fallthrough } forward . 8.8.8.8:53 114.114.114.114:53 log }
其中 forward 指向上级 dns 服务
独立hosts文件方式
我们还可以将 hosts 独立出来为一个单独的文件,
- 如下所示:
.:53 { hosts /etc/coredns/hostsfile { fallthrough } forward . 8.8.8.8:53 114.114.114.114:53 log }
其中 /etc/coredns/hostsfile 为内部域名解析映射文件,
- 使用 docker-compose 的话你需要对应挂载出来:
version: '3.7' services: coredns: image: coredns/coredns:1.10.0 container_name: coredns ports: - 53:53/udp volumes: - ./coredns/hostsfile:/etc/coredns/hostsfile - ./coredns/Corefile:/Corefile
- hostsfile 内容示例如下:
192.168.1.11 test.com 192.168.1.12 test1.com
使用
以 Linux 为例,修改配置文件 cat /etc/resolv.conf 设置 nameserver 为运行的这个 dns 服务IP地址即可,
- 如下示例:
[root@localhost /]# cat /etc/resolv.conf # Generated by NetworkManager nameserver 192.168.1.2
保持后就可以使用 nslookup 或者 ping 来验证内部域名解析是否正常了。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。