10

我正在努力将我的域的名称服务器切换到新的 DNS 服务。将新设置与现有 DNS 设置进行比较的最佳工具是什么。

我尝试使用带有和不带有 @nameserver 的 dig 来确保新旧提供商之间的 DNS 记录匹配。

至今没有成功。

有任何想法吗 ?

4

3 回答 3

20

我回答了那个老问题,我遇到了这个问题,我以这种方式解决了它:

对于单个域:

diff <(sort -u <(dig +nottlid +noall +answer @ns.myfirstserver.com example.com ANY) ) <(sort -u <(dig +nottlid +noall +answer @ns.mysecondserver.com example.com ANY) )

对于多个域或子域:

  • 逐行创建一个包含 1 个域的文本文件(例如:alldomains.txt)

命令行:

diff <(sort -u <(for host in $(cat alldomains.txt); do dig +nottlid +noall +answer @ns.myfirstserver.com $host ANY; done) ) <(sort -u <(for host in $(cat alldomains.txt); do dig +nottlid +noall +answer @ns.mysecondserver.com $host ANY; done) )

注释:

  • diff : 逐行比较文件
  • sort:对文本文件的行进行排序
  • -u:确保只有唯一的行
  • dig : DNS 查找实用程序
  • +nottlid : 打印记录时不显示 TTL
  • +noall : 清除所有显示标志
  • answer:显示回复的权限部分。
  • @ns.server.com : 要查询的名称服务器的名称或 IP 地址
  • ANY:表示需要什么类型的查询(ANY、A、MX、SIG 等)

> myresult.txt您可以通过在末尾添加来重定向到文件。

我希望这可以帮助某人。

于 2015-03-16T14:55:59.520 回答
1

是的!从代码源的回答中得到灵感,我创建了这个来检查一个已知的区域文件。由于 ANY 查询不输出完整区域。

输入是绑定格式的区域文件,第一个字段是强制性且完整的!尚不支持空的第一个字段或缩短!

zone=test.txt; ns1=ns1.test.com; ns2=ns2.test.com; \
zcl=$(basename ${zone} .txt)_cl.txt; zl1=$(basename ${zcl} .txt)_${ns1}.log; zl2=$(basename ${zcl} .txt)_${ns2}.log; \
echo "Diffing the stuff in $zcl (from $zone) for $ns1 <-> $ns2" >&2 ;echo " loggings to $zl1, $zl2" >&2 ; \
cat $zone | awk 'BEGIN {IFS=" "} $1 !~ /^;|^[[:space:]]+|^$/ {t=$4; if (!match($2,/[[:digit:]]/)) t=$3; n=$1; print n " " t }' | sort -u > $zcl ; \
diff <(sort -u <(while read host type; do echo "Q $host $type" >&2; dig +nottlid +noall +answer @$ns1 $host $type; done < $zcl) | tee $zl1 ) \
     <(sort -u <(while read host type; do dig +nottlid +noall +answer @$ns2 $host $type; done < $zcl) | tee $zl2 ) && echo "OK"
于 2019-06-26T08:31:56.247 回答
1

该脚本用于在迁移期间比较两个区域文件。

它使用颜色编码和最终状态输出来指示哪些记录不同

SOA 和 NS 记录在迁移期间会有所不同 - 请注意差异

任何记录也可能会有所不同,因为它包含上述类型。

A MX 和 TXT 记录应该是相同的,如果它们存在的话——这里的不同意味着有问题!

查看示例屏幕截图

来源:https ://github.com/geek4unix/compare-zones/

于 2021-05-14T22:17:40.447 回答