news 2026/4/23 16:05:31

麒麟Kylin | CoreDNS部署

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
麒麟Kylin | CoreDNS部署

一、CoreDNS基本概念

1. CoreDNS概述

CoreDNS 是 CNCF(云原生计算基金会)毕业的开源 DNS 服务器,由 Miek Gieben 主导开发,基于 Go 语言实现,是云原生时代 kube-dns 的替代方案,同时也可作为通用 DNS 服务独立部署。其核心设计理念是「插件化、极简配置、云原生原生适配」,既兼容传统 DNS 场景,又能完美适配容器、K8s 等动态环境。

  • 独立运行:作为独立守护进程常驻内存,监听 53 端口(DNS 默认端口),无需依附任何其他服务;
  • 插件化扩展:通过插件实现健康检查、域名重写、缓存、转发等功能,配置极简;
  • 多场景适配:既支持传统内网域名的静态解析,也支持云原生环境的动态服务发现;
  • 热重载:修改配置后无需重启进程,通过信号量即可重载配置,无服务中断。

2. 与传统的DNS软件对比

特性CoreDNSBindUnbound
架构设计插件化、单进程、轻量模块化、多进程、重量级单进程、专注递归、轻量
云原生适配原生支持 K8s/ETCD无原生支持无原生支持
健康检查内置health插件需第三方脚本需第三方工具联动
配置复杂度Corefile 声明式多配置文件专注递归
动态能力插件化动态解析(如 K8s)静态配置为主静态 / 转发为主
热重载原生支持(SIGUSR1 信号支持但配置复杂支持(unbound-control)
资源占用极低(MB 级内存)较高(GB 级内存)低(MB 级)
监控能力内置prometheus插件需额外配置需额外配置

3. CoreDNS核心架构模型

CoreDNS的核心是:「插件链+Corefile配置」。所有功能均通过插件实现,配置文件定义插件的执行顺序和规则。

  • 插件链执行逻辑:请求按Corefile中插件的声明顺序依次执行,插件可决定终止请求(返回结果)或传递给下一个插件。
  • 插件优先级:核心基础插件(如 log/errors)通常放在最前,业务插件(如 hosts/kubernetes)居中,兜底插件(如 forward/rewrite)放在最后。

4. Corefile语法解析

Corefile是CoreDNS的唯一配置文件,采用【域+插件块】的声明式语法,格式极简。

<域名>[:端口] { <插件1>[插件参数] <插件1>[插件参数] ... }

极简配置案例:所有域名监听 53 端口

.:53 { bind 0.0.0.0 # 绑定所有网卡 log # 记录查询日志 hosts { # 静态解析 192.168.1.1 www.meaauf.com } forward . 8.8.8.8 # 未匹配的域名转发到谷歌 DNS cache 60 # 缓存 60 秒 }

5. 基础类插件介绍

插件类核心功能示例
bind指定监听的网卡 / 端口bind 192.168.8.10
log记录所有DNS查询日志,如客户端IP、域名、查询类型、响应状态等log【无需参数】
errors记录解析过程中的错误日志,如域名不存在、后端服务异常errors【无需参数】
cache缓存解析结果,减少重复查询,提升性能cache 60【缓存60秒】
reload支持配置热重载,修改Corefile后自动重载,无需重启进程reload【无需参数】

6. 解析类插件介绍

插件类核心功能示例
hosts静态解析域名hosts { 192.168.1.1 www.meaauf.com;}
forward将域名查询转发到上游DNS服务器forward 114.114.114.114
kubernetesK8s 集群内域名解析kubernets cluster.loacal in-addr.arpa ip6.arpa { pods verified; fallthrough}
file从Zone文件(Bind 格式)读取解析记录,兼容传统DNS配置file /etc/coredns/meaauf.zone

二、CoreDNS部署

1. 二进制方式部署

[Step1]访问CoreDNS的官网或GitHub,下载CoreDNS二进制包。

官网:https://coredns.io GitHub:https://github.com/coredns/coredns/releases

[Step2]将软件包上传到CoreDNS。

[Step3]将coredns解压缩,解压出来的是一个二进制命令。

[root@CoreDNS ~]# tar zxf coredns_1.14.1_linux_amd64.tgz

[Step4]确保coredns命令具备执行权限,将其移动到“/usr/local/bin”目录。

[root@CoreDNS ~]# chmod +x coredns [root@CoreDNS ~]# mv coredns /usr/local/bin/

[Step5]验证:输出coredns的版本号。

[root@CoreDNS ~]# coredns -version

2. Docker方式部署

[Step1]确保本地Docker服务状态正常。

[root@CoreDNS ~]# systemctl status docker.service

[Step2]拉取官方镜像。

[root@CoreDNS ~]# docker pull coredns/coredns:latest

[Step3]临时启动一个 CoreDNS 容器,查看其版本信息,并且容器运行结束后自动删除。

[root@CoreDNS ~]# docker run --rm coredns/coredns -version

三、传统内网静态解析案例配置

1. 节点设置

主机名网络参数系统版本说明
CoreDNS192.168.8.100/24Kylin Linux Advanced Server V11 (Swan25)DNS服务器
Client192.168.8.200/24Kylin Linux Advanced Server V11 (Swan25)测试客户端

2. CoreDNS服务器配置

[Step1]安装coredns,以下使用二进制安装方式。

[root@CoreDNS ~]# coredns -version

[Step2]创建配置文件目录,编写Corefile。

[root@CoreDNS ~]# mkdir /etc/coredns [root@CoreDNS ~]# vim /etc/coredns/Corefile # 写入下列内容 .:53 { bind 192.168.8.100 # 仅监听指定网卡,增强安全性 log # 记录所有 DNS 查询日志 errors # 记录错误日志 reload # 支持配置热重载 # 静态解析域名 hosts { 192.168.8.100 coredns.meaauf.com 192.168.8.101 www.meaauf.com 192.168.8.200 client.meaauf.com } cache 60 # 缓存优化 }

[Step3]启动coredns,同时观察回显日志。

[root@CoreDNS ~]# coredns -conf /etc/coredns/Corefile

3. 客户端验证

[Step1]验证:使用nslookup测试正向解析,该命令需要先安装bind-utils。

[root@client ~]# dnf install -y bind-utils [root@client ~]# nslookup coredns.meaauf.com [root@client ~]# nslookup www.meaauf.com [root@client ~]# nslookup client.meaauf.com

[Step2]验证:使用nslookup测试反向解析。

[root@client ~]# nslookup 192.168.8.100 [root@client ~]# nslookup 192.168.8.101 [root@client ~]# nslookup 192.168.8.200

[Step3]验证:在CoreDNS上查看日志信息,能够看到刚刚的解析记录。

4. 系统服务部署

[Step1]在CoreDNS服务器上创建CoreDNS systemd服务文件。

[root@CoreDNS ~]# vim /etc/systemd/system/coredns.service # 写入下列内容 [Unit] Description=CoreDNS DNS Server Documentation=https://coredns.io After=network.target network-online.target Wants=network-online.target [Service] User=root Group=root ExecStart=/usr/local/bin/coredns -conf /etc/coredns/Corefile Restart=on-failure RestartSec=5s StartLimitInterval=0 StandardOutput=journal StandardError=journal SyslogIdentifier=coredns Nice=-5 [Install] WantedBy=multi-user.target

[Step2]在CoreDNS服务器重新加载systemd配置,启动CoreDNS服务并设置开机自启。

[root@CoreDNS ~]# systemctl daemon-reload [root@CoreDNS ~]# systemctl enable --now coredns.service

四、搭配file模块实现静态解析

1. 节点设置

主机名网络参数系统版本说明
CoreDNS192.168.8.100/24Kylin Linux Advanced Server V11 (Swan25)DNS服务器
Client192.168.8.200/24Kylin Linux Advanced Server V11 (Swan25)测试客户端

2. CoreDNS服务器配置

[Step1]安装coredns,以下使用二进制安装方式。

[Step2]创建配置文件目录,编写Corefile。

[root@CoreDNS ~]# mkdir /etc/coredns [root@CoreDNS ~]# vim /etc/coredns/Corefile # 写入下列内容 .:53 { bind 192.168.8.100 # 仅监听指定网卡,增强安全性 log # 记录所有 DNS 查询日志 errors # 记录错误日志 reload # 支持配置热重载 # 使用file插件加载解析规则,替代hosts file /etc/coredns/zones/meaauf.db cache 60 # 缓存优化 }

[Step3]编写“meaauf.db”文件,类似于Bind的解析文件。

[root@CoreDNS ~]# mkdir /etc/coredns/zones [root@CoreDNS ~]# vim /etc/coredns/zones/meaauf.db # 写入下列内容 $TTL 1D @ IN SOA @ rname.invalid. ( 2026012701 ; serial 1D ; refresh 1H ; retry 1W ; expire 3H ) ; minimum coredns.meaauf.com. IN A 192.168.8.100 www.meaauf.com. IN A 192.168.8.101 client.meaauf.com. IN A 192.168.8.200

[Step4]编写systemd服务文件,编写systemd服务文件的过程省略。启动coredns服务。

[root@CoreDNS ~]# systemctl restart coredns.service

3. 客户端验证

[Step1]验证:使用nslookup测试正向解析,该命令需要先安装bind-utils。

[root@client ~]# dnf install -y bind-utils [root@client ~]# nslookup coredns.meaauf.com [root@client ~]# nslookup www.meaauf.com [root@client ~]# nslookup client.meaauf.com

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 19:23:39

运维自动化场景下Debian与Rocky Linux哪个更易管理?

在运维自动化场景下&#xff0c;Rocky Linux 通常比 Debian 更易管理&#xff0c;但具体选择需结合团队技术栈和场景需求。以下是详细对比&#xff1a; 原文地址&#xff1a;https://blog.phpnode.cn/article/2647 核心对比 维度Rocky LinuxDebian系统定位企业级稳定性优先&a…

作者头像 李华
网站建设 2026/4/17 19:37:46

在吴忠码上羽毛球俱乐部,遇见更好的自己——与韩宁波教练一起,体验科技赋能的专业羽毛球训练

在吴忠码上羽毛球俱乐部里&#xff0c;十几位学员正专注地练习着步伐移动&#xff0c;他们跟随韩宁波教练的示范&#xff0c;像是踩着音乐的节拍跳起一场优雅的羽毛球华尔兹。韩教练手中的球拍仿佛有了生命&#xff0c;每一次挥动都将羽毛球送到学员最舒适的位置&#xff0c;让…

作者头像 李华
网站建设 2026/4/23 14:43:09

农业数据平台如何利用UEDITOR在ELECTRON中导入WORD图表?

企业级Word内容导入解决方案需求分析报告 需求背景 作为广东科技小巨人领军企业的项目负责人&#xff0c;我司在政府、军工、金融等领域承接了大量信息化建设项目。近期多个项目组反馈&#xff0c;客户强烈要求在CMS系统中增加专业级Word内容导入功能&#xff0c;以满足政府公…

作者头像 李华
网站建设 2026/4/23 11:50:22

文件上传漏洞原理

一&#xff0c;文件上传漏洞定义 文件上传漏洞是web系统中常见的一种功能&#xff0c;通过文件上传能实现上传图片、视频&#xff0c;以及其他类型的文件&#xff0c;但是随着web中包含的功能越来越多&#xff0c;潜在的网络安全风险也就越大。 如果恶意用户上传了可执行的文…

作者头像 李华
网站建设 2026/4/23 11:47:48

吐血推荐2026本科生AI论文网站TOP10:开题报告文献综述全测评

吐血推荐2026本科生AI论文网站TOP10&#xff1a;开题报告文献综述全测评 2026年本科生AI论文写作工具测评&#xff1a;为何需要这份榜单&#xff1f; 随着人工智能技术在学术领域的深度应用&#xff0c;越来越多的本科生开始借助AI工具辅助论文写作。然而&#xff0c;面对市场…

作者头像 李华