首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Nsupdate,获取错误

Nsupdate,获取错误
EN

Stack Overflow用户
提问于 2012-01-05 23:29:17
回答 3查看 5.3K关注 0票数 4

我试图使用在名称服务器内部执行的nsupdate更新名称,但收到错误消息; TSIG error with server: tsig indicates error

我用dnssec-keygen -a hmac-md5 -b 512 -n HOST -r /dev/urandom dyn.mydomain.com.创建了一个密钥,并将密钥复制到named.conf中。

我的named.conf如下

代码语言:javascript
复制
key "dyn.mydomain.com." {
   algorithm hmac-md5;
   secret "T2DjtGkGAzPAVrL6zar9GpxjNQ1iOjJzWKhPsF5gu0xQbaONhK7ZmC0n WKatgbGEHqla1uoxG3FdktQPolMIjQ==";
};
zone "dyn.mydomain.com." {
   type master;
   file "/var/cache/bind/dyn.mydomain.com.hosts";
   allow-update {
       key "dyn.mydomain.com.";
   };
};

文件dyn.mydomain.com.hosts如下所示:

代码语言:javascript
复制
$ORIGIN .
$TTL 8400       ; 2 hours 20 minutes
dyn.mydomain.com  IN SOA  ns. root. (
                           2007072513 ; serial
                           7200       ; refresh (2 hours)
                           900        ; retry (15 minutes)
                           1857600    ; expire (3 weeks 12 hours)
                           8400       ; minimum (2 hours 20 minutes)
                           )
                   NS      ns.dyn.mydomain.com.
$ORIGIN dyn.mydomain.com.
ns                      A       [ip of this name server]
$TTL 60 ; 1 minute

我重新添加了bind9,然后使用

代码语言:javascript
复制
nsupdate -v -d -k /etc/bind/Kdyn.mydomain.com.+157+53489.private
> server localhost
> zone dyn.mydomain.com
> update add test.dyn.mydomain.com IN A 80.80.80.80
> send

Sending update to 127.0.0.1#53
Outgoing update query:
;; ->>HEADER<<- opcode: UPDATE, status: NOERROR, id:  50553
;; flags: ; ZONE: 1, PREREQ: 0, UPDATE: 1, ADDITIONAL: 1
;; ZONE SECTION:
;dyn.mydomain.com.                   IN      SOA

;; UPDATE SECTION:
test.dyn.mydomain.com.       60      IN      A       80.80.80.80

;; TSIG PSEUDOSECTION:
dyn.mydomain.com.            0       ANY     TSIG    hmac-md5.sig-alg.reg.int. 1325777156 300 16 5k3AkgLuCziNKtaeb39MRE== 50553 NOERROR 0

; TSIG error with server: tsig indicates error

Reply from update query:
;; ->>HEADER<<- opcode: UPDATE, status: NOTAUTH, id:  50553
;; flags: qr ra ; ZONE: 0, PREREQ: 0, UPDATE: 0, ADDITIONAL: 1
;; TSIG PSEUDOSECTION:
dyn.mydomain.com.            0       ANY     TSIG    hmac-md5.sig-alg.reg.int. 1325777156 300 0  50553 BADKEY 0

可能的原因是什么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-09-17 05:36:46

我想在这里跟进,因为我有这个特殊的问题,我可以比“你的秘密似乎是错的”更好地解释解决方案,尽管我没有冒犯的意思。由于某种原因,dnssec-keygen在我的私钥中间插入了一个错误的空格()。当我消除这个空间时(就像你在你的秘密中所做的那样),世界上一切都很好。试着去掉秘密中间的一小块地方:

代码语言:javascript
复制
secret "T2DjtGkGAzPAVrL6zar9GpxjNQ1iOjJzWKhPsF5gu0xQbaONhK7ZmC0n WKatgbGEHqla1uoxG3FdktQPolMIjQ==";

..。实际上可能是:

代码语言:javascript
复制
secret "T2DjtGkGAzPAVrL6zar9GpxjNQ1iOjJzWKhPsF5gu0xQbaONhK7ZmC0nWKatgbGEHqla1uoxG3FdktQPolMIjQ==";

我知道这是一个古老的问题,但是这个特殊的问题帮助我解决了我的问题,那就是空格。

票数 2
EN

Stack Overflow用户

发布于 2012-05-10 21:00:55

代码语言:javascript
复制
secret "T2DjtGkGAzPAVrL6zar9GpxjNQ1iOjJzWKhPsF5gu0xQbaONhK7ZmC0n WKatgbGEHqla1uoxG3FdktQPolMIjQ=="

似乎是错的。

从.private文件中复制"Key:“后面的密钥。

票数 3
EN

Stack Overflow用户

发布于 2016-07-25 08:55:17

另一个常见问题是密钥名称不匹配,即生成的名称:使用dnssec-keygen给定的名称必须与named.conf.local的密钥名称相同!

例如:

代码语言:javascript
复制
dnssec-keygen -a hmac-md5 -b 512 -n HOST -r /dev/urandom dyn.mydomain.com.

将不会在此配置下运行:

代码语言:javascript
复制
key "key.mydomain.com." {
   algorithm hmac-md5;
   secret "T2DjtGkGAzPAVrL6zar9GpxjNQ1iOjJzWKhPsF5gu0xQbaONhK7ZmC0n WKatgbGEHqla1uoxG3FdktQPolMIjQ==";
};

拖尾。对于键名称的末尾,似乎不会产生问题。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8745057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档