Я новичок в рубине и шеф-поваре. Я создал сервер шеф-повара и успешно загрузил узел. Я хочу получить доступ к Mysql на узле через свою кулинарную книгу без Mysql и кулинарной книги базы данных. Я использовал ruby/mysql API. Это работало хорошо, когда было запрограммировано в одном файле ruby. Код выглядит следующим образом.
require "rubygems"
require "mysql"
begin
con = Mysql.new("localhost", "root", "123")
res = con.query("create database abc")
rescue Mysql::Error => e
puts e.errno
puts e.error
ensure
con.close if con
end
Но когда я добавил этот код в ruby_block в моей поваренной книге и использовал его для шеф-повара, я получил ошибку на узле.
================================================================================
Error executing action `run` on resource 'ruby_block[test1]'
================================================================================
LoadError
---------
cannot load such file -- mysql
Cookbook Trace:
---------------
/var/chef/cache/cookbooks/db_test/recipes/default.rb:14:in `block (2 levels) in from_file'
Resource Declaration:
---------------------
# In /var/chef/cache/cookbooks/db_test/recipes/default.rb
11: ruby_block "test1" do
12: block do
13: require "rubygems"
14: require "mysql"
15:
16: begin
17: con = Mysql.new("localhost", "root", "123")
18: res = con.query("create database abc")
19: rescue Mysql::Error => e
20: puts e.errno
21: puts e.error
22: ensure
23: con.close if con
24: end
25: end
26: # action :run
Compiled Resource:
------------------
# Declared in /var/chef/cache/cookbooks/db_test/recipes/default.rb:11:in `from_file'
ruby_block("test1") do
action "run"
retries 0
retry_delay 2
default_guard_interpreter :default
block_name "test1"
declared_type :ruby_block
cookbook_name "db_test"
recipe_name "default"
block #<Proc:0x000000051907a8@/var/chef/cache/cookbooks/db_test/recipes/default.rb:12>
end
Running handlers:
[2015-04-07T22:14:12-04:00] ERROR: Running exception handlers
Running handlers complete
[2015-04-07T22:14:12-04:00] ERROR: Exception handlers complete
[2015-04-07T22:14:12-04:00] FATAL: Stacktrace dumped to /var/chef/cache/chef-stacktrace.out
Chef Client failed. 0 resources updated in 0.962999999 seconds
[2015-04-07T22:14:12-04:00] ERROR: ruby_block[test1] (db_test::default line 11) had an error: LoadError: cannot load such file -- mysql
[2015-04-07T22:14:12-04:00] FATAL: Chef::Exceptions::ChildConvergeError: Chef run process exited unsuccessfully (exit code 1)
Я не мог понять, когда проблема. Может ли кто-нибудь помочь в этом?