运维DNS原理配置

时间:2022-04-01 13:39:55

Linux DNS原理简介及配置

  1. DNS简介
  2. DNS原理
  3. 域名解析的过程
  4. 资源记录
  5. DNS BIND安装配置

一、简介

一般来讲域名比IP地址更加的有含义、也更容易记住,所以通常用户更习惯输入域名来访问网络中的资源,但是计算机主机在互联网中只能通过IP识别对方主机,那么就需要DNS域名解析服务了。

域名:www.baidu.com(也叫做FQDN:Full Qualified Domain Name, 完全限定域名,同时带有主机名和域名的名称)

通常 Internet 主机域名的一般结构为:主机名.三级域名.二级域名.*域名。

TLD(top level domain)

组织域:.com, .org, .net, .cc

国家域: .cn, .tw, .hk, .iq, .ir, .jp

反向域: IP-->FQDN 将IP地址转换成主机名,早期只能正向解析,后来引入了一个机制。指针;但是从IP转换成FQDN是另外一套数据库。

DNS服务协议采用类似目录树的层次结构记录域名与IP地址的映射对应关系,形成一个分布式的数据库系统,上级仅知道其直接下级,下级只知道根的位置。结构模型:

运维DNS原理配置

DNS域名解析服务(Domain Name System)是用于解析域名与IP地址对应关系的服务,功能上可以实现正向解析反向解析

正向解析:根据主机名(域名)查找对应的IP地址。

反向解析:根据IP地址查找对应的主机名(域名)。

二、原理

Linux下nsswitch(network service switch)是一个通用框架,与各种类型存储交互的公共实现,实现名称解析服务。其中有库文件,libnss_files.so库文件就是实现查找文件时, 其应该调用的文件。其展现的就是一个配置文件,/etc/nssitch.conf,此配置文件中

运维DNS原理配置

这个files就是通过libnss_files来查找/etc/hosts

hosts可通过两种方式来查找:     files    dns

file: /etc/hosts配置文件

dns: DNS服务器

系统中stub resolver:名称解析器,根据配置文件来查找对应的ip地址。

ping www.itodo.com此过程就是先查找本地/etc/hosts文件,如果没有再查找dns服务器。

hosts格式:

IPADDR FQDN    Ailases

192.168.100.1    www.ss.com     www

三、域名解析的过程

当应用过程需要将一个主机域名映射为IP地址时,就调用域名解析函数,解析函数将待转换的域名放在DNS请求中,以UDP报文方式发给本地域名服务器。本地的域名服务器查到域名后,将对应的IP地址放在应答报文中返回。

运维DNS原理配置

dns查询:

递归查询:主机向本地域名服务器的查询一般都是采用递归查询,只发出一次请求。

迭代查询:本地域名服务器向根域名服务器的查询的迭代查询,发出多次请求。

运维DNS原理配置

以上简单理解来说,主机1访问主机2的域名a.zz.com,首先向本机域名服务器发起请求主机2的ip,本机没有,向根域名服务器查询,根返回消息说*域名服务器那里知道,本机又向*域名服务器查询,*域名服务器又返回消息说二级域名服务器那里有答案,本机又向二级域名查询,最后经过本机域名服务器的缓存之后,返回主机2的域名对应的ip地址。

四、资源记录

数据库中的每一个条目称作一个资源记录(Resource Record,RR)

资源记录的格式:

$TTL 600;

NAME            [TTL]            IN            RRT            VALUE

www.ss.com                        IN            A            1.1.1.1

1.1.1.1                        IN            PTR            www.ss.com

资源记录类型(RRT):

SOA(start of authority)

ZONE_NAME    TTL        IN    SOA        FQDN        ADMINISTRATOR_MAILBOX(

serial number 版本号

refresh    刷新时间

retry    重试时间

expire    过期时间

na ttl )    否定答案的ttl

时间单位:M(分钟)、H(小时)、D(天)、W(周),默认单位是秒

