百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

「干货分享」DNS域名解析服务systemd-resolved使用指南

nanshan 2025-02-15 16:43 21 浏览 0 评论

1.关于DNS解析服务

DNS(Domain Name System),即域名系统。

一句话总结DNS解析服务功能就是,将域名转换为IP地址。

DNS解析服务过程中有如下几个角色参与:

? 待解析的域名

? DNS客户端

? DNS服务器

? 域名对应的IP地址

DNS解析大致过程:

? 用户在应用程序中使用域名

? 应用程序调用DNS客户端申请域名解析

? DNS客户端向DNS服务器发送待解析的域名(本地有解析缓存则不用再请求)

? DNS服务器将解析出的IP地址返回给客户端(服务端可能会缓存DNS解析结果,避免重复查询)

? 应用程序使用域名对应的IP地址(客户端可能会缓存DNS解析结果,加快响应速度)

Windows和Linux系统中都有常用的DNS解析服务,例如Windows中的DNS Client,Linux中的systemd-resolved、BIND等。

而其中systemd-resolved是现代Linux发行版(基于systemd)中最常用的默认DNS解析服务,今天本文将分享systemd-resolved这款DNS解析服务。

2.systemd-resolved 的常用命令

2.1 查看当前systemd-resolved的运行状态

systemctl status systemd-resolved

该服务在基于systemd的系统中是默认开启的,也可以将status字段更换为start或stop来控制该服务的开启和关闭,因为本文主要围绕systemd-resolved展开,所以systemdctl的操作命令不再详细展开。

2.2 查看systemd-resolved的统计信息,在输出中可以查看缓存命中率、缓存大小、DNSSEC 验证情况。

systemd-resolve --statistics

2.3 检查当前DNS配置:

resolvectl status
或
systemd-resolve --status(旧版本兼容)

2.4 清理DNS缓存,systemd-resolved会缓存在内存上,并不进行持久化保存,若缓存过大可以使用该命令清理本地缓存。

systemd-resolve --flush-caches

2.5 手动进行域名解析测试,输出中可以查看解析出来的IP、解析耗时等。

systemd-resolve www.xxx.com

2.6 临时给端口配置DNS服务器,该配置重启会失效,若想永久固定需修改/etc/systemd/resolved.conf等相关配置文件。

resolvectl dns eth0 8.8.8.8

3. systemd-resolved相关配置文件

3.1 /etc/resolv.conf配置文件

/etc/resolv.conf是最表面的DNS配置文件,systemd-resolved执行DNS解析时,会读取该文件来获取DNS服务器IP,从而进行DNS解析。

所以不难看出,/etc/resolv.conf是systemd-resolved服务中最重要的文件,因此/etc/resolv.conf会被多方控制,从而达到配置DNS解析服务的目的。

若用户想要临时配置系统的DNS解析服务器,可以直接修改该文件,写入对应的服务器IP:

nameserver 114.114.114.114
nameserver 8.8.8.8

不过以上修改操作只能是临时的,因为/etc/resolv.conf正常情况下是动态生成的,当查看它的详细信息时会发现是一个软连接,它的状态会随着配置和用户的动作而变化。

lrwxrwxrwx 1 root root 37 Dec ?5 14:24 /etc/resolv.conf -> /run/systemd/resolve/stub-resolv.conf

这里所指向的stub-resolv.conf文件后面再详细解释。

3.2 /etc/systemd/resolved.conf配置文件

该文件是systemd-resolved的主要配置文件,通常用于设置DNS服务器、DNS解析策略等。修改这个文件后,需要重新启动systemd-resolved服务才能生效。

[Resolve]
DNS=8.8.8.8 8.8.4.4 # DNS服务器列表
FallbackDNS=114.114.114.114 ? # 当主要DNS不可用时,使用备用DNS
Domains=example.com ? ? ? ? ? # 域名搜索拓展列表
LLMNR=no ? ? ? ? ? ? ? ? ? ? # LLMNR(本地链路多播名称解析)启用设置
DNSSEC=no ? ? ? ? ? ? ? ? ? ? # 是否启用DNSSEC(域名系统安全扩展)
Cache=yes ? ? ? ? ? ? ? ? ? ? # 启用DNS缓存

