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

如何在Linux中查询 DNS 记录,这三个命令可谓是最常用、最经典的

nanshan 2025-03-24 18:37 8 浏览 0 评论

在进入正题之前,先聊聊为什么我们需要检查 DNS 记录。DNS 是互联网的基石,它负责把域名解析成 IP 地址,确保你的浏览器能找到目标服务器。如果 DNS 出问题,可能导致网站打不开、邮件发不出去,甚至某些服务完全瘫痪。在 Linux 终端检查 DNS 记录,可以帮你:

  • 诊断网络问题:网站访问不了?可能是 DNS 解析出了岔子。
  • 验证配置:刚设置好一个域名,想确认 MX 记录是否正确指向邮件服务器。
  • 学习和探索:搞清楚某个域名背后到底藏着什么秘密。

Linux 终端提供了多种工具来完成这些任务,而 dignslookuphost 是其中最常用、最经典的三剑客。接下来,我们逐一拆解它们,看看怎么把它们玩得炉火纯青。

1. dig 命令

DNS 查询的“瑞士军刀”

如果你问一个网络管理员,排查 DNS 问题时最喜欢用什么工具,十有八九会提到 dig。全名叫 “Domain Information Groper” 的它,就像一把多功能的瑞士军刀,能挖出 DNS 的各种细节。不管是查询 A 记录、MX 记录,还是追踪整个解析过程,dig 都能给你满满的掌控感。

大多数 Linux 发行版默认不自带 dig,但它通常包含在 bind-utilsdnsutils 软件包中。安装方法很简单:

  • Ubuntu/Debiansudo apt install dnsutils
  • CentOS/RHELsudo yum install bind-utils
  • Arch Linuxsudo pacman -S bind

安装好后,试试最简单的用法:

dig baidu.com

敲下回车,你会看到一堆输出。别被吓到,我们慢慢拆开看。

dig 的输出信息量很大,但很有条理,分成了几个关键部分:

  • 头部(HEADER)
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 722

这里 status: NOERROR 表示查询成功,id 是查询的唯一标识。

  • 查询部分(QUESTION SECTION)
;; QUESTION SECTION:
;baidu.com.                     IN      A

显示你问了什么:我要 baidu.com 的 A 记录。

  • 答案部分(ANSWER SECTION)
;; ANSWER SECTION:
baidu.com.              252     IN      A       110.242.68.66
baidu.com.              252     IN      A       39.156.66.10

这是核心内容:baidu.com 的 IP 是 110.242.68.66

  • 统计信息
;; Query time: 0 msec
;; SERVER: 127.0.0.53#53(127.0.0.53)
;; WHEN: Sat Mar 15 11:16:50 CST 2025
;; MSG SIZE  rcvd: 70

第一次看可能觉得眼花缭乱,但多用几次,你就会爱上这种清晰的结构。

查询各种 DNS 记录

dig 的强大之处在于它能查几乎所有类型的 DNS 记录。语法是:

dig [域名] [记录类型]

试试这些例子:

  • A 记录(IPv4 地址)
dig baidu.com A

  • AAAA 记录(IPv6 地址)
dig baidu.com AAAA

  • MX 记录(邮件服务器)
dig google.com MX

输出可能像:

数字 10 是优先级,值越低越优先。

  • NS 记录(名称服务器)
dig google.com NS

  • TXT 记录(文本信息,常用于验证)
dig google.com TXT

  • CNAME 记录(别名)
dig www.google.com CNAME

高级玩法

dig 不止能查,还能让你掌控查询过程:

  • 指定 DNS 服务器
dig @8.8.8.8 baidu.com

用 Google 的 DNS 服务器查询,排查百度 DNS 问题时超实用。

  • 精简输出
dig baidu.com +short

只返回 39.156.66.10110.242.68.66,适合脚本使用。

  • 追踪解析过程
dig baidu.com +trace

从根服务器开始,步步展示解析路径,堪称 DNS 的“探秘日记”。

  • 禁用递归查询
dig baidu.com +norecurse

测试权威服务器的直接响应。

  • 批量查询

把域名写进文件(比如 domains.txt),然后:

dig -f domains.txt

有一次,我帮朋友排查网站打不开的问题,用 dig +trace example.com 发现某个区域的 DNS 服务器没正确更新记录。换了 dig @1.1.1.1 再试,发现解析正常,问题出在本地运营商的 DNS。dig 的详细输出让我迅速锁定了症结。


nslookup 命令:简单好用的老朋友

nslookup 是 DNS 查询的老牌工具,虽然没有 dig 那么炫酷,但胜在简单直接。它在很多系统上默认安装(包括 Windows),是快速上手的好选择。

两种用法

  • 非交互模式
nslookup baidu.com

输出:

  • 交互模式
nslookup
> baidu.com
> google.com
> exit

适合连续查多个域名。

查询不同记录

指定类型用 -type=

  • MX 记录
nslookup -type=mx google.com

  • NS 记录
nslookup -type=ns baidu.com

在交互模式下:

nslookup
> set type=mx
> baidu.com

指定 DNS 服务器

  • 非交互:
nslookup baidu.com 8.8.8.8

  • 交互:
nslookup
> server 8.8.8.8
> baidu.com

更多选项

  • 调试模式
nslookup -debug baidu.com