邮箱格式:admin@ss.com -写为-> admin.ss.com

@:也就是ZONE_NAME

NS(Name Server): ZONE_NAME --> FQDN

magedu.com.        600        IN        NS        ns1.magedu.com.

ns1.magedu.com.    600        IN        A        1.1.1.2

MX(Mail eXchanger): ZONE_NAME --> FQDN

ZONE NAME    TTL        IN        MX pri        VALUE

优先级:0-99,数字越小级别越高

magedu.com.    600        IN        MX    10    mail.magedu.com.

mail.magedu.com.    600        IN    A    1.1.1.3

A(address):    FQDN-->IPv4

AAAA:FQDN-->IPv6

PTR(pointer):IP-->FQDN

CNAME(Canonical NAME): FQDN-->FQDN

www2.magedu.com.        IN        CNAME        www.magedu.com.

TXT:文本字符串

DNS区域:

正向区域文件

magedu.com.        IN        SOA

www.maged.com.   IN    A    192.168.0.1

简写为:

www          IN    A    192.168.0.1

反向区域文件

0.168.192.in-addr.arpa.       IN    SOA

1.0.168.192.in-addr.arpa.      IN    PTR        www.magedu.com.

简写为:

1       IN       PTR       www.magedu.com.

区域传送

区域传送的类型:

完全区域传送: axfr

增量区域传送:ixfr

区域类型:

主区域:master

从区域:slave

提示区域:hint

转发区域:forward

五、DNS BIND安装配置

DNS所用的最常用软件为BIND

bind:

运维DNS原理配置

/etc/named.conf

BIND进程的工作属性

区域的定义

/etc/rndc.key

rndc: Remote Name Domain Controller

密钥文件

配置信息:/etc/rndc.conf

/var/named/

区域数据文件

bind-chroot:为了提高系统安全新,把系统中的一个子目录作为bind运行时的目录。

默认:named

用户:named

组:named

/var/named/chroot/

etc/named.conf

etc/rdnc.key

sbin/named

var/named/

安装配置:

1.安装bind,查看是否安装成功

yum -y install bind bind-utils bind-chroot

rpm –qa | grep "^bind"

2.修改/etc/named.conf

listen-on port 53 { any; };

3.修改/etc/named.rfc1912.zones

运维DNS原理配置

4.添加所需要的zone文件

在/var/named目录下添加正向解析文件named.yan和反向解析文件named.222

运维DNS原理配置

运维DNS原理配置

5.检查语法

 named-checkconf

 named-checkzone "区域名" 区域文件路径

运维DNS原理配置

6.修改/etc/resolv,并启动服务。

运维DNS原理配置

systemctl start named

7.nslookup测试,或者使用dig命令。

正向解析测试:

运维DNS原理配置

反向解析测试:

运维DNS原理配置

