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