CNAME记录

✍ dations ◷ 2024-12-22 18:19:34 #CNAME记录

真实名称记录(英语:Canonical Name Record),即CNAME记录,是域名系统(DNS)的一种记录。CNAME记录用于将一个域名(同名)映射到另一个域名(真实名称),域名解析服务器遇到CNAME记录会以映射到的目标重新开始查询。

这对于需要在同一个IP地址上运行多个服务的情况来说非常方便。若要同时运行文件传输服务和Web服务,则可以把和都指向DNS记录,而后者则有一个指向IP地址的A记录。如此一来,若服务器IP地址改变,则只需修改的A记录即可。

CNAME记录必须指向另一个域名,而不能是IP地址。

《RFC 1034》详细定义了CNAME记录的标准,并在《RFC 2181》的第十节中做了进一步规范。

CNAME记录在域名系统中的使用有诸多限制。当一个DNS解析服务器在查询各类记录时遇到一则CNAME记录时,它会立即重启查询,查询所映射到域名的对应记录。(除非是要查询CNAME记录本身,在那种情况下会返回所映射到的域名。)CNAME记录所映射的域名可以是域名服务中的任何域名。在同一服务器上,在远程服务器上,甚至在属于不同DNS zone(解析空间)的服务器上,都可以。

假设有下述DNS zone:

NAME                    TYPE   VALUE--------------------------------------------------bar.example.com.        CNAME  foo.example.com.foo.example.com.        A      192.0.2.23

当要查询的A记录时,域名解析器会查到对应的CNAME记录,即,随即开始查询该域名的A记录,查到192.0.2.23则返回结果。

可以使用CNAME记录将“”指向“”。因此,可能会有人随意的将称作是的“CNAME”。然而事实并非如此,的“CNAME”是,因为CNAME的意思是真实名称,而右侧才是真实名称,才是CNAME。

这则误会在《RFC 2181》“DNS规范的解释”一章中有提到。应当说左侧标签是右侧真实名称的一个同名。即下述CNAME记录:

bar.example.com.        CNAME  foo.example.com.

应当读作:

的真实名称是。请求访问的客户端会得到返回的结果。

foo.example.com.  CNAME  bar.example.com.bar.example.com.  CNAME  foo.example.com.
  • MX记录和NS记录永远都不应指向由CNAME记录标记的域名(《RFC 2181》第10.3节)。因此,解析空间不应有下述结构:
example.com.      MX     0   foo.example.com.foo.example.com.  CNAME  host.example.com.host.example.com. A      192.0.2.1
  • 根据(《RFC1912》)第2.4节,根网域(Root Domain)不应该被添加 CNAME 纪录。但部分 DNS 服务商(例如 DNSPod、NS1)可以忽略该 RFC 标准而针对根网域做出 CNAME 解析,比如:
example.com.  CNAME  foo.example.com.

但这样做会导致该网域若有用于邮箱服务,则可能造成错误,详见如下方。

而愿意遵守 RFC 标准的 DNS 供应商 (例如 Neustar UltraDNS、Cloudflare DNS)则采用了 Apex Alias 或 CNAME flattening 技术,这个技术将使得由 DNS 服务商自行处理 CNAME 解析的过程,并将最终解析的 A 纪录作为实际解析的结果,从而不与 RFC 标准抵触,比如:

example.com.  A      192.0.2.1
  • 用于邮箱服务的域名不应有CNAME记录。在实践中,这或许不会出错,但由于邮件服务的不同,可能会有意料之外的效果。

DNAME记录

DNAME记录,即代理名称记录,由《RFC 6672》定义(原《RFC 2672》已经废弃)。一条DNAME记录会将某个域名的整个解析子树映射到另一域名,而CNAME只映射设定的域名,不映射子域名。如同CNAME一样,在DNS查询过程中,会查找所映射到的新域名的地址。域名解析服务器会为每一个被查询的子域名生成一则CNAME记录。为某个域名设置DNAME记录和为该域名的所有子域名设置CNAME记录的效果是一样的。

例如下述记录:

foo.example.com.        DNAME  bar.example.com.bar.example.com.        A      192.0.2.23xyzzy.bar.example.com.  A      192.0.2.24*.bar.example.com.      A      192.0.2.25

查询的A记录不会返回任何结果。不同于CNAME记录,DNAME不会直接影响所设置域名的解析。

如果我们需要查询,则由于DNAME记录的映射会返回的A记录,即192.0.2.24。而如果将DNAME记录换成是CNAME记录的话,这样的请求则会报错提示无法找到。

由此,查询会由于DNAME记录映射返回192.0.2.25。

部分DNS平台支持尚未被标准化的ALIAS或ANAME记录类型。此类伪记录由DNS服务器维护,类似于CNAME记录,但在(某些)客户端解析时等同于A记录。ANAME记录通常会被设置指向另一域名。但在被客户端请求时候,则会直接返回对应的IP地址。ANAME记录的标准化过程正在进行中,但已经有许多不同的实现,所以由于平台的不同,效果也多种多样。有些存在于域名解析区的顶端,有些则为了提供邮件服务而存在。ANAME记录相对CNAME记录的一大优势是速度。服务端解析A记录的速度通常比客户端快,同时可以缓存对应的IP地址以备查询。IETF正在讨论和考虑ANAME记录的标准化。

相关

  • 门部,为汉字索引中的部首之一,康熙字典214个部首中的第一百六十九个(八划的则为第三个)。就繁体中,门部归于八划部首,而简体中文则归在三划。门部只以上方包围为部字。且无其他部
  • 欧洲原产地命名保护原产地名称保护标识是一个欧盟提供的证明商标,用于“标明生产、加工和制备全都在指定的地理区域内进行的、使用地区本地的生产者认可的技术和相关地区的配料的产品”。此标识
  • 杜立特空袭东南亚地区:缅甸:西南太平洋地区:北美地区:日本:满洲地区:空袭东京,亦常称杜立特空袭(英语:Doolittle Raid),是美国于第二次世界大战期间的1942年4月18日时,向日本本土首次进行的空中轰
  • 圣克鲁斯群岛战役圣克鲁斯群岛战役(Battle of the Santa Cruz Islands)发生于1942年10月26日,有时称为圣克鲁斯战役或南太平洋海战,是第二次世界大战太平洋战场上第4场航母战役。同时也是美国海
  • 拉纳康拉纳康是一家位于多伦多的软件公司, 由前德拉里纳执行董事托尼·戴维斯创立。专注于制作互联网内容软件。1997年初,该公司发布了一个名为“Headliner”的产品,是一个自动整理
  • 乌兹别克斯坦语言大部分乌兹别克斯坦的语言都属于突厥语系。其中,乌兹别克语是乌兹别克斯坦的第一官方语言,而俄语是当地不同民族间交流使用的语言,通常被视为第二官方语言。在突厥语系中,乌兹别
  • 你还是不懂群马《你还是不懂群马》(日语:お前はまだグンマを知らない)是日本漫画家井田博人(日语:井田ヒロト)的漫画作品。于2013年10月起在新潮社的漫画杂志《月刊Comic@Bunch(日语:月刊コミック@
  • 查卡纳火山查卡纳火山是厄瓜多尔的火山,位于该国北部,距离首都基多约30公里,属于安第斯山脉的一部分,最近一次火山喷发在1773年发生。
  • 凌毓勋凌毓勋(1926年-2006年1月29日),男,贵州贵阳人,中华人民共和国政治人物,曾任中华人民共和国物资部副部长,第七、八届全国政协委员。
  • 6吋47倍径舰炮Mk 16型6吋47倍径舰炮(英语:6"/47 caliber Mark 16 naval gun)是美国海军于战前和第二次世界大战当中采用的6英寸(152毫米)轻巡洋舰舰载主炮。它们主要搭载在三联装炮塔以内,并且用于打击地面、水面目标。而Mk 16DP型6吋47倍径舰炮(英语:6"/47 caliber Mark 16DP naval gun)是Mk 16的高平两用炮,可用于打击飞机和水面舰艇。它搭载于战后的伍斯特级轻巡洋舰和密西西比号(BB-41)防空炮兵训练舰。还有Mk 17型6吋47倍径舰炮(英语