DNS服务的部署与配置(2)

1、dns的安装及开启

dnf install bind.x86_64 -y         #安装
#Berkeley Internet Name Domain (BIND)

systemctl enable --now named    #启用dns服务,服务名称叫named
firewall-cmd --permanent --add-service=dns #火墙设置
firewall-cmd --reload            #重启火墙
setenforce 0                    #调整内核级火墙为警告模式

2、配置dns服务使内网主机可以访问其dns资源

netstat -antlupe | grep named                #可以查看dns开放端口

vim /etc/named.conf                            #编辑dns配置文件,对文件做以下修改
11行左右 listen-on port 53 { any; };         #在本地所有网络接口上开启53端口
19行左右 allow-query { any; };                 #允许查询A记录的客户端列表,提供服务给所有主机
20行左右 forwarders { 114.114.114.114; };    #将源换为国内的,指定资源从114上取,这样速度会快一点
34行左右 dnssec-validation no;                 #禁用dns检测使dns能够缓存外部信息到本机,开着会因为检测不合规返回不了“答案”
##每一个字符串一定要用分号结尾

systemctl restart named                        #重启服务

使用内网其他主机测试:

vim /etc/resolv.conf #编辑dns指向文件 nameserver 192.168.187.129

#添加我们配置的dns服务器的ip dig www.baidu.com

#解析测试我们的dns服务器配置是否成功

显示NOERROR就是没有问题!

3、DNS的正向解析

企业内部也需要对外提供dns做相应的解析工作!
准备工作:
在上个高速缓存配置的基础上,先编辑主配置文件vim /etc/named.conf,将源注释掉

然后使用命令nm-connection-editor将dns服务器在的主机和测试主机的ip都改为静态ip
dns服务器的IP改成:192.168.187.129
测试主机IP改为:192.168.187.136   

修改配置并保存

(1)主机记录A记录

第一步:添加域名语句块

vim /etc/named.rfc1912.zone
##和主配置文件里的内容一样,里边有要维护域名的语句块
##主配置文件读取域名信息就会到这个文件里读取
##我们可以在这个文件里添加我们要维护的域名的语句块
添加:
zone "lucky.com" IN {             #维护的域名
 type master;                     #当前服务器位主dns
 file "lucky.com.zone";         #域名A记录文件,要解析域名时看的是这个文件
 allow-update { none; };         #允许更新主机列表
};

第二步:编辑域名A记录文件

cd /var/named/                #进入数据目录
cp -p named.localhost lucky.com.zone        #复制模板得到我们要的域名A记录文件,一定要加-p参数,所属组相同

vim lucky.com.zone            #编辑A记录文件

A记录文件内容及解释如下:
$TTL 1D #TIME-TO-LIVE(dns地址保存时间长度)
@ IN SOA dns.lucky.com. root.lucky.com (         #SOA授权起始(Start of Authority),谁授权的
#@符的值就是/etc/named.rfc1912.zone文件里我们编写的域名语句块引号里的内容
#不是以.结尾的字符串都会被自动补齐@符的值
 0 ; serial             #域名版本序列号,下文dns集群会用到,有详细解释
 1D ; refresh             #刷新时间(辅助dns)
 1H ; retry             #重试时间(辅助dns)
 1W ; expire             #过期时间(辅助dns,查询失败过期停止对辅助域名的应答)
 3H ) ; minimum         #A记录最短有效期
         NS     dns.lucky.com.
dns     A     192.168.187.129
lucky.a A     192.168.187.97         ##正向解析记录
lucky.a A     192.168.187.99

复制并编辑A记录文件

第三步:重启并在另一台内网主机测试
systemctl restart named
另一台主机先检查下dns服务器是不是我们设置的

然后dig www.lucky.com,如图测试成功!
##多个ip会自动做轮调

(2)规范域名转换CNAME记录

当内部主机名不规范时,对外开放的是规范域名。
那么对外开放的域名只有一个,将对外开放的域名转换到内部主机再做解析

dns服务器端:
vim /var/named/lucky.com.zone            #编辑A记录文件