显示详细解析过程。

  • 端口号
nslookup -port=5353 baidu.com

用非标准端口查询。

和 dig 的对比

nslookup 输出简单,但信息量少,适合快速确认;dig 则更全面,适合深度分析。个人经验:我常用 nslookup 验证 IP,复杂问题还是交给 dig

host 命令:小巧灵活的轻量选手

host 是三者中最轻量的,输出简洁,特别适合脚本或快速检查。它没有 dig 的花哨,但用起来毫不含糊。

基本用法

host baidu.com

输出:

查询记录类型

-t 指定:

  • MX
host -t mx google.com

  • NS
host -t ns google.com

反向查询

host 93.184.216.34

输出:

34.216.184.93.in-addr.arpa domain name pointer example.com.

指定服务器

host baidu.com 8.8.8.8

高级用法

  • 显示所有记录
host -a baidu.com

  • 超时设置
host -W 5 baidu.com

等待 5 秒。

三种工具各有千秋:

  • dig:全面强大,适合深入排查。
  • nslookup:简单直观,适合快速上手。
  • host:轻巧高效,适合脚本和日常检查。

实际工作中,可以混搭使用:用 nslookup 快速试水,dig 深入挖掘,host 自动化处理。试着动手敲敲这些命令,DNS 的奥秘就在你的终端里等着你去发现!有什么问题或心得,欢迎留言交流!

相关推荐

ssh终端xshell日志查看命令(xshell怎么看日志)

现在我们云服务器运维较多用的是SSH工具,其中常用的包括PUTTY、XSHELL等,其实大同小异界面UI稍微不同,但是都可以进入远程连接。这里有朋友提到如何查看服务器的日志文件,这个其实和是否使用XS...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

如何高效读取Linux日志文件?这些命令要熟记于心!

在Linux系统中,日志文件通常存储在/var/log目录下。比如,/var/log/syslog(或/var/log/messages,视发行版而定)记录系统整体事件,/var/log/a...

Windows服务器远程登录日志查询方法,linux查看登录日志方法

概述本文介绍Windows、Linux服务器查询系统的远程登录日志方法。根据服务器所使用的操作系统不同,有以下两种查询方法。Linux操作系统的登录日志查询通过远程连接登录Linux服务器,使用roo...

iptables防火墙如何记录日志(防火墙日志查看)

例如:记录所有ssh服务的登录的日志首先,我们需要了解如何将所有的iptables的INPUT链数据包记录到/var/log/messages中。如果你已经有一些iptables规则了,那么将记录日志...

如何安全管理SSH密钥以防止服务器被入侵

SSH密钥安全管理实施指南(2025年更新版)一、密钥生成与存储规范高强度密钥生成bashCopyCodessh-keygen-ted25519-a100#生成ED25519算法密钥(比...

在CentOS上安装nginx服务器(centos搭建代理服务器)

一、环境描述1.虚拟机配置CPU:单核内存:2GB硬盘:120GBIP:10.24.17.1082.操作系统版本:CentOS6.6x86_64安装方式:Minimal3.虚拟化环境VM...

CentOS7安全加固的一份整理规划建议

◆更新系统:及时更新CentOS7操作系统版本和安全补丁,确保系统以最新状态运行。◆关闭不必要的服务:在运行系统时,应关闭不需要的服务和端口,以减少系统暴露的攻击面。◆安装防火墙:使用iptables...

第四十七天-二叉树,centOS安装tomcat,Maven,vsftpd

学习笔记:1.Maven是Apache下的一个纯Java开发的开源项目。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。Maven...

Linux远程桌面连接使用教程 Widows终端远程连接Linux服务器

一、前言为什么不是远程连接Linux服务器?因为我不会,远程连接window我就用电脑自带的“远程桌面连接”。以下所述都是在CentOS操作系统下的。服务器刚换成Linux的时候很迷茫,感觉无从下手...

CentOS 安全加固操作,保护你的操作系统

系统加固是保障系统安全的重要手段,对于维护企业数据安全、用户隐私以及系统稳定运行具有重要意义。加固后的系统更加健壮和稳定,能够有效减少因安全问题导致的系统故障和停机时间,提高系统的可用性和可靠性。通过...

Dockerfile部署Java项目(docker如何部署java项目)

1、概述本文主要会简单介绍什么是Docker,什么是Dockerfile,如何安装Docker,Dockerfile如何编写,如何通过Dockerfile安装jar包并外置yaml文件以及如何通过do...

CentOS7云主机部署Fail2ban阻断SSH暴力破解

关于Fail2banFail2ban可以监视你的系统日志,然后匹配日志的错误信息(正则式匹配)执行相应的屏蔽动作(一般情况下是调用防火墙屏蔽)例如:当有人在试探你的HTTP、SSH、SMTP、FTP密...

在CentOS7上用源码编译安装PostgreSQL

1、新建postgres用户#useraddpostgres&&passwdpostgres2、安装依赖包#yum-yinstallmakegccgcc-c++readline...

pure-ftpd 使用(ftp prompt命令)

pure-ftpd是一个免费的ftp软件,其他介绍就不多说了。我们直接开始主题安装centosyuminstallepel-releaseyuminstallpure-ftpd配置备份原配置...

取消回复欢迎 发表评论: