0

我目前正在 CentOS VM 上学习 Chef + Test Kitchen,似乎每次运行时kitchen converge,一些包都会失​​败并抛出相同的错误:

Chef::Exceptions::Exec
----------------------

returned 1, expected 0

并且所有错误都位于package资源中。例如:

Compiled Resource:
------------------
# Declared in /tmp/kitchen/cookbooks/nginx/recipes/package.rb:39:in `from_file'

package("nginx") do
     action :install
     retries 0
     retry_delay 2
     guard_interpreter :default
     package_name "nginx"
     version "1.0.15-5.el6"
     cookbook_name :nginx
     recipe_name "package"
end

但是,当我使用登录到 VMkitchen login并手动运行

yum install nginx

它运行正常。kitchen converge此外,有时当我第二次运行时它安装得很好。

我的食谱文件是:

# create vtapp user
user node.default['railsapp']['user'] do
supports :manage_home => true
system true
home "/home/#{node.default['railsapp']['user']}"
shell '/bin/bash'
end

# install git
package 'git'

# install mysql and run the service
mysql_service 'default'

# install redis and run the service
include_recipe 'redis::server'

# install rbenv to vtapp user, and install ruby 2.1.0 along with bundler
include_recipe "ruby_build"
node.default['rbenv']['user_installs'] = [
    {
        'user' => node.default['railsapp']['user'],
    'rubies' => ['2.1.0'],
    'gems' => {
      '2.1.0' => [
        { 'name' => 'bundler' }
      ]
    }
    }
]
include_recipe "rbenv::user"

# install monit
include_recipe "monit"

# install nginx
include_recipe "nginx"

我错过了什么?

4

1 回答 1

1

好吧,看起来很疯狂,在我将 Vagrant 的内存分配增加到 1024 MB 之后,如下链接中所述:

https://github.com/test-kitchen/kitchen-vagrant/issues/22

上面的间歇性问题突然消失了......

更新:

kitchen test增加内存分配后,我已经成功地反复运行完整命令:-)

更新(2):

我对 Chef 进行了更多研究,另一个可能的原因是 Chef 中设置的执行操作的超时时间,如果我没记错的话是 15 分钟。我使用的可能解决方案是 1) 安装代理服务器以加快下载时间,2) 增加互联网带宽,3) 允许 vagrant 为 VM 分配更多 CPU 内核。

您还必须注意应用程序所需的最小内存。例如,我安装了带有 Chef 的 ZenOSS,它至少需要 3 GB 内存,如果我分配的内存低于该值,就会出现上面的错误代码。

于 2014-05-05T11:05:01.753 回答