添加:
www     CNAME   www.a.lucky.com.
#www.a.lucky.com.就是不规范域名

systemctl restart named        #重启dns

客户端:
dig www.lucky.com            #另一台主机测试

编辑文件

重启

另一台主机测试,如图设置成功!

(3)邮件解析MX记录

什么是MX记录?
当我们在发送邮件时,假设我们用的163.com邮箱,需要将163.com解析成ip才能进行数据传输,这个ip就叫这个域的mx记录(负责邮件发送和接收的ip)。

dns服务器端

vim /var/named/lucky.com.zone

#编辑A记录文件 添加后保存退出:

lucky.com. MX 1 192.168.187.129.

systemctl restart named

#重启dns

添加时写的是服务器ip

客户端:

dnf install postfix mailx -y          #安装提供邮件投递协议的软件postfix和发送邮件的客户端mailx systemctl start postfix               #开启postfix服务 

dig -t mx lucky.com                  #查看mx记录

查看mx记录,没有问题

发邮件给root@lucky.com(自行类比@qq.com)
##因为在dns服务器端25端口是自用的(回环),所以不会收到邮件,所以我们在测试端看发送队列看下效果即可
##如图即是正向解析成功

4、DNS的反向解析

逆向查询记录PTR记录

什么是PTR记录?
邮件接收方只会显示发送方的ip,需要做反向解析,显示真实的域名,让用户知道邮件从哪儿来的。从ip到域名就是ptr记录。

dns服务器端

vim /etc/named.rfc1912.zones            #编辑文件
添加:
zone "187.168.192.in-addr.arpa" IN {
        type master;
        file "192.168.187.ptr";
        allow-update { none; };
};

cd /var/named/
cp -p named.loopback 192.168.187.ptr        #复制模板得到ptr文件

vim 192.168.187.ptr                            #编辑ptr记录文件
修改成下文:
$TTL 1D
@       IN SOA  dns.lucky.com. rname.invalid. (
                                        0       ; serial
                                        1D      ; refresh
                                        1H      ; retry
                                        1W      ; expire
                                        3H )    ; minimum
        NS      dns.lucky.com.
dns     A       192.168.187.129
233     PTR     www.lucky.com.
#反向解析IP192.168.187.233应该得到域名www.lucky.com

systemctl restart named                        #重启

编辑named.rfc1912.zones文件

编辑ptr记录文件

客户端:
dig -x 192.168.187.233测试如图成功!

5、DNS的双向解析


双向解析:
在内网中的主机解析得到内网的ip,
在外网中的主机解析得到外网的ip。
实验环境:
我们需要一台双网卡主机模拟内网,一台单网卡主机模拟外网
dns服务器端做内网主机:
添加一个网卡,将ip设为192.168.0.0/24网段的
原来的192.168.187.0/24网段的做内网ip

单网卡主机做外网主机:
ip改为192.168.0.0/24网段的,模拟外网主机,并且将网关设为dns服务器端192.168.0.0/24网段的ip,保证两台主机能相互通信

两台主机更改完网络后都需重启网络

nmcli connection reload

nmcli connection up

网络名 例如客户端网卡名为ens160,那么就是

nmcli connection up ens160

设置完后ping一下通了即可

dns服务器端(内网主机):

vim /etc/named.conf #编辑主配置文件

将下图内容注释掉:

注释掉后,在下边添加如下内容:
view localnet {
        match-clients { 192.168.187.0/24; };
        zone "." IN {
                type hint;
                file "named.ca";
        };
        include "/etc/named.rfc1912.zones";
};

view internet {
        match-clients { any; };
        zone "." IN {
                type hint;
                file "named.ca";
        };
        include "/etc/named.rfc1912.zones.inter";
};

拷贝/etc/named.rfc1912.zones文件得到/etc/named.rfc1912.zones.inter文件
cp -p /etc/named.rfc1912.zones /etc/named.rfc1912.zones.inter
vim /etc/named.rfc1912.zones.inter        #编辑外网配置文件
做如下图更改:

拷贝A记录文件得到外网的A记录文件
cp -p /var/named/lucky.com.zone /var/named/lucky.com.inter
vim /var/named/lucky.com.inter        #编辑外网A记录文件
做如下图更改:
#把ip都改成我们想让外网主机访问时看到的ip

重启systemctl restart named

vim /etc/resolv.conf       #添加dns服务器

ip nameserver 192.168.187.129

#因为更改过网络,所以可能需要重新添加

客户端(外网主机)

vim /etc/resolv.conf                    #添加dns服务器

ip nameserver 192.168.187.129    #因为更改过网络,所以可能需要重新添加

测试:
dns服务器端(内网主机):
dig -x 192.168.187.233测试,如图显示的内网ip,成功!

客户端(外网主机):
dig -x 192.168.187.233测试,如图显示的外网ip,成功!

6、DNS集群

当我们的主dns服务器访问量过大时,服务器不足以支撑这么大的访问量,我们可以增加n台辅助dns来分担访问压力。
我们下面以增加一台辅助dns来实验如何使主辅dns同步更新!

辅助dns:


我以上面用过的客户端主机为辅助dns
先将其IP改为和主dns一个网段的,192.168.187.136

更改完网络后需重启网络

nmcli connection reload

nmcli connection up ens160

dnf install bind.x86_64 -y         #也安装dns
#Berkeley Internet Name Domain (BIND)

systemctl enable --now named    #启用dns服务,服务名称叫named
firewall-cmd --permanent --add-service=dns #火墙设置
firewall-cmd --reload            #重启火墙
setenforce 0                    #调整内核级火墙为警告模式

vim /etc/named.conf                #编辑主配置文件
注释掉11,12,19行

vim /etc/named.rfc1912.zones    #在文件中加入域名语句块
添加:
zone "lucky.com" IN {
        type slave;                #类型是辅助dns
        masters { 192.168.187.129; };    #主dns
        file "slaves/lucky.com.zone";    #数据同步到slaves目录下
};

编辑主配置文件注释掉如图三行,就相当于全部都开启(any)

添加域名语句块

vim /etc/resolv.conf

nameserver 192.168.187.136    #将dns服务器改为自己的,为了看效果

systemctl restart named    #重启dns服务

主dns:


我以上面配好的dns服务器192.168.187.129这台主机为主dns

先去掉上个实验的配置,防止影响

vim /etc/named.conf   

#编辑主配置文件

注释掉如下图内容:

vim /etc/named.rfc1912.zones

在域名语句块内添加如下内容:

also-notify { 192.168.187.136; };   #辅助dns的ip

systemctl restart named             #重启dns

测试:
辅助dns:
dig www.lucky.com得到如图结果:

主dns:

vim /var/named/lucky.com.zone

#编辑A记录文件 更改下ip和serial值:

之后在辅助dns端重新dig看是否同步成功

serial值的作用:
每更改一次该值并重启主dns服务后,辅助dns就会重新同步A记录
即重新同步域名所对应ip
一天可以改99次
值可以任意写!
!!!!!但只能增量更改!!!!!

其他值解释:
 1D ; refresh             #刷新时间(辅助dns)
 1H ; retry             #重试时间(辅助dns)
 1W ; expire             #过期时间(辅助dns,查询失败过期停止对辅助域名的应答)
 3H ) ; minimum         #A记录最短有效期

辅助dns:
dig www.lucky.com得到如图结果:
测试成功!ip同步成功!

DNS(DHCP+DNS)动态域名解析

dhcp能自动分配ip,当重新分配时怎么让dns知道ip重新分配了呢?ddns可以解决这个问题,实现动态域名解析。
更新原理:制作一个key,让dhcp能更新dns的A记录,key是更新域名的钥匙。
在/var/named目录下生成一个更新数据,在系统读取A记录时会把.jnl结尾的更新文件与A记录文件整合实现。

ddns服务端