3.3 /run/systemd/resolve/stub-resolv.conf和/run/systemd/resolve/resolv.conf配置文件

从3.1中可以发现,/etc/resolv.conf就是指向了/run/systemd/resolve/stub-resolv.conf,所以/etc/resolv.conf同样也能指向/run/systemd/resolve/resolv.conf,也证明这两个文件才是真正的DNS服务器指定文件。

这两个文件实际由systemd-resolved服务直接管理和生成,其中:

/run/systemd/resolve/resolv.conf文件:由systemd-resolved服务生成,其内容由3.2提到的/etc/systemd/resolved.conf配置文件进行指定,如下:

# This file is managed by man:systemd-resolved(8). Do not edit.
#
# This is a dynamic resolv.conf file for connecting local clients directly to
# all known uplink DNS servers. This file lists all configured search domains.
#
# Third party programs must not access this file directly, but only through the
# symlink at /etc/resolv.conf. To manage man:resolv.conf(5) in a different way,
# replace this symlink by a static file or a different symlink.
#
# See man:systemd-resolved.service(8) for details about the supported modes of
# operation for /etc/resolv.conf.
nameserver 8.8.8.8
nameserver 8.8.4.4
search example.com

/run/systemd/resolve/stub-resolv.conf文件:由systemd-resolved服务生成,配置使用DNS stub解析器,这种情况下应用程序不会与systemd-resolved直接通信,而是由stub解析器转发,一般情况下应用程序只需要向127.0.0.53查询即可,由stub解析器转发给systemd-resolved,避免了紧耦合:

# This file is managed by man:systemd-resolved(8). Do not edit.
#
# This is a dynamic resolv.conf file for connecting local clients to the
# internal DNS stub resolver of systemd-resolved. This file lists all
# configured search domains.
#
# Run "resolvectl status" to see details about the uplink DNS servers
# currently in use.
#
# Third party programs must not access this file directly, but only through the
# symlink at /etc/resolv.conf. To manage man:resolv.conf(5) in a different way,
# replace this symlink by a static file or a different symlink.
#
# See man:systemd-resolved.service(8) for details about the supported modes of
# operation for /etc/resolv.conf.
nameserver 127.0.0.53
options edns0 trust-ad
search example.com

4.总结

在实际使用过程中,可以只关注/etc/resolv.conf文件即可:

? 想临时修改系统DNS服务器,直接修改/etc/resolv.conf文件即可(或使用resolvectl命令修改,可以更好的控制);

? 想持久化修改系统DNS服务器,配置/run/systemd/resolve/resolv.conf文件,并确保 /etc/resolv.conf 符号链接指向 /run/systemd/resolve/resolv.conf;

? 想使用DNS Stub解析器,配置/run/systemd/resolve/resolv.conf文件,并确保 /etc/resolv.conf 符号链接指向 /run/systemd/resolve/stub-resolv.conf。

在操作上,了解systemd-resolved是如何管理DNS请求,了解配置文件如何影响DNS解析行为,已经足以完成日常的配置和故障排查。

在理论上,若想要使用DNS解析服务更高级的功能可以深入了解DNS工作原理以及DNS协议的高级特性,并深入学习systemd-resolved服务相关的高级命令和安全防护等。


串口服务器_数传电台_4G DTU_遥控开关_LoRa/ZigBee/WiFi/蓝牙模块-成都亿佰特电子科技有限公司官网

相关推荐

CentOS 7 搭建 Harbor2.4.1 Docker镜像仓库

上一篇文章我们使用了registry镜像来搭建Docker私有镜像仓库,但是使用体验不是很好,没有一个可管理的UI界面,管理很麻烦。本篇文章将介绍一个新的搭建Docker镜像仓库的工具叫做Har...

简单认识认识mqtt及mosquitto(mqtt报文解析)

