域名解析服务器(DNS)

2024-05-23 22:28
文章标签 服务器 域名解析 dns

本文主要是介绍域名解析服务器(DNS),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

简介

        DNS

        域名

        域名结构

        域名服务器类型

        相关指令

实验内容 

        软件

 实验准备

正向解析实验 

        服务端操作

        客户端操作

逆向解析实验 

        服务端操作

        客户端操作


简介

        DNS

        DNS(Domain Name System)时互联网上的一项服务,作为将域名和IP地址互相映射的一个分布式数据库,能更方便人们访问互联网;DNS服务的监听端口是UDP协议的53端口。

        域名

        因特网采用层次树状结构的命名方法,任何连接在因特网上的主机或路由器,都有一个唯一的层次结构的名字,即域名(Domain Name)。

        域名只是逻辑概念,并不代表计算机所在的物理地点。

        域名结构

        域名可分为三大类:国家顶级域名、通用顶级域名、基础结构域名

        国家顶级域名:采用ISO3166标准;cn为中国、us为美国、uk为英国等。

        通用顶级域名:com代表企业公司、net代表网络服务机构、org代表非盈利组织、int代表国际组织、gov代表政府部门等。

        基础结构域名:该顶级域名只有一个---arpa,用于域名转换为IP地址,因此成为反向域名。

        域名服务器类型

        根域名服务器:顶层的域名服务器,知道所有顶级域名服务器的域名和IP地址

        顶级域名服务器:负责管理在该顶级域名注册的二级域名

        权限域名服务器: 负责一个区域的域名

        本地域名服务器:不属于域名服务器的层次结构,但对域名系统非常重要;当主机发出DNS请求时,查询请求就发送给本地域名服务器

        缓存DNS服务器:不负责解析域,只缓存域名解析的结果

        相关指令

        nslookup

                用于查询DNS记录,查看域名解析是否正常,在网络故障时可以用来诊断网络问题;Liunx和Windows都可以使用该命令

                非交互模式:nslookup + 需要解析的域名或IP地址

                交互模式: 使用nslookup命令进入交互模式(ctrl + Z退出交互模式)

        dig 

                是一个域名查询工具;可以从DNS服务器查询主机地址信息,获取到详细的域名信息

                安装

                Debian(Ubuntu、kali...)系列:

apt-get install dnsutils

                RedHat(RedHat、Centos、Fedora...)系列:

yum install bind-utils

                使用

dig + 需要解析的域名或IP地址

        其中status的值为状态指示

        NOERROR:查询成功

        SERVFAIL:DNS服务器执行查询时遇到错误,无法完成请求

        NXDOMAIN:查询的域名不存在记录

        使用 dig -x + 需要查询的域名或IP地址

        注意:dig会从域名的官方服务器上获取到精确的结果;nslookup只会获得DNS服务器保存在cache中非权威的解答

实验内容 

        软件

        bind是提供DNS服务的软件,它的守护进程名是named

        安装

yum install bind

         检查安装情况

rpm -qc bind

 实验准备

        实验设备

        两个操作系统,一个作为客户端,一个作为服务器

        服务器

        客户端

        修改服务器named配置

cp /etc/named.conf /etc/named.conf_bak        #备份配置文件

vim /etc/named.conf

         将127.0.0.1和localhost修改为any        #允许所有人访问本机DNS

        关闭SELiunx

setenforce 0

        关闭防火墙

 systemctl stop firewalld.service

正向解析实验 

        实验将域名解析为IP地址

        服务端操作

        编辑区域配置文件

cp /etc/named.rfc1912.zones /etc/named.rfc1912.zones_bak        #备份配置文件

vim /etc/named.rfc1912.zones

        在配置文件末尾添加

zone "hello.com" IN {
        type master;
        file "hello.com.zone";
        allow-update { none; };
};                                                                 #hello.com为域名,可自定义

        编辑正向解析文件

        复制正向解析模板 

 cd /var/named/        #进入文件位置

cp -a named.localhost hello.com.zone        #拷贝并重命名;hello.com要与上面域名一致

vim hello.com.zone        #进入文件编辑

         修改前

        修改后 (保存退出)

         hello.com.        #自定义域名

        192.168.73.130        #域名对应的IP地址(为了简化实验将其设置为服务器IP地址)

        www.        ftp.        www1.        #匹配域名的前缀

        重启服务

