上传Chef食谱失败:invalid-x-ops-server-api-version

Chef服务器:12.0.8

Chef开发包(Windows):2.1.11

C:\Data\SVN\dev\trunk\chef-repo>chef --version
Chef开发工具包版本:2.1.11
chef客户端版本:13.2.20
delivery版本:master (73ebb72a6c42b3d2ff5370c476be800fee7e5427)
berks版本:6.3.0
kitchen版本:1.17.0
inspec版本: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命令添加了详细日志记录:

knife cookbook upload acl -V -V

它显示导致错误的原因实际上是ChefDK和服务器API版本之间不匹配:

invalid-x-ops-server-api-version: "Specified version 2 not supported","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不兼容?

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

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

点赞
用户78722
用户78722

这是 ChefDK 2.x 早期版本中的一个漏洞。我们已经在我们所知道的所有情况下进行了修正。如果当前的 ChefDK(2.3.4)仍然出现此问题,请告诉我们。

2017-09-27 02:32:20