某项目中使用了MQTT作为进程间的通信方式,之前没用过,这两篇笔记我们就来一起学习一下这种方式。MQTT的一些介绍以下介绍内容来自《[野火]《LwIP应用开发实战指南》MQTT协议全称是Messa...

全源码打造高性能 LNMP 架构: 实战教程(2025最新版)

适用场景:企业生产环境、自建Web服务、深度性能调优操作系统:CentOS7/8、RockyLinux、Debian、Ubuntu(本文以CentOSStream9为例)技术栈:N...

Nacos3.0重磅来袭!全面拥抱AI,单机及集群模式安装详细教程!

之前和大家分享过JDK17的多版本管理及详细安装过程,然后在项目升级完jdk17后又发现之前的注册和配置中心nacos又用不了,原因是之前的nacos1.3版本的,版本太老了,已经无法适配当前新的JD...

Ubuntu24.04.2 企业级MinIO存储系统部署指南

一、概要1.1MinIO架构解析MinIO是一款高性能的云原生对象存储系统,采用Golang开发并遵循ApacheLicensev2.0协议。其核心架构基于纠删码(ErasureCode)技...

从零打造自己的 国产鸿蒙(OpenHarmony)定制系统-完整可落地流程

适用版本:OpenHarmony4.0/5.0Standard目标人群:想在x86PC、RK3568开发板或自有硬件上裁剪、加品牌、预装应用并生成可刷机镜像的开发者/团队目录环境准...

一次暂未成功的dify安装经历(dify怎么安装)

前几天在阿里云买了一台机,这几天一直在尝试安装dify,到现在还没安装上我是按这个教程装的https://blog.csdn.net/2401_82469710/article/details/14...

ZLMediaKit教程(五)支持webrtc(webrtc lib)

ZLMediaKit系列文章(共六篇):ZLMediaKit流媒体(一)编译安装ZLMediaKit教程(二)主程序和配置文件解析ZLMediaKit教程(三)URL规则ZLMediaKit教程...

Linux程序安装与管理指南(linux程序安装命令大全)

在Linux系统中,安装和管理程序主要通过包管理器和手动编译安装两种主要方式实现。以下是详细的操作指南,涵盖常见发行版(如Ubuntu/Debian、CentOS/RHEL、Fedora等)的用法。一...

离线状态下安装 Nginx 各个模块?这篇攻略让你轻松搞定

你是不是也在为离线状态下安装Nginx各个模块而发愁?在互联网大厂后端开发工作中,我们常常会遇到一些特殊的网络环境,比如公司内部的离线服务器,或是处于隔离状态的测试环境。当需要在这些离线环境中安装...

Rust实践:Win10环境下的openssl交叉编译

Rust支持跨平台,可以指定生成目标平台,交叉编译也是支持的。当然,想要交叉编译成功,还需要指定平台的编译器(如:msvc、gcc等)。openssl是C语言开发的库,如果在Rust代码中用到open...

Linux下Blackwell架构显卡(RTX5070/5090)编译PaddlePaddle指南

Blackwell显卡架构如RTX5070\5090等显卡当前Paddle预编译版本中包含的GPU架构(即SM架构)是有限的,比如常见的SM75(T4)、SM86(A10)、SM89(...

突破操作系统界限,掌握Linux的必备指南

#头条创作挑战赛#简介Linux是一种开源的操作系统,它的核心思想是自由和开放。Linux以其稳定性、可靠性和安全性而闻名,被广泛用于服务器和嵌入式设备中。Linux创始人Linux安装在安装Linu...

Linux日常高频使用的100条命令,强烈建议收藏

查看系统信息如何查看系统版本:uname-alsb_release-acat/etc/os-release如何查看系统内核信息:uname-r如何查看系统CPU信息:lscpucat...

Linux文件系统结构全解析(linux文件结构详解)

对Linux新手而言,“一切皆文件”的设计哲学常让人既兴奋又困惑——打开终端输入ls/,看到的bin、etc、var等目录到底有什么用?如何快速定位关键文件?本文将从Linux文件系统的底层逻...

取消回复欢迎 发表评论: