PowerDNS和CNAME到外部域

PowerDNS和CNAME到外部域,dns,external,cname,powerdns,Dns,External,Cname,Powerdns,我正在为我的客户端使用PowerDNS(2.9.22)。因为它可以将所有数据存储到MySQL数据库中,并且客户端可以轻松地编辑他们喜欢的区域 现在我对CNAMEs有一个问题: 以下是MySQL数据库中的记录: +-----------------------+-------+-----------------------+ | localhost.example.com | A | 127.0.0.1 | +-----------------------+----

我正在为我的客户端使用PowerDNS(2.9.22)。因为它可以将所有数据存储到MySQL数据库中,并且客户端可以轻松地编辑他们喜欢的区域

现在我对CNAMEs有一个问题:

以下是MySQL数据库中的记录:

+-----------------------+-------+-----------------------+
| localhost.example.com |   A   | 127.0.0.1             |
+-----------------------+-------+-----------------------+
| a.example.com         | CNAME | localhost.example.com |
+-----------------------+-------+-----------------------+
| www.example.com       | CNAME | andreyzentavr.com     |
+-----------------------+-------+-----------------------+
PowerDNS配置在这里:

allow-recursion=127.0.0.1, 173.193.**.162, 173.193.**.163
allow-recursion-override=on
cache-ttl=20
config-dir=/etc/powerdns
daemon=yes
default-soa-name=ns3.bserver.com
disable-axfr=yes
guardian=no
launch=gmysql
gmysql-host=127.0.0.1
gmysql-port=3306
gmysql-user=powerdns
gmysql-dbname=powerdns
gmysql-password=123123
lazy-recursion=yes
local-address=173.193.**.162, 173.193.**.163
local-port=53
log-dns-details=yes
log-failed-updates=yes
logfile=/var/log/pdns.log
loglevel=6
master=yes
max-queue-length=5000
max-tcp-connections=10
module-dir=/usr/lib/powerdns
query-logging=yes
recursor=127.0.0.1:53
setgid=pdns
setuid=pdns
skip-cname=no
slave=yes
slave-cycle-interval=600
soa-minimum-ttl=3600
soa-refresh-default=10800
soa-retry-default=3600
soa-serial-offset=0
socket-dir=/var/run
use-logfile=yes
wildcards=yes
version-string=powerdns
在执行nslookup查询时,我得到了以下结果:

server:~# nslookup
> set q=any
> server ns3.***.com
Default server: ns3.***.com
Address: 173.193.**.163#53
> a.example.com
Server:         ns3.***.com
Address:       173.193.***.163#53

a.example.com      canonical name =localhost.example.com.
Name: localhost.example.com
Address: 127.0.0.1
>
>
> www.example.com
Server:         ns3.***.com
Address:       
173.193.***.163#53

** server can't find www.example.com: NXDOMAIN
正如您所看到的,如果CNAME指向内部记录,那么一切都会很好地解决。但如果它指向外部域-我有一个错误

andreyzentavr.com是现有域,指向194.126.204.41


是PowerDNS中的bug吗?还是配置错误?

通常,使用DNS,如果您想将CNAME指向外部记录,必须在记录的末尾添加句点(
sub.domain.com.
)。当您取消最后一个点时,DNS将其解释为一个相对记录(例如,
sub.domain.com
将被解释为
sub.domain.com.domain


我假设,由于您在数据库中设置了
localhost.example.com
的“A”记录,PowerDNS看到并知道您要指向的域,即使您没有将另一个CNAME设置为绝对(
localhost.example.com.
)或相对(只是主机名中的
localhost
).

解决方案是将递归器放在权威服务器前面,并使用forward zones recurse指令将递归器配置为将特定域转发到权威服务器。需要3.2版本的递归程序。

我认为您的
默认soa名称
包括您试图从帖子中删除的域名。实际上,PowerDNS不需要记录末尾的句点。