chef server api 调用返回401

最近公司的chef server api在调用时忽然就返回401, 因为最近没有变更操作,所以不知道从何处查找原因。

后来查看了chef的官方文档,发现401错误是由于请求资源不存在或者计算的SIGN错误产生的。

所以首先检查了SIGN,发现和以前正常的情况一致。然后使用knife命令在workstation上查找了请求的资源,发现资源是有的。

然后想在chef server上查找到相关报错的日志,首先检查了nginx,只有在access log 中找到了调用返回401的记录。然后查找了erchef的日志,没有找到错误日志。

后来就查看了chef server源码,发现在调用chef server api的时候需要传入timestamp, 请求的timestamp 和 chef server的差距较大时(15 min以上)也会报401。

后来想到云主机的chef-client在注册的时候,如果客户端机器和chef server的时间大于15min,也会报401错误.

 

然后就有了解决办法,直接使用NTP同步chef client和chef server的机器时间,时间同步后就可以调用成功。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值