2015-05-04 88 views
2

我是廚師的新手,並開始使用用戶庫編寫簡單的食譜。我Berksfile:致命錯誤:NoMethodError:未定義的方法`unreachable_cookbook?'爲零:NilClass

[email protected]:~/chef-repo$ cat Berksfile 
site :opscode 

cookbook "users" 

,然後我跑:

berks install 

和我的食譜:

[email protected]:~/chef-repo$ ls cookbooks/ 
users 

終於我的食譜:

[email protected]:~/chef-repo$ cat blah-users.rb 
include_recipe "users" 

users_manage "blah-dev" do 
    group_id 1001 
    action [ :remove, :create ] 
end 

當我appply我得到一個錯誤:

[email protected]:~/chef-repo$ chef-apply blah-users.rb 
[2015-05-04T09:05:48-04:00] FATAL: Stacktrace dumped to /home/name/.chef/cache/chef-stacktrace.out 
[2015-05-04T09:05:48-04:00] FATAL: NoMethodError: undefined method `unreachable_cookbook?' for nil:NilClass 

我相當肯定的是,include_recipe「用戶」是問題(至少第一個)。我也發現這行Stacktrace轉儲到/home/name/.chef/cache/chef-stacktrace.out有趣的是,在那個位置沒有文件。

我嘗試過和沒有sudo。所以我不認爲這是一個權限問題。

我運行一個本地安裝的廚師服務器12.3看起來能正常運行罰款......

感謝


~/chef-repo$ sudo chef-apply blah-users.rb -l debug 

[2015-05-04T13:17:50-04:00] DEBUG: Building node object for tbrown 
[2015-05-04T13:17:50-04:00] DEBUG: Extracting run list from JSON attributes provided on command line 
[2015-05-04T13:17:50-04:00] DEBUG: Applying attributes from json file 
[2015-05-04T13:17:50-04:00] DEBUG: Platform is ubuntu version 14.04 
[2015-05-04T13:17:50-04:00] INFO: Run List is [] 
[2015-05-04T13:17:50-04:00] INFO: Run List expands to [] 
[2015-05-04T13:17:50-04:00] DEBUG: Loading Recipe users via include_recipe 
[2015-05-04T13:17:50-04:00] FATAL: Stacktrace dumped to /var/chef/cache/chef-stacktrace.out 
[2015-05-04T13:17:50-04:00] DEBUG: NoMethodError: undefined method `unreachable_cookbook?' for nil:NilClass 
/opt/chefdk/embedded/apps/chef/lib/chef/run_context.rb:257:in `unreachable_cookbook?' 
/opt/chefdk/embedded/apps/chef/lib/chef/run_context.rb:155:in `load_recipe' 
/opt/chefdk/embedded/apps/chef/lib/chef/run_context.rb:142:in `block in include_recipe' 
/opt/chefdk/embedded/apps/chef/lib/chef/run_context.rb:141:in `each' 
/opt/chefdk/embedded/apps/chef/lib/chef/run_context.rb:141:in `include_recipe' 
/opt/chefdk/embedded/apps/chef/lib/chef/dsl/include_recipe.rb:26:in `include_recipe' 
blah-users.rb:1:in `run_chef_recipe' 
/opt/chefdk/embedded/apps/chef/lib/chef/application/apply.rb:168:in `instance_eval' 
/opt/chefdk/embedded/apps/chef/lib/chef/application/apply.rb:168:in `run_chef_recipe' 
/opt/chefdk/embedded/apps/chef/lib/chef/application/apply.rb:180:in `run_application' 
/opt/chefdk/embedded/apps/chef/lib/chef/application/apply.rb:193:in `run' 
/opt/chefdk/embedded/apps/chef/bin/chef-apply:25:in `<top (required)>' 
/usr/bin/chef-apply:51:in `load' 
/usr/bin/chef-apply:51:in `<main>' 
[2015-05-04T13:17:50-04:00] FATAL: NoMethodError: undefined method `unreachable_cookbook?' for nil:NilClass 
+1

願你嘗試用'廚師申請等等,users.rb的-l debug'。總之,我不確定廚師 - 申請可以用於依賴(即需要從另一個食譜的配方),因爲它只是用來運行一小部分內部資源,並且沒有烹飪書的加載(所以沒有讀取'metadata.rb'因爲沒有)。我能想到的最佳解決方法是使用chef-solo或chef-zero(請參閱http://docs.chef.io查看已發佈的信息),並在其metadata.rb文件中具有正確的依賴關係。 – Tensibai

+1

metadata.rb需要「依賴」「用戶」菜譜 – akaphenom

+0

您可能想要添加該答案(並接受它),以便稍後有人發現此問題時,他們可以輕鬆找到答案。 –

回答

1

後評論:

當使用include_recipe的地方,承載這個食譜的食譜必須被加載,有兩種方式得到它加載:

  1. 有它在運行列表
  2. 使用depends "cookbook", "version limitation"metadata.rb文件中的食譜包括使用chef-apply我們運行一個特殊的配方,而不是運行列表,因此1沒有其他(Documentation

這裏申請和2不能申請,沒有食譜加載,只有一個配方。旨在使用內部廚師資源而不是LWRP的Chef-apply

使用多重烹飪書的方法是創建一個烹飪書並在其metadata.rb文件中有一個依賴指令。

之後,你可以用chef-solochef-zero指定在命令行運行列表以'-r-o運行這個食譜,這將允許加載所有需要的食譜,使從可用取決於食譜的LWRP。關於廚師的客戶端模式(獨奏和零隻是快捷方式)

更多擴展文件可here

+0

的關注@akaphenom可以隨意發表評論,如果我遺漏了一些東西,我會根據需要進行編輯 – Tensibai

+1

當然需要將食譜放在食譜中,將食譜和相關食譜上傳到廚師服務器,然後通過metadata.rb參考配方,我懷疑我的耐心是我需要努力的。我無法站在「你好世界」教程的頁面。謝謝 – akaphenom

相關問題