Шеф-повар: Как потребовать API ruby/mysql в ruby_block?

Я новичок в рубине и шеф-поваре. Я создал сервер шеф-повара и успешно загрузил узел. Я хочу получить доступ к 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)

Я не мог понять, когда проблема. Может ли кто-нибудь помочь в этом?


person talihsu    schedule 08.04.2015    source источник


Ответы (2)


Chef работает в своем собственном экземпляре ruby ​​(при условии, что вы установили его с помощью omnibus). Вам потребуется установить гем mysql в рубин Chef, используя ресурс chef_gem. Затем вы сможете загрузить mysql ruby

person Charlie    schedule 08.04.2015

Добавьте chef_gem "mysql2" вверху блока перед оператором require.

person Pubudu Perera    schedule 08.04.2015