dnf install dhcp-server -y        #安装dhcp服务器
cp /usr/share/doc/dhcp-server/dhcpd.conf.example /etc/dhcp/dhcpd.conf        #复制模板得到配置文件
vim /etc/dhcpd/dhcpd.conf        #编辑dhcp配置文件
做如下图修改:
#修改最终结果是剩31行

systemctl start dhcpd        #开启dhcp
接下来制作更新域的“钥匙”key:
#/etc/rndc.key是dns默认使用的key模板,用的是SHA-256加密,所以我们下面也要使用SHA-256加密
cd /mnt/
dnssec-keygen -a HMAC-SHA256 -b 128 -n HOST luckykey
#SHA256加密方式是对称的,公钥和私钥是一样的

cp -p /etc/rndc.key /etc/lucky.key        #复制key模板得到key文件
vim /etc/lucky.key                        #编辑key文件
改成如下内容:
key "luckykey" {                        #我们前面取的key名字
        algorithm hmac-sha256;            #加密方式
        secret "/P/GVMVRb/dNIjtr2qYvMg==";        #我们前面生成的密钥,最好复制粘贴
};

vim /etc/named.conf         #更改dns主配置文件加key文件指向

在第45行左右添加key文件指向:

include "/etc/lucky.key";

vim /etc/named.rfc1912.zones             #域名语句块在这里

在域名语句块里添加key更新:

如下图:

systemctl restart named        #重启dns

接下来测试一下该key能否更新dns:
nsupdate -k Kluckykey.+163+37031.private        #-k指定key,不指定send会失败
> update add hello.lucky.com 86400 A 192.168.187.111    #新增A记录
> send                                                    #成功
> update del hello.lucky.com                            #删除A记录
> send                                                    #成功
> quit                                                    #退出
测试成功!继续下一步

vim /etc/dhcp/dhcpd.conf             #编辑dncp配置文件

打开dns更新的“开关”:
第14行取消注释,并改为interim(网络更新):
ddns-update-style interim;

在最后指定key,相当于让dhcp拿到了dns更新的“钥匙”:
key luckykey {                            #我们前面取得key的名字,别写错了
  algorithm hmac-sha256;
  secret /P/GVMVRb/dNIjtr2qYvMg==;        #最好直接复制前面我们生成的key文件里的防止出错
};

在最后加入key要更新的域:
zone lucky.com. {
  primary 127.0.0.1;                    #dns在本机,所以直接写本机回环接口就可以了
  key luckykey;                            #我们前面取得key的名字,别写错了
}

删掉jnl文件(不然前面的更新测试会影响):

rm -fr /var/named/lucky.com.zone.jnl

重启两个服务:

systemctl restart dhcpd

systemctl restart named

客户端:
首先要关闭VM虚拟机的本地dhcp服务,如下图操作即可:
##如果是真机是linux系统直接在虚拟机里改配置文件即可

选择更改设置

取消勾选本地dhcp服务

然后将我们之前设置的静态ip改为dhcp:

nm-connection-editor

测试下我们是否关闭本地dhcp成功:

nmcli connection up ens160          #重启网卡

cat /etc/resolv.conf        #看下dns服务用的谁的

如图是用的我们自己配置的,设置成功!

改下主机名方便测试:

hostnamectl       #查看主机名 

hostnamectl set-hostname nodeb.lucky.com      #改主机名为nodeb.lucky.com

测试:
客户端:

dig    nodeb.lucky.com

ifconfig     看两个出来的ip一样否

如图是一样的

dns服务端:

vim /etc/dhcp/dhcpd.conf     #编辑dncp配置文件

改一下ip范围:

我改为了77-90,如下图:

重启下dhcp服务: systemctl restart dhcpd

客户端

nmcli connection up ens160                #重启网卡,

那么会重新获取ip

dig nodeb.lucky.com

ifconfig 看两个出来的ip一样否

如图,重新获取的ip是我们上面重新设置的范围内的,dns解析也是同步的

测试成功!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/647431.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

学 Java 具体能干什么?

学习 Java 后,你可以从事许多不同的工作和项目,涵盖了广泛的应用领域。以下是一些具体的应用场景和工作方向: 1. 企业级应用开发 Java 是企业级应用开发的首选语言之一,特别适合开发大规模、分布式、多层次的企业应用程序。 Jav…

