云原生 | 企业内使用 CoreDNS 构建高性能、插件化的DNS服务器
设为「️ 星标」带你从基础入门 到 全栈实践 再到 放弃学习!
涉及 网络安全运维、应用开发、物联网IOT、学习路径 、个人感悟 等知识分享。
希望各位看友多多支持【关注、点赞、评论、收藏、投币】,助力每一个梦想。
【WeiyiGeek Blog's - 花开堪折直须折,莫待无花空折枝 】
作者主页: 【 https://weiyigeek.top 】
博客地址: 【 https://blog.weiyigeek.top 】
作者答疑学习交流群:欢迎各位志同道合的朋友一起学习交流【点击 加入交流群】, 或者关注公众号回复【学习交流群】。
首发地址: https://mp.weixin.qq.com/s/hAMvwSqWfCQmGM_XzeqOOQ
0X00 前言简述
在企业高可用DNS架构部署方案中我们使用的是传统老牌DNS软件Bind, 但是现在不少企业内部流行容器化部署,所以也可以将Bind替换为 CoreDNS ,由于 CoreDNS 是 Kubernetes 的一个重要组件,稳定性不必担心,于此同时还可将K8S集群SVC解析加入到企业内部的私有的CoreDNS中。
CoreDNS 介绍
什么是CoreDNS?
CoreDNS 由 Go 语言编写是一个高度可扩展和灵活的(
插件式
) DNS 服务器,可以在多平台环境上运行,来自Cloud Native Computing Foundation
(云原生基金会)的开源毕业项目,它的设计目标是易于使用且具有强大的功能。
除此之外,CoreDNS与其他DNS服务器不同,例如(所有优秀的)BIND
,Knot
,PowerDNS
和 Unbound
(技术上是一个解析器,但仍然值得一提)因为它非常灵活,几乎所有功能都外包到插件中,插件可以是独立的,也可以协同工作以执行“DNS功能”,这使得 CoreDNS
不仅可以用作传统的 DNS 服务器,还可以用作服务发现、负载均衡和其他用途。
coredns 官方文档:https://coredns.io/manual/toc/
coredns 发布版本: https://github.com/coredns/coredns/releases/
那么什么是“DNS功能”呢?
CoreDNS 其目的是易于使用且具有强大的功能,我们将其定义为一个软件实现 CoreDNS 插件 API, 实现的功能可能会大相径庭,有本身不会创建响应(例如指标或缓存)但会添加功能的插件,然后有一些插件确实会生成一个回应。这些也可以做任何事情:有与 Kubernetes 通信以提供服务发现的插件,从中读取数据的插件 文件或数据库。
CoreDNS 核心特点
插件架构(Plugins):通过插件,可以轻松扩展 CoreDNS 的功能。插件可以用于处理 DNS 请求、转发请求、缓存结果、记录日志等。插件的使用和配置都非常简单。
性能和可靠性:CoreDNS 使用 Go 语言编写,具有很高的性能。同时,它具有自动重试、健康检查和负载均衡等功能,以确保 DNS 服务的可靠性。
易于配置:CoreDNS 使用名为 Caddyfile 的配置文件格式,这种格式简单易懂,易于编写和维护。
Kubernetes 集成:CoreDNS 可以与 Kubernetes 集成,作为集群内的 DNS 服务器。自 Kubernetes 1.11 版本起,CoreDNS 成为 Kubernetes 的默认 DNS 服务器,替代了之前的 kube-dns。
其实从功能角度来看,CoreDNS 更像是一个通用 DNS 方案(类似于 BIND),然后通过插件模式来极大地扩展自身功能,从而可以适用于不同的场景(比如 Kubernetes)。正如官方博客所说:CoreDNS is powered by plugins.
0x01 安装部署
1.编译方式安装
$ git clone -b v1.11.1 https://github.com/coredns/coredns
$ cd coredns
$ make
# 如果本地没有go环境,可以使用docker 的go镜像进行编译
$ docker run --rm -i -t -v $PWD:/v -w /v golang:1.21 make
2.二进制方式安装
# 指定最新版本
COREDNS_VERSION="1.11.1"
# 官方下载
wget -O /tmp/coredns_${COREDNS_VERSION}_linux_amd64.tgz https://github.com/coredns/coredns/releases/download/v${COREDNS_VERSION}/coredns_${COREDNS_VERSION}_linux_amd64.tgz
# 代理下载
wget -O /tmp/coredns_${COREDNS_VERSION}_linux_amd64.tgz https://ghproxy.com/https://github.com/coredns/coredns/releases/download/v${COREDNS_VERSION}/coredns_${COREDNS_VERSION}_linux_amd64.tgz
# 解压
tar xf /tmp/coredns_${COREDNS_VERSION}_linux_amd64.tgz -C /usr/local/bin
# 软连接设置
ln -s /usr/local/bin/coredns /usr/bin/coredns
3.部署配置&验证
Step 1.为了安全,此处为 coredns 服务创建独立用户,以及使用systemd
管理此服务。
# 添加独立用户
useradd coredns -s /sbin/nologin
# 创建配置目录文件及权限
mkdir -vp /etc/coredns/
touch /etc/coredns/Corefile
chown -R coredns /etc/coredns/Corefile
# 创建systemd服务管理清单
tee -a /usr/lib/systemd/system/coredns.service <<'EOF'
[Unit]
Description=CoreDNS DNS server
Documentation=https://coredns.io
After=network.target
[Service]
LimitNOFILE=1048576
LimitNPROC=512
CapabilityBoundingSet=CAP_NET_BIND_SERVICE
AmbientCapabilities=CAP_NET_BIND_SERVICE
PermissionsStartOnly=true
NoNewPrivileges=true
WorkingDirectory=/etc/coredns
User=coredns
ExecStart=/usr/bin/coredns -conf=/etc/coredns/Corefile
ExecReload=/bin/kill -SIGUSR1 $MAINPID
Restart=on-failure
[Install]
WantedBy=multi-user.target
EOF
# Reload systemd manager configuration
systemctl daemon-reload
# Auto Start Configuration
systemctl enable coredns
Step 2.设置防火墙规则,以及创建生成coredns服务所需使用的配置文件。
# 设置防火墙允许DNS服务53端口网络通行
firewall-cmd --permanent --add-service=dns
firewall-cmd --reload
# 使用 host 插件配置一个简单解析
tee -a /etc/coredns/Corefile <<'EOF'
.:53 {
# 绑定所有接口
bind 0.0.0.0
# hosts 插件: https://coredns.io/plugins/hosts/
hosts {
# 自定义 weiyigeek.top 子域名解析
# 因为解析的域名少我们这里直接用hosts插件即可完成需求
# 如果有大量自定义域名解析那么建议用file插件使用 符合RFC 1035规范的DNS解析配置文件
192.168.1.2 www.weiyigeek.top
192.168.1.3 blog.weiyigeek.top
192.168.1.250 gitlab.weiyigeek.top
192.168.1.251 harbor.weiyigeek.top
# ttl
ttl 60
# 重载hosts配置
reload 1m
# 继续执行
fallthrough
}
# file enables serving zone data from an RFC 1035-style master file.
# 最后所有的都转发到系统配置的上游dns服务器去解析
forward . 223.6.6.6
# 缓存时间ttl
cache 120
# 自动加载配置文件的间隔时间
reload 6s
# 输出日志
log
# 输出错误
errors
}
EOF
# 启动并查看coredns服务
systemctl start coredns && systemctl status coredns
# 查看监听端口服务
lsof -i :53
# COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
# coredns 4548 coredns 7u IPv6 36174 0t0 TCP *:domain (LISTEN)
# coredns 4548 coredns 8u IPv6 36176 0t0 UDP *:domain
Step 3.简单测试部署的Coredns服务是否正常工作。
- 在 Windows 中使用 nslookup 工具解析指定子域名
# 配置在coredns中的子域解析
[weiyigeek@localhost] C:\Users\WeiyiGeek $ nslookup -qt=a gitlab.weiyigeek.top 10.20.176.120
服务器: UnKnown
Address: 10.20.176.120
名称: gitlab.weiyigeek.top
Address: 192.168.1.250
# coredns 不存在的子域解析将转发给上游DNS服务器解析
[weiyigeek@localhost] C:\Users\WeiyiGeek $ nslookup -qt=a api.weiyigeek.top 10.20.176.120
服务器: UnKnown
Address: 10.20.176.120
非权威应答:
名称: api.weiyigeek.top
Address: 82.156.18.253
- 在 Linux (redhat/centos/kylinos) 中 dig 工具解析指定子域名
dnf install bind-utils -y
dig harbor.weiyigeek.top @10.20.176.120
dig api.weiyigeek.top @10.20.176.120
0x02 CoreDNS 配置说明
描述: 通常情况下,一个典型的 Corefile 格式如下所示:
# ZONE : 定义 server 负责的 zone,PORT 是可选项,默认为 53;
ZONE:[PORT] {
# PLUGIN : 定义 server 所要加载的 plugin, 并且每个 plugin 可以有多个参数;
[PLUGIN] ...
}
例如,设置根域 .
的解析以及自定义域名的正向与反向解析。
# 根域, 监听 53 端口
.:53 {
# whoami 插件:返回解析器的本地 IP 地址、端口和传输,且请求结束时下一个插件将不会被调用。
whoami
# .....
}
# 定义 Server Zone (正向解析)
weiyigeek.top {
whoami
# 可使用 host 或者 file 方法指定解析记录。
file db.weiyigeek.top
}
# 同一个 server 但是负责不同 zone 的解析,有不同插件链。
weiyigeek.cn {
whoami
# 使用 host 或者 file 方法指定解析记录。
host db.weiyigeek.top
}
# 定义 Reverse Zone (反向解析 IP 地址对应的域名)
# 方式1
0.0.10.in-addr.arpa {
whoami
}
# 方式2
10.0.0.0/24 {
whoami
}
# CoreDNS 除了支持 DNS 协议,也支持 TLS 和 gRPC,即 DNS-over-TLS[3] 和 DNS-over-gRPC 模式
tls://example.org:1443 {
#...
}
示例演示:
假若,CoreDNS 的 Corefile 配置文件的内容如下所示:
coredns.io:5300 {
file db.coredns.io
}
example.io:53 {
log
errors
file db.example.io
}
example.net:53 {
file db.example.net
}
.:53 {
kubernetes
proxy . 8.8.8.8
log
health
errors
cache
}
从配置文件来看,我们定义了两个 server(尽管有 4 个区块),分别监听在 5300 和 53 端口, 每个进入到某个 server 的请求将按照 plugin.cfg 定义顺序执行其已经加载的插件。
其逻辑图可如下所示, 从图中我们需要注意尽管在 .:53 配置了 health 插件,但是它并为在上面的逻辑图中出现,其原因是,该插件并未参与请求相关的逻辑(即并没有在插件链上),只是修改了 server 配置。
一般地,我们可以将插件分为两种:Normal 插件
(参与请求相关的逻辑,且插入到插件链中) 和 Other 插件
(不参与请求相关的逻辑,也不出现在插件链中,只是用于修改 server 的配置, 例如 health,tls
等插件.)
0x03 CoreDNS 插件说明
插件分类
描述: coredns官方对于插件的分类基本可以分为三种:Plugins
(默认)、External Plugins
和其他
,其中Plugins一般都会被默认编译到coredns的预编译版本中,而External Plugins
则不会,官方的文档对外部插件的定义有着明确的解释,主要要求大概是有用、高效、符合标准、文档齐全、通过测试等。
官方插件帮助文档: https://coredns.io/plugins/
通过官方的二进制部署的coredns
可使用--plugins
参数验证可用的coredns
插件,
$ coredns -plugins
Server types:
dns
Caddyfile loaders:
flag
default
Other plugins:
dns.acl
dns.any
dns.auto
dns.autopath
dns.azure
dns.bind
dns.bufsize
dns.cache
dns.cancel
dns.chaos
dns.clouddns
dns.debug
dns.dns64
dns.dnssec
dns.dnstap
dns.erratic
dns.errors
dns.etcd
dns.file
dns.forward
dns.geoip
dns.grpc
dns.header
dns.health
dns.hosts
dns.k8s_external
dns.kubernetes
dns.loadbalance
dns.local
dns.log
dns.loop
dns.metadata
dns.minimal
dns.nsid
dns.pprof
dns.prometheus
dns.ready
dns.reload
dns.rewrite
dns.root
dns.route53
dns.secondary
dns.sign
dns.template
dns.timeouts
dns.tls
dns.trace
dns.transfer
dns.tsig
dns.view
dns.whoami
on
温馨提示: 若所需的插件不存在,请自行下载插件源码
到cordns源码的plugin目录
,然后在plugin.cfg
文件中添加下载的插件名称例如etcd:etcd
,又或者直接指定Github中的插件地址他会自行下载,例如 dump:github.com/miekg/dump
,最后手动编译coredns源码。
# plugin.cfg
.....
# 对于在plugin目录下已经存在的插件,则可以直接写成plugin中的目录名:
sign:sign
# 对于在plugin目录下不存在的插件
dump:github.com/miekg/dump
# 需提前准备Golang环境
$ git clone -b v1.11.1 https://github.com/coredns/coredns
$ cd coredns
$ go get github.com/miekg/dump
$ go generate
$ go build && make
插件工作模式
描述: 当 CoreDNS 启动后,它将根据配置文件启动不同 server ,每台 server 都拥有自己的插件链。当有 DNS 请求时,它将依次经历如下 3 步逻辑:
- 如果有当前请求的 server 有多个 zone,将采用贪心原则选择最匹配的 zone;
- 一旦找到匹配的 server,按照
plugin.cfg
定义的顺序执行插件链上的插件; - 每个插件将判断当前请求是否应该处理,将有以下几种可能:
- 请求被当前插件处理 : 插件将生成对应的响应并回给客户端,此时请求结束,下一个插件将不会被调用,如
whoami
插件; - 请求被当前插件以 Fallthrough 形式处理 : 如果请求在该插件处理过程中有可能将跳转至下一个插件,该过程称为 fallthrough,并以关键字
fallthrough
来决定是否允许此项操作,例如host
插件,当查询域名未位于 /etc/hosts,则调用下一个插件; - 请求在处理过程被携带 Hint : 请求被插件处理,并在其响应中添加了某些信息(hint)后继续交由下一个插件处理。这些额外的信息将组成对客户端的最终响应,如
metric
插件
- 请求被当前插件处理 : 插件将生成对应的响应并回给客户端,此时请求结束,下一个插件将不会被调用,如
常用插件介绍
host 插件
描述: 此对于为文件中的区域提供服务很有用,但是仅支持 A、AAAA 和 PTR 记录,如果要在主机插件中没有匹配项的情况下将请求传递给插件链的其余部分,则必须指定该fallthrough
选项,请注意每个块{}
只能使用一次此插件。
插件参考: https://coredns.io/plugins/hosts/
温馨提示: 反向查找的 PTR 记录由 CoreDNS 自动生成(基于hosts文件条目)
语法参数:
hosts [FILE [ZONES...]] {
# 条目的形式基于 IETF RFC 952 格式
# IP_address canonical_hostname [aliases...]
[INLINE]
# 生成的记录的 DNS TTL,默认 3600s
ttl SECONDS
# 重载时间,若为0s表示不重载
reload DURATION
# 禁用生成反向解析
no_reverse
# 如果区域匹配并且无法生成任何记录,请将请求传递给下一个插件。
fallthrough [ZONES...]
}
示例演示:
示例1.少量不同域名解析直接写在 Corefile 配置文件中
.:53 {
# 绑定interface ip
bind 127.0.0.1
# 先走本机的hosts
hosts {
# 因为解析的域名少我们这里直接用hosts插件即可完成需求
192.168.1.2 www.weiyigeek.top weiyigeek.top
192.168.1.3 blog.weiyigeek.top
# ttl
ttl 60
# 重载hosts配置
reload 1m
# 继续执行
fallthrough
}
# file enables serving zone data from an RFC 1035-style master file.
# 最后所有的都转发到系统配置的上游dns服务器去解析
forward . /etc/resolv.conf
# 缓存时间ttl
cache 120
# 自动加载配置文件的间隔时间
reload 6s
# 输出日志
log
# 输出错误
errors
}
示例2.将解析写在独立的/etc/coredns/hosts
文件中,也可以写在 /etc/hosts
看个人喜好。
tee /etc/coredns/Corefile <<'EOF'
.:53 {
bind 10.20.176.120
hosts /etc/coredns/hosts
# 未配置解析的将转发到上游服务器。
forward . 8.8.8.8:53
# 缓存时间ttl
cache 120
# 自动加载配置文件的间隔时间
reload 6s
# 输出日志
log
# 输出错误
errors
}
EOF
tee /etc/coredns/hosts <<'EOF'
# weiyigeek.com
192.168.1.2 www.weiyigeek.com
192.168.1.3 blog.weiyigeek.com
# weiyigeek.top
192.168.1.250 gitlab.weiyigeek.top
192.168.1.251 harbor.weiyigeek.top
EOF
修改配置文件后重启coredns以便于验证解析:
[weiyigeek@localhost] C:\Users\WeiyiGeek $ nslookup -qt=a www.weiyigeek.com 10.20.176.120
服务器: UnKnown
Address: 10.20.176.120
名称: www.weiyigeek.com
Address: 192.168.1.2
[weiyigeek@localhost] C:\Users\WeiyiGeek $ nslookup -qt=a harbor.weiyigeek.top 10.20.176.120
服务器: UnKnown
Address: 10.20.176.120
名称: harbor.weiyigeek.top
file 插件 (常用)
描述: 如果有大量自定义域名记录解析那么则建议使用file
插件,配置需要符合RFC 1035
规范的DNS解析配置文件,如果区域文件包含签名(即,使用 DNSSEC),返回正确的 DNSSEC 答案
语法参数
# DBFILE : 要读取和分析的数据库文件
# ZONES:它应该是权威的, 若为空则配置块中的区域被使用。
file DBFILE [ZONES...] {
# 在 SOA 版本更改时执行区域重新加载的时间间隔
reload DURATION
}
示例演示:
示例1.使用file插件创建内部域名的正向以及反向解析。
tee /etc/coredns/Corefile <<'EOF'
.:53 {
forward . 223.6.6.6:53 114.114.114.114:53 /etc/resolv.conf # 上面etcd未查询到的请求转发给设置的DNS服务器解析
# 启用缓存,保持正高速缓存大小 5000 和 负高速缓存大小 2500.
cache {
success 5000
denial 2500
}
log
errors
}
# 正向解析
weiyigeek.top {
file /etc/coredns/weiyigeek.top.conf
forward . 223.6.6.6:53
log
errors
}
# 反向解析
20.10.in-addr.arpa {
file /etc/coredns/db.20.10.conf
log
errors
}
EOF
# 正向解析配置文件,符合 RFC 1035 标准格式
tee /etc/coredns/weiyigeek.top.conf <<'EOF'
$TTL 86400
$ORIGIN weiyigeek.top.
@ 3600 IN SOA dns1.weiyigeek.top. master.weiyigeek.top. (
20210313 ; Serial
50400 ; Refresh
86400 ; Retry
604800 ; Expire
86400 ) ; Negative Cache TTL
;
; name servers - NS records
@ IN NS dns1
dns1 IN A 10.20.176.120
; root server - A records
@ IN A 192.168.10.71
; child server records
www IN A 192.168.10.71
blog IN A 192.168.10.70
EOF
tee /etc/coredns/db.20.10.conf <<'EOF'
$TTL 86400
@ 3600 IN SOA 20.10.in-addr.arpa. master.weiyigeek.top. (
20210313 ; Serial
50400 ; Refresh
86400 ; Retry
604800 ; Expire
86400 ) ; Negative Cache TTL
;
; name servers - NS records
@ IN NS dns1.weiyigeek.top.
; PTR Records
120.176 IN PTR dns1.weiyigeek.top.
EOF
重启cordns服务验证服务: systemctl restart coredns && sleep 6 &&systemctl status coredns
$ nslookup -qt=a weiyigeek.top 10.20.176.120
$ nslookup -qt=ns weiyigeek.top 10.20.176.120
$ nslookup -qt=ptr weiyigeek.top 10.20.176.120
执行结果:
etcd 插件
描述: 使用etcd插件我们可以将解析存入到etcd的解析记录进行读取,它可以实现了DNS服务发现,但是它不适合作为一个通用的DNS区域数据插件, 只实现了DNS记录类型的一个子集。
语法示例
etcd [ZONES...] {
fallthrough [ZONES...]
path PATH
endpoint ENDPOINT...
credentials USERNAME PASSWORD
tls CERT KEY CACERT
stubzones
}
# 参数解析
fallthrough: 如果区域匹配但没有记录可以生成,将请求传递给下一个插件
path: etcd中的路径,默认值/skydns
endpoint: etcd endpoint
credentials: etcd的用户名和密码
tls: CA
stubzones 启用存根区域功能
示例演示:
.:53 {
forward . 223.6.6.6
}
weiyigeek.local {
file weiyigeek.local {
reload 30s
}
}
etcd-weiyigeek.local:53 {
etcd {
stubzones # 启用存根区域功能,stubzone仅在位于指定的第一个区域下方的etcd树中完成
path /root
endpoint http://172.22.50.98:2379 # 此处根据自己部署的etcd地址进行填写。
fallthrough # 如果区域匹配但不能生成记录,则将请求传递给下一个插件
}
forward . 8.8.8.8:53 8.8.4.4:53 /etc/resolv.conf # 上面etcd未查询到的请求转发给设置的DNS服务器解析
cache 160
loadbalance # 开启DNS记录轮询策略
log # 打印日志
}
使用 etcd 插件利用目录结构查询相关条目,已上面的 etcd-weiyigeek.local
为例,配置的etcd的path为/root
。
# etcd-weiyigeek.local 的 A 记录 为 172.22.50.28
$./etcdctl put /root/local/etcd-weiyigeek/ '{"host":"172.22.50.28","ttl":60}'
# demo1.etcd-weiyigeek.local 的 A 记录 为 172.22.50.128
$./etcdctl put /root/local/etcd-weiyigeek/demo1 '{"host":"172.22.50.128","ttl":60}'
# demo2.etcd-weiyigeek.local 的 A 记录 为 172.22.50.228
$./etcdctl put /root/local/etcd-weiyigeek/demo2 '{"host":"172.22.50.228","ttl":60}'
kubernetes 插件
描述: kubernetes 插件允许从kubernetes集群读取区域数据, 插件地址: https://coredns.io/plugins/kubernetes/
语法参数:
kubernetes [ZONES...] {
endpoint URL
tls CERT KEY CACERT
kubeconfig KUBECONFIG [CONTEXT]
namespaces NAMESPACE...
labels EXPRESSION
pods POD-MODE
endpoint_pod_names
ttl TTL
noendpoints
fallthrough [ZONES...]
ignore empty_service
}
示例演示:
在 K8S 集群中的 Pod 内的 DNS 域名解析配置文件为 /etc/resolv.conf
,文件内容如下所示。
#定义 DNS 服务器的 IP 地址。
nameserver xx.xx.0.10
# 设置域名的查找后缀规则,查找配置越多,说明域名解析查找匹配次数越多。
# Kubernetes 集群匹配有 kube-system.svc.cluster.local、svc.cluster.local、cluster.local 3 个后缀,最多进行 8 次查询才能得到正确解析结果。
search kube-system.svc.cluster.local svc.cluster.local cluster.local
#定义域名解析配置文件选项,例如该参数设置成 ndots:5,说明如果访问的域名字符串内的点字符数量超过 ndots 值,则认为是完整域名,并被直接解析;如果不足 ndots 值,则追加 search 段后缀再进行查询。
options ndots:5
CoreDNS 配置:
$ kubectl get cm -n kube-system coredns -o yaml
.....
Corefile: |
.:53 {
errors # 输出错误信息,若需调试请设置为debug
log # 输出客户端请求解析信息
health { # 健康检查配置
lameduck 15s # 关闭延迟时间
}
ready # CoreDNS 插件,一般用来做可读性检查,可以通过 http://localhost:8181/ready 读取。
# CoreDNS Kubernetes 插件,提供集群内服务解析能力。
kubernetes {{.ClusterDomain}} in-addr.arpa ip6.arpa {
pods verified
fallthrough in-addr.arpa ip6.arpa
}
# 添加自定义 hosts。
hosts {
192.168.1.41 www.weiyigeek.top
192.168.1.40 harbor.weiyigeek.top
fallthrough in-addr.arpa ip6.arpa
}
prometheus :9153 # CoreDNS 自身 metrics 数据接口。
# 当域名不在 Kubernetes 域时,将请求转发到预定义的解析器。
forward . /etc/resolv.conf {
max_concurrent 1000
}
cache 30 # DNS 查询缓存。
loop #环路检测,如果检测到环路,则停止 CoreDNS。
reload #允许自动重新加载已更改的 Corefile, 编辑 ConfigMap 配置后,请等待两分钟以使更改生效。
loadbalance #循环 DNS 负载均衡器,可以在答案中随机 A、AAAA、MX 记录的顺序。
}
dnssec 插件
描述: DNSSEC 支持对服务的数据进行动态 DNSSEC 签名,每个服务器块只能使用此插件一次。
插件地址: https://coredns.io/plugins/dnssec/
语法参数:
dnssec [ZONES... ] {
# 指定读取的Key文件
key file KEY...
# 使用缓存来存储 RRSIGs,缺省值为 10000
cache_capacity CAPACITY
}
示例演示:
$ mkdir -vp /etc/coredns/dnssec && cd /etc/coredns/dnssec
# 使用 dnssec-keygen 工具生成密钥文件
$ dnssec-keygen -a ECDSAP256SHA256 -f KSK weiyigeek.top
Generating key pair.
# 生成的密钥的基本名称
Kweiyigeek.top.+013+29388
# 生成的 public key 与 private key
$ ls
Kweiyigeek.top.+013+29388.key Kweiyigeek.top.+013+29388.private
# 配置文件 Corefile 示例
$ cat /etc/coredns/Corefile
.:53 {
forward . 223.6.6.6:53
log
errors
}
# 正向解析
weiyigeek.top {
file /etc/coredns/db.weiyigeek.top.conf
dnssec {
key file /etc/coredns/dnssec/Kweiyigeek.top.+013+29388.key
}
log
errors
}
知识扩展: 使用dnssec-keygen
生成DNSSEC密钥对,您需要按照以下步骤操作:
- 打开命令行工具,并确保您的计算机上已经安装了BIND软件包,该软件包通常包含在DNS服务器软件包中。
- 运行以下命令来生成DNSSEC密钥对:
dnssec-keygen -a <algorithm> -b <bits> -n <type> -f KSK/ZSK <domain>
<algorithm>
:选择用于生成密钥对的加密算法,常见的算法有RSA、DSA、ECDSA等。<bits>
:指定密钥的位数,一般为1024、2048、4096等。<type>
:指定密钥的类型,可以是KSK(Key Signing Key)或ZSK(Zone Signing Key)。<domain>
:指定域名,生成的密钥对将与该域名相关联。
- 运行命令后,将会生成两个密钥文件,一个是私钥文件(以".private"结尾),另一个是公钥文件(以".key"结尾)。
请注意,生成的密钥对需要妥善保管,私钥文件应保密,而公钥文件需要添加到您的域名的DNS记录中。接下来,我们将讨论如何将公钥添加到DNS记录中。
sign 插件
描述: sign 插件用于对区域进行签名并 将 DNSSEC 记录添加到区域文件。
插件地址: https://coredns.io/plugins/sign/
语法参数:
# DBFILE 读取和分析的区域数据库文件, 即符合 RFC 1035 标准格式文件
sign DBFILE [ZONES...] {
# 指定用于对区域进行签名的密钥(可以有多个)
key file|directory KEY...|DIR...
# 指定 CoreDNS 应在其中保存已签名区域的 DIR,默认为 /var/lib/coredns 目录(需要自行验证)
directory DIR
}
使用示例:
# 1.使用 dnssec-keygen 生成 KSK 类型的 密钥
$ cd /etc/coredns/dnssec/
$ dnssec-keygen -a ECDSAP256SHA256 -f KSK weiyigeek.top
# Generating key pair.
# Kweiyigeek.top.+013+04352
$ ls
# Kweiyigeek.top.+013+04352.key Kweiyigeek.top.+013+04352.private
# 2.创建已签名区域的 DIR 目录 /var/lib/coredns
mkdir -vp /var/lib/coredns
# 3.Corefile 配置示例文件
$ cat /etc/coredns/Corefile
# 正向解析
weiyigeek.top {
file /etc/coredns/db.weiyigeek.top.conf
sign /etc/coredns/db.weiyigeek.top.conf {
key file /etc/coredns/dnssec/Kweiyigeek.top.+013+29388.key
}
}
# 4.运行后生成的signd文件
cat /var/lib/coredns/db.weiyigeek.top.signed
tsig 插件
描述: tsig 定义 TSIG 密钥,验证传入的 TSIG 签名请求并签署响应。
插件地址: https://coredns.io/plugins/tsig/
温馨提示: 对于 Secondary 主从区域传输暂不支持此插件,希望后续官方完善。
语法参数:
tsig [ZONE...] {
# 显式的设置密钥的名称 以及 TSIG 密钥
secret NAME KEY
# 使用文件方式的加载TSIG 密钥(推荐)
secrets FILE
# 指定用于的查询类型,例如 `AXFR IXFR`
require [QTYPE...]
}
使用示例:
# 1.使用 tsig-keygen 工具生成TSIG 密钥
tsig-keygen -a hmac-sha256 dns-tsig-keygen. > /etc/coredns/dnssec/dns-tsig-keygen.secrets
cat /etc/coredns/dnssec/dns-tsig-keygen.secrets
# key "dns-tsig-keygen." {
# algorithm hmac-sha256;
# secret "ec5onpRjGTIaOBZa+zGl2VJbwdJl1qlzj+NZNHrhhk4=";
# };
# 2.Corefile 配置文件示例
# 要求 TSIG 签名的事务才能发出 AXFR IXFR
weiyigeek.top {
file /etc/coredns/db.weiyigeek.top.conf
tsig {
secrets /etc/coredns/dnssec/dns-tsig-keygen.secrets
require AXFR IXFR
}
transfer {
to *
}
}
# 要求 TSIG 签名的事务才能发出所有请求
auth.zone {
tsig {
secret auth.zone.key. NoTCJU+DMqFWywaPyxSijrDEA/eC3nK0xi3AMEZuPVk=
require all
}
forward . 10.1.0.2
}
原文地址: https://blog.weiyigeek.top
本文至此完毕,更多技术文章,尽情期待下一章节!
专栏书写不易,如果您觉得这个专栏还不错的,请给这篇专栏 【点个赞、投个币、收个藏、关个注,转个发,留个言】(人间六大情),这将对我的肯定,谢谢!。
点击 关注「 全栈工程师修炼指南」公众号
微信沟通交流: weiyigeeker (点击添加)
交流沟通群:629184198 或 关注公众号回复【学习交流群】
温馨提示: 由于作者水平有限,本章错漏缺点在所难免,希望读者批评指正,并请在文章末尾留下您宝贵的经验知识,联系邮箱地址 master@weiyigeek.top 或者关注公众号 WeiyiGeek 联系我。
云原生 | 企业内使用 CoreDNS 构建高性能、插件化的DNS服务器的更多相关文章
- apisix docker镜像构建及插件化开发
高能劝退:lua开发,适合小白看!!! 前段时间有个项目,用的java程序做网关,压测tps只有1k多点,惨不忍睹. 后来公司有个大佬改用apisix做网关,tps飙升到1w多. 于是对神奇的apis ...
- 8.云原生之Docker容器镜像构建最佳实践浅析
转载自:https://www.bilibili.com/read/cv15220861/?from=readlist 本章目录 0x02 Docker 镜像构建最佳实践浅析 1.Dockerfile ...
- 构建高性能插件式Web框架
基于MVC插件模式构建支持数据库集群.数据实时同步.数据发布与订阅的Web框架系统.如下图: 1.基于插件式开发 采用插件模式开发的优点是使得系统框架和业务模式有效地进行分离,系统更新也比较简单,只需 ...
- apisix网关-构建docker镜像构建及插件化开发
高能劝退:lua开发,适合小白看!!! 前段时间有个项目,用的java程序做网关,压测tps只有1k多点,惨不忍睹. 后来公司有个大佬改用apisix做网关,tps飙升到1w多. 于是对神奇的apis ...
- CNCF 宣布成立应用交付领域小组,正式开启云原生应用时代
作者|赵钰莹 作为云原生领域的顶级开源社区, Cloud Native Computing Foundation (云原生基金会,以下简称 CNCF)近日宣布成立 Application Delive ...
- 公有云上构建云原生 AI 平台的探索与实践 - GOTC 技术论坛分享回顾
7 月 9 日,GOTC 2021 全球开源技术峰会上海站与 WAIC 世界人工智能大会共同举办,峰会聚焦 AI 与云原生两大以开源驱动的前沿技术领域,邀请国家级研究机构与顶级互联网公司的一线技术专家 ...
- 云原生应用管理,像管理手机APP一样管理企业应用
我们在使用智能手机的时候,手机APP从应用市场一键安装,安装好即点即用,当有新版本一键升级,如果不想用了长按图标删除,整个过程非常简单,小朋友都能熟练掌握.而对于企业应用,由于结构复杂.可用性要求高. ...
- 分布式云原生平台Kurator v0.2.0正式发布!一键构建分布式云原生平台
摘要:北京时间2023年2月9日,Kurator 正式发布 v0.2.0 版本. 本文分享自华为云社区<分布式云原生平台Kurator v0.2.0正式发布!一键构建分布式云原生平台>,作 ...
- 5大最新云原生镜像构建工具全解析,3个来自Google,你了解几个?
1云原生大背景下的镜像构建在分享开始,我想先跟大家简单聊一下云原生,可能不会详细展开,而是带领大家了解一下云原生对镜像构建方面的影响.第一,在接触云原生相关的技术时,无论是要解决开发.测试环境的问题, ...
- 产品对话 | 愿云原生不再只有Kubernete
从2013年,云原生(Cloud Native)的概念由 Pivotal 的 MattStine 首次提出,到现在,其技术细节不断得到社区的完善.云原生逐渐演变出包括 DevOps.持续交付.微服务. ...
随机推荐
- AcWing 3956. 截断数组
给定一个长度为 n 的数组 a1,a2,-,an. 现在,要将该数组从中间截断,得到三个非空子数组. 要求,三个子数组内各元素之和都相等. 请问,共有多少种不同的截断方法? 输入格式 第一行包含整数 ...
- 记录一些不知道哪里冒出来的 idea(可能已存在)
2022/7/4 给定一张 \(n\) 个点的有权无向图和 \(m\) 个关键点,求其生成树满足每个点到离它最近的关键点的距离之和最小. 输出该生成树边权和. 加强一下: 给出一个 \(N\) 个点 ...
- flutter dio自定义http client
final dio = Dio(); Dio getMyDio() { initAdapter(); dio.options.headers = {'apiKey': 'xxxxx'}; dio.op ...
- .NET周报 【6月第2期 2023-06-11】
国内文章 如何计算一个实例占用多少内存? https://www.cnblogs.com/artech/p/size-calculation.html 我们都知道CPU和内存是程序最为重要的两类指标, ...
- 现代C++学习指南-标准库
在[上一章](https://www.yuque.com/docs/share/adb5b1e4-f3c6-46fd-ba4b-4dabce9b4f2a?# <现代C++学习指南-类型系统> ...
- Mybatis Generator 配置详解
因原版观感不佳,搬运至此. 作者:Jimin 链接:https://www.imooc.com/article/21444 来源:慕课网 <?xml version="1.0" ...
- AcWing 4490. 染色题解
题目描述 样例 输入: 6 1 2 2 1 5 2 1 1 1 1 1 输出 3 算法描述 思路 我们以样例为例讲讲思路. 如何确保dfs能顺利便利呢,我们可以使用链式前向星来存图(树) C++代码 ...
- 【SpringBoot】 集成 Ehcache
SpringBoot ehcache 缓存 简介 EhCache 是一个纯 Java 的进程内缓存框架,具有快速.精干等特点, 是 Hibernate 中默认CacheProvider.Ehcache ...
- 【Springboot】项目启动后执行特定方法
Springboot项目启动后执行特定方法 Springboot给我们提供了两种"开机启动"方式:ApplicationRunner和CommandLineRunner. 这两种方 ...
- 行行AI人才直播第11期:墨尔本大学数据科学高级讲师-宫明明《机器学习:从统计到因果,人工智能的发展之路》
行行AI人才是博客园和顺顺智慧共同运营的AI行业人才全生命周期服务平台. 马克斯·普朗克智能系统中心主任曾在国际数学家大会进行了题为 From Statistical to Causal Learni ...