运维DNS原理配置的更多相关文章

  1. nginx基本运维及常用配置

    nginx基本运维及常用配置 ========================================================== 基本运维 nginx 的启动 nginx -c /p ...

  2. Python自动化运维——DNS处理模块

    Infi-chu: http://www.cnblogs.com/Infi-chu/ 模块:dnspython 功能: 支持所有的记录类型 可以用于查询.传输并动态更新ZONE信息 支持TSIG(事务 ...

  3. 菜鸟运维笔记:配置Apache二级域名及WWW訪问

    事实上www訪问也能够理解为二级域名的一种. 域名 比方.com..org..edu..gov..info..net等等都是一级域名,或称*域名. 其详细格式是 *.*域名,比方csdn.net. ...

  4. linux运维之路配置网络

    前言裸机上装操作系统,想和物理机通信需要设置IP 开机以后: 第一步:setup命令  ——>  NetWork configguation  ---->Device configurat ...

  5. HBase运维基础--元数据逆向修复原理

    背景 鉴于上次一篇文章——“云HBase小组成功抢救某公司自建HBase集群,挽救30+T数据”的读者反馈,对HBase的逆向工程比较感兴趣,并咨询如何使用相应工具进行运维等等.总的来说,就是想更深层 ...

  6. 更优雅的配置:docker/运维/业务中的环境变量

    目录 docker-compose 环境变量 .env 文件 env_file docker stack 不支持基于文件的环境变量 envsubst envsubst.py 1. 使用行内键值对 2. ...

  7. python自动化运维篇

    1-1 Python运维-课程简介及基础 1-2 Python运维-自动化运维脚本编写 2-1 Python自动化运维-Ansible教程-Ansible介绍 2-2 Python自动化运维-Ansi ...

  8. MySQL服务器的运维与优化

    MySQL运维 安装数据库 配置本地yum源,将gpmall-repo文件上传至/opt目录 创建yum.repo文件 安装mariadb服务 # yum install -y mariadb mar ...

  9. Linux运维实战之DNS(bind)服务器的安装与配置

    转自http://sweetpotato.blog.51cto.com/533893/1598225 上次博文我们讨论了DNS的基础,本次博文我们重点来看看如何配置一台DNS服务器. [本次博文的主要 ...

随机推荐

  1. Velocity 语法(转)

    一.基本语法 1."#"用来标识Velocity的脚本语句,包括#set.#if .#else.#end.#foreach.#end.#iinclude.#parse.#macro ...

  2. 页面上有两个元素id相同,js中如何取值

    页面上有两个table,id都是”cont2",现要在js中取到这两个table,改变样式. js实现: var tab2=document.all.cont2(1);var  tab=do ...

  3. 神奇的HTML5离线存储(应用程序缓存)

    声明:本文为原创文章,如需转载,请注明来源并保留原文链接前端小尚,谢谢! 前言 使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本. HTML5引入 ...

  4. 如何学习c++

    在之后的随笔中,我作为一个c++的初学者将会把我如何学习c++的经历尽可能详细的记录下来. 这里引用了JerryZhang在他的博文里面写的一段话,当作我的座右铭. 1.多交流:不管你的技术多么硬,你 ...

  5. 2014多校第一场J题 || HDU 4870 Rating(DP || 高斯消元)

    题目链接 题意 :小女孩注册了两个比赛的帐号,初始分值都为0,每做一次比赛如果排名在前两百名,rating涨50,否则降100,告诉你她每次比赛在前两百名的概率p,如果她每次做题都用两个账号中分数低的 ...

  6. 【XSY2703】置换 数学 置换 DP

    题目描述 对于置换\(p\),定义\(f(p)\)为最小的正整数\(k\),使得\(p^k\)为恒等置换. 你需要求对于所有的\(n\)元素置换\(p\),\(f^2(p)\)的平均值. \(n\le ...

  7. GCC编译器原理(一)------GCC 工具:addr2line、ar、as、c++filt和elfedit

    1.3 GCC 工具 1.3.1 binutils 工具集 工具 描述 addr2line 给出一个可执行文件的内部地址,addr2line 使用文件中的调试信息将地址翻译成源代码文件名和行号. ar ...

  8. C++ 三/五法则

    当定义一个类时,我们显式地或隐式地指定了此类型的对象在拷贝.赋值和销毁时做什么.一个类通过定义三种特殊的成员函数来控制这些操作:拷贝构造函数.拷贝赋值运算符和析构函数. 拷贝构造函数定义了当用同类型的 ...

  9. Navicat for Oracle 绿色版 连接 Oracle 12c

    亲测可用,留下文章以备忘记. Navicat for Oracle 绿色版 地址 链接:http://pan.baidu.com/s/1qY5wMok 密码:kw06 解压到一个目录下. 然后还需要O ...

  10. class path resource [spring/applicationContext.xml] cannot be opened because it does not exist

    1.查看路径有没有写错 2.编辑器认为你的文件不是 source folders(原文件),需要你手动将文件改过来