systemctl restart named

        客户端操作

        修改网络适配器文件

        客户端网络适配器为ens160

        进入网络适配器配置文件 

vim /etc/NetworkManager/system-connections/ens160.nmconnection

        添加DNS服务器地址 

dns=192.168.73.130        #dnsIP地址为服务器IP地址

        重启网络适配器

 nmcli connection reload                #重启服务

nmcli connection up ens160                #重启网络适配器

         测试正向解析

逆向解析实验 

        服务端操作

        主要配置文件与正向解析相同,区域配置文件中添加逆向解析配置

vim /etc/named.rfc1912.zones

        添加以下配置 

        73.168.192为服务器端IP地址的网络位

        注意:IP地址需要反向书写

zone "73.168.192.in-addr.arpa" IN {
        type master;
        file "192.168.73.arpa";
        allow-update { none; };
};

         编辑反向解析文件

        复制反向解析模板

cd /var/named/        #进入配置位置

cp -a named.loopback 192.168.73.arpa        #拷贝并重命名文件为反向解析的IP地址

vim 192.168.73.arpa        #编辑配置文件

         修改后

        域名结尾必须加点(.);130为服务器的主机位

         重启服务

systemctl restart named

        客户端操作

        配置与正向解析操作一致

        测试

这篇关于域名解析服务器(DNS)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/996584

相关文章

Apache Tomcat服务器版本号隐藏的几种方法

《ApacheTomcat服务器版本号隐藏的几种方法》本文主要介绍了ApacheTomcat服务器版本号隐藏的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1. 隐藏HTTP响应头中的Server信息编辑 server.XML 文件2. 修China编程改错误

如何在一台服务器上使用docker运行kafka集群

《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本... 目录1.拉取镜像2.创建集群之间通信的网络3.将zookeeper加入到网络中4.启动kafka集群

Python如何实现 HTTP echo 服务器

《Python如何实现HTTPecho服务器》本文介绍了如何使用Python实现一个简单的HTTPecho服务器,该服务器支持GET和POST请求,并返回JSON格式的响应,GET请求返回请求路... 一个用来做测试的简单的 HTTP echo 服务器。from http.server import HT

如何安装 Ubuntu 24.04 LTS 桌面版或服务器? Ubuntu安装指南

《如何安装Ubuntu24.04LTS桌面版或服务器?Ubuntu安装指南》对于我们程序员来说,有一个好用的操作系统、好的编程环境也是很重要,如何安装Ubuntu24.04LTS桌面... Ubuntu 24.04 LTS,代号 Noble NumBAT,于 2024 年 4 月 25 日正式发布,引入了众

如何提高Redis服务器的最大打开文件数限制

《如何提高Redis服务器的最大打开文件数限制》文章讨论了如何提高Redis服务器的最大打开文件数限制,以支持高并发服务,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录如何提高Redis服务器的最大打开文件数限制问题诊断解决步骤1. 修改系统级别的限制2. 为Redis进程特别设置限制

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

速盾:直播 cdn 服务器带宽?

在当今数字化时代,直播已经成为了一种非常流行的娱乐和商业活动形式。为了确保直播的流畅性和高质量,直播平台通常会使用 CDN(Content Delivery Network,内容分发网络)服务器来分发直播流。而 CDN 服务器的带宽则是影响直播质量的一个重要因素。下面我们就来探讨一下速盾视角下的直播 CDN 服务器带宽问题。 一、直播对带宽的需求 高清视频流 直播通常需要传输高清视频

一种改进的red5集群方案的应用、基于Red5服务器集群负载均衡调度算法研究

转自: 一种改进的red5集群方案的应用: http://wenku.baidu.com/link?url=jYQ1wNwHVBqJ-5XCYq0PRligp6Y5q6BYXyISUsF56My8DP8dc9CZ4pZvpPz1abxJn8fojMrL0IyfmMHStpvkotqC1RWlRMGnzVL1X4IPOa_  基于Red5服务器集群负载均衡调度算法研究 http://ww

RTMP流媒体服务器 crtmpserver

http://www.oschina.net/p/crtmpserver crtmpserver又称rtmpd是Evostream Media Server(www.evostream.com)的社区版本采用GPLV3授权 其主要作用为一个高性能的RTMP流媒体服务器,可以实现直播与点播功能多终端支持功能,在特定情况下是FMS的良好替代品。 支持RTMP的一堆协议(RT