使用 LangFuse 意外被挂马!我是怎么恢复系统稳定的?

在使用 LangFuse 过程中,被意外挂马!通过一番折腾服务恢复正常~ 本文将详细介绍应对恶意脚本和进程的完整方案,包括识别、清理、恢复和预防步骤。 阿里云扫到的信息 被执行的 Base64 SUlaQnRTCmV4ZWMgJj4vZGV2L251bGwKSUhDa0hQbmQ9Li8uJChkYXRlfG1kNXN1bXxoZWFkIC1jMjApCl…

深度学习面试问题总结(21)| 模型优化

本文给大家带来的百面算法工程师是深度学习模型优化面试总结,文章内总结了常见的提问问题,旨在为广大学子模拟出更贴合实际的面试问答场景。在这篇文章中,我们还将介绍一些常见的深度学习面试问题,并提供参考的回答及其理论基础&a…

【WEEK13】 【DAY5】Shiro第五部分【中文版】

2024.5.24 Friday 接上文【WEEK13】 【DAY4】Shiro第四部分【中文版】 目录 15.7.Shiro请求授权的实现15.7.1.修改ShiroConfig.java15.7.1.1.添加一行验证授权的代码15.7.1.2.重启 15.7.2.修改MyController.java15.7.3.修改ShiroConfig.java15.7.4.重启15.7.5.修改UserRealm.ja…

汽车以太网发展现状及挑战

一、汽车以太网技术联盟 目前推动汽车以太网技术应用与发展的组织包括:OPEN Alliance(One-Pair Ether-Net Alliance SIG)联盟,主要致力于汽车以太网推广与使用,该联盟通过推进 BroadR- Reach 单对非屏蔽双绞线以太网传…

深入探索python编程中的字典结构

