2017-09-26 68 views
0

厨师服务器:12.0.8厨师食谱上传失败:无效-X-OPS-服务器API版本

ChefDK(Windows)中:2.1.11

C:\Data\SVN\dev\trunk\chef-repo>chef --version 
Chef Development Kit Version: 2.1.11 
chef-client version: 13.2.20 
delivery version: master (73ebb72a6c42b3d2ff5370c476be800fee7e5427) 
berks version: 6.3.0 
kitchen version: 1.17.0 
inspec version: 1.33.1 

这个问题开始了错误:

C:\Data\SVN\dev\trunk\chef-repo>knife cookbook upload acl 
C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/json_compat.rb:35:in `rescue in parse': input must be a string or IO (Chef::Exceptions::JSON::ParseError) 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/json_compat.rb:33:in `parse' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/json_compat.rb:40:in `from_json' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/knife.rb:511:in `humanize_http_exception' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/knife.rb:455:in `humanize_exception' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/knife.rb:446:in `rescue in run_with_pretty_exceptions' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/knife.rb:436:in `run_with_pretty_exceptions' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/knife.rb:219:in `run' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/lib/chef/application/knife.rb:156:in `run' 
     from C:/opscode/chefdk/embedded/lib/ruby/gems/2.4.0/gems/chef-13.2.20-universal-mingw32/bin/knife:25:in `<top (required)>' 
     from C:/opscode/chefdk/bin/knife:275:in `load' 
     from C:/opscode/chefdk/bin/knife:275:in `<main>' 

这是突然​​发生的所有食谱。

所以我们增加了详细的记录,以刀命令:

knife cookbook upload acl -V -V 

这表明错误实际上是从ChefDK和服务器API版本之间的不匹配来:

无效-X-ops-服务器API的版本: “指定的版本2不支持”, “MIN_VERSION”:0 “MAX_VERSION”:1

DEBUG: ---- HTTP Status and Header Data: ---- 
DEBUG: HTTP 1.1 406 Not Acceptable 
DEBUG: server: openresty/1.7.10.1 
DEBUG: date: Tue, 26 Sep 2017 23:33:12 GMT 
DEBUG: content-length: 122 
DEBUG: connection: close 
DEBUG: x-ops-api-info: flavor=cs;version=12.0.0;oc_erchef=1.6.4 
DEBUG: ---- End HTTP Status/Header Data ---- 
DEBUG: ---- HTTP Response Body ---- 
DEBUG: {"error":"invalid-x-ops-server-api-version","message":"Specified version 2 not supported","min_version":0,"max_version":1} 
DEBUG: ---- End HTTP Response Body ----- 

这是否意味着ChefDK v2与Chef Server v12不兼容?

根据他们的文档,厨师12支持的API版本0到3:

https://github.com/chef/chef-rfc/blob/master/rfc041-server-api-versioning.md

+0

我们使用chef-server-core_12.16.14-1_amd64.deb升级了Chef服务器,现在我们可以上传食谱了。 – Alan

回答

0

这是ChefDK 2.x的一些早期版本中的错误在所有我们知道的情况下,它都被纠正了。请让我们知道,如果这仍然发生在当前ChefDK(2.3.4)。