❤️💕💕计算机网络--TCP/IP 学习。Myblog:http://nsddd.top
[TOC]
- 域名系统(DNS)是互联网的一项服务。它作为将域名和IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。
- DNS使用TCP和UDP端口53。
- DNS每一级域名长度的限制是63个字符,域名总长度则不能超过253个字符。
- dns用于转换主机名和IP地址。
- 它是应用层协议,体现在:
- 是C/S架构
- 端到端发送dns报文
- 与其他应用层协议不同的是,dns主要为其他应用层协议服务,而不是直接面向用户。
- 主机记录(A记录):用于名称解析的重要记录,将特定的主机名映射到对应主机的IP地址上。
- 别名记录(CNAME记录): 将某个别名指向到某个A记录上,这样就不需要再为某个新名字另外创建一条新的A记录。
- IPv6主机记录(AAAA记录): 用于将特定的主机名映射到一个主机的IPv6地址。
- 服务位置记录(SRV记录): 用于定义提供特定服务的服务器的位置,如主机(hostname),端口(port number)等。
- NAPTR记录:提供了正则表达式方式去映射一个域名。NAPTR记录非常著名的一个应用是用于ENUM查询。
- MX记录:记录邮件服务器的别名。某公司的web服务器可以和邮件服务器共享别名。
- NS记录:记录从哪个dns服务器可以获得某个域(如foo.com)的dns记录,即用于记录查询链。
- 映射域名与IP地址,并提供别名
- 为邮件服务器提供别名
- 负载分配(一个域名多个IP的时候)
dns整体的工作主要围绕在主机和IP地址映射上面
DNS查询有两种方式:递归和迭代。DNS客户端设置使用的DNS服务器一般都是递归服务器,它负责全权处理客户端的DNS查询请求,直到返回最终结果。而DNS服务器之间一般采用迭代查询方式。
- 从请求主机到
DNS
服务器是递归查询 - 除此之外,其余的查询都是迭代查询
以查询zh.wikipedia.org为例:
- 客户端发送查询报文"query zh.wikipedia.org"至DNS服务器,DNS服务器首先检查自身缓存,如果存在记录则直接返回结果。
- 如果记录老化或不存在,则
域名的划分是在逻辑上的划分
网络的划分则是物理上的划分
为了解决扩展性问题(集中式架构不易扩展),DNS使用了大量的DNS服务器,它们以层次方式组织(解决重名),并且分布在全世界的范围内,没有一台DNS服务器拥有因特网上所有主机的映射。
- dns具有分布式分层次解构
- dns能够缓存
dns记录往往由四部分组成。
- Type:标志这是一条什么记录,见dns记录了什么
- Value:Name的对应值
- Name:Value的对应值
- TTL:本记录应该在缓存中呆多久
- 前12字节为首部域包括
- 标识符(16bit数字):查询的唯一标识
- 标志(0 or 1):0是查询 1是回答
- 查询问题区包括
- 名字字段:主机名
- 类型:想查什么记录
- 回答区:根据问题来回答,可能由多个回答
- 授权区即权威区,包含其他权威服务器的记录
- 附加区是一些备注信息
我们需要向DNS数据库中插入数据
应该向注册登记机构注册自己的网络域名和IP地址,才能被查询到。
dns大多数情况下是安全的。
- 对于
DDos
攻击,DNS有包过滤系统和缓存服务,仅在DDos
攻击指向顶级服务器的时候稍微有些困扰。 - 可以被中间人攻击(伪造回答哄骗客户主机)和DNS毒害攻击(伪造回答哄骗下一级dns服务器来缓存,从而欺骗客户主机),但是技术上很难实现。
- dns服务器本身可被利用于攻击其他服务器,但是至今为止只是个例。
domain name system 域名系统:
字段对应的字节数:
::: tip 当然这个只是查询问题,还有回答:
这个就大很多了:
:::
dns 相关的程序和代码:
# nameserver结构体
type NS struct {
Host string
}
# srv记录 指定该域名由哪个DNS服务器来进行解析
type SRV struct {
Target string
Port uint16
Priority uint16
Weight uint16
}
# dns正向解析(域名解析到cname或者实际的ip地址)
## 仅返回指定域名name的cname地址
func LookupCNAME(name string) (cname string, err error)
## 直接返回域名解析到地址.
func LookupHost(host string) (addrs []string, err error)
## 直接返回域名解析到地址,[]IP结构体.可以对具体ip进行相关操作(是否回环地址,子网,网络号等)
# type IP []byte
func LookupIP(host string) (addrs []IP, err error)
## DNS反向解析(ip地址反向解析查找解析到的域名)
# 根据ip地址查找主机名地址(必须得是可以解析到的域名)[dig -x ipaddress]
func LookupAddr(addr string) (name []string, err error)