新书上架~👇全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我👆,收藏下次不迷路┗|`O′|┛ 嗷~~ 目录 一、字典的特点与基础操作 二、安全访问与哈希函数 三、字典的应用案例 四、总结 在编程的…

基于Python Selenium web测试工具 - 基本用法详解

这篇文章主要介绍了Selenium(Python web测试工具)基本用法,结合实例形式分析了Selenium的基本安装、简单使用方法及相关操作技巧,需要的朋友可以参考下 本文实例讲述了Selenium基本用法。分享给大家供大家参考,具体如下: Seleni…

代码随想录|Day42|动态规划 part07|● 70. 爬楼梯 (进阶)● 322. 零钱兑换 ● 279.完全平方数

70. 爬楼梯 &#xff08;进阶&#xff09; 322. 零钱兑换 class Solution: def climbStairs(self, n: int) -> int: if n < 1: return n dp [0] * (n 1) dp[0] 0 dp[1] 1 dp[2] 2 for i in range(3, n 1): dp[i] dp[i - 1] dp[i - 2] return dp[n] 279.完全平方数…

moviepy入门

1. 简介 由于恶心的工作和没有规划的部门安排&#xff0c;我被排到了算法部门&#xff0c;从事和算法没有半毛钱关系的业务上&#xff0c;也就是。。。搞视频。咋说呢&#xff1f;视频这东西我没有一点基础&#xff0c;还好有前人写好的代码&#xff0c;用的是moviepy和ffmpeg…

在CSDN上成长的感悟,你的粉丝长啥样?

文章目录 一、写作的初衷1. 记录所学内容2.巩固所学知识3.分享与帮助4.方便后续查找5.获取激励 二、你的粉丝长啥样&#xff1f;1. 粉丝的特点与困惑2. 关于粉丝&#xff0c;细思极恐 三、继续前行、坚持初心 在CSDN上写博文&#xff0c;对于我来说&#xff0c;不仅仅是一个记录…

(2024,attention,可并行计算的 RNN,并行前缀扫描)将注意力当作 RNN

Attention as an RNN 公众号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 3. 方法 3.1 注意力作为一种&#xff08;多对一的&#xff09;RNN 3.2 注意力作为&#xff08;多对多&…

Linux C++ Socket 套接字、select、poll、epoll 实例

文章目录 1. 概述2. TCP 网络编程实例2.1 服务器端2.2 客户端2.3 运行截图 3. I/O 模型3.1 阻塞式I/O模型3.2 非阻塞I/O模型3.3 I/O 复用模型3.4 信号驱动式I/O3.5 异步I/O模型 4. I/O复用之 select4.1 select 函数描述4.2 服务端代码4.3 客户端代码4.4 运行截图 5. I/O复用之 …

音视频开发9 FFmpeg 解复用框架--如何将一个影音文件(mp4文件/wav文件) 最终播放起来

一&#xff0c;播放器框架 二 常用音视频术语 容器&#xff0f;文件&#xff08;Conainer/File&#xff09;&#xff1a; 即特定格式的多媒体文件&#xff0c; 比如mp4、flv、mkv等。 媒体流&#xff08;Stream&#xff09;&#xff1a; 表示时间轴上的一段连续数据&#xff0…

jmeter之测试计划

一、测试计划作用 测试计划是jmeter的默认控件所有线程组都是测试计划的下级控件测试计划可以配置用户自定义的变量测试计划可以配置线程组的串行或并行 二、查看界面 名称&#xff1a;可以修改自定义的名称注释&#xff1a;解释测试计划是用来做什么的用户自定义的变量&…

23种设计模式顺口溜

口诀&#xff1a; 原型 抽风 &#xff0c;单独 建造 工厂 &#xff08;寓意&#xff1a;&#xff08;这里代指本来很简单的东西&#xff0c;却要干工厂这里复杂的业务&#xff09; 抽风&#xff1a;抽象工厂单独&#xff1a;单例桥代理组合享元适配器&#xff0c;&#xff0…

驱动开发之新字符设备驱动开发

1.前言 register_chrdev 和 unregister_chrdev 这两个函数是老版本驱动使用的函数&#xff0c;现在新的 字符设备驱动已经不再使用这两个函数&#xff0c;而是使用 Linux 内核推荐的新字符设备驱动 API 函数。 旧版本的接口使用&#xff0c;感兴趣可以看下面这个博客&#…

关于C的\r回车在不同平台的问题

首先我们需要搞明白\r和\n是两回事 \r是回车&#xff0c;前者使光标到行首&#xff0c;&#xff08;carriage return&#xff09; \n是换行&#xff0c;后者使光标下移一格&#xff0c;&#xff08;line feed&#xff09; Linux平台下 #include <stdio.h> int main()…

TiDB学习4:Placement Driver

目录 1. PD架构 2. 路由功能 2. TSO 2.1 TSO 概念 2.2 TSO分配过程 2.3 TSO时间窗口 3. 调度 3.1 信息收集 3.2 生成调度(operator) 3.3 执行调度 4. Label 与高可用 4.1 Label 的配置 5. 小结 1. PD架构 PD是整个TiDB的总控&#xff0c;相当于集群的大脑 PD集成了…

Overleaf中出现文字越界、越下届、没有正确分页、换页的原因和解决方法

在使用overleaf中&#xff0c;我偶尔会遇到如标题所说的情况&#xff0c;也如图所示&#xff1a; 后来发现&#xff0c;是因为这一页前面是一个表格&#xff0c;所以怀疑是表格的格式导致的。所以让chatgpt帮我更换了表格的格式&#xff0c;成功解决问题。 对于问题可能的成因…

20232803 2023-2024-2 《网络攻防实践》实践十报告

目录 1. 实践内容1.1 SEED SQL注入攻击与防御实验1.2 SEED XSS跨站脚本攻击实验(Elgg) 2. 实践过程2.1 SEED SQL注入攻击与防御实验2.1.1 熟悉SQL语句2.1.2 对SELECT语句的SQL注入攻击2.1.3 对UPDATE语句的SQL注入攻击2.1.4 SQL对抗 2.2 SEED XSS跨站脚本攻击实验(Elgg)2.2.1 发…