"нет такого файла для загрузки - chef/provider/lwrp_base" при попытке запустить поваренную книгу mysql через Vagrant с помощью поставщика chef-solo
Хорошо, поэтому я использую кучу технологий, которые являются новыми для меня здесь, поэтому я не уверен, как решить проблему. У меня небольшой опыт работы с vagrant, и сейчас я пытаюсь выучить Chef.
Я клонировал эту кулинарную книгу: https://github.com/opscode-cookbooks/mysql в мой каталог./cookbooks/mysql. Я пытаюсь запустить эту кулинарную книгу через Vagrant с помощью этого Vagrantfile:
# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
VAGRANTFILE_API_VERSION = "2"
# Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
Vagrant::Config.run do |config|
config.vm.box = "precise64"
config.vm.box_url = "http://files.vagrantup.com/precise64.box"
config.vm.define "mysql" do |mysql|
mysql.vm.network :hostonly, "192.168.33.12"
mysql.vm.provision :chef_solo do |chef|
chef.cookbooks_path = "cookbooks"
chef.add_recipe "mysql"
chef.json = {
:server => {
version: '5.6',
port: '3307',
data_dar: '/data-mysql',
allow_remote_root: true,
remove_anonymous_Users: true,
remove_test_database: true
}
}
end
end
end
Когда я запускаю 'vagrant up mysql', я получаю такой вывод:
Running chef-solo...
stdin: is not a tty
[2014-05-07T17:20:23+00:00] INFO: *** Chef 10.14.2 ***
[2014-05-07T17:20:23+00:00] INFO: Run List is []
[2014-05-07T17:20:23+00:00] INFO: Run List expands to []
[2014-05-07T17:20:23+00:00] INFO: Starting Chef Run for precise64
[2014-05-07T17:20:23+00:00] INFO: Running start handlers
[2014-05-07T17:20:23+00:00] INFO: Start handlers complete.
================================================================================
Recipe Compile Error in /tmp/vagrant-chef-2/chef-solo-1/cookbooks/mysql/libraries/provider_mysql_service_omnios.rb
================================================================================
LoadError
---------
no such file to load -- chef/provider/lwrp_base
Cookbook Trace:
---------------
/tmp/vagrant-chef-2/chef-solo-1/cookbooks/mysql/libraries/provider_mysql_service_omnios.rb:1
Почему это не удается? Интересно, есть ли зависимость поваренной книги mysql от другой поваренной книги, которая должна содержать файл 'chef/provider/lwrp_base'.
ОБНОВЛЕНИЕ: Проблема может заключаться в том, что Vagrant работает под управлением Chef 10.14.2, а поваренная книга помечена как требующая Chef 11 здесь ( http://community.opscode.com/cookbooks/mysql).
Есть довольно много файлов, ссылающихся на LWRP, показанных здесь:
> gci .\cookbooks * -rec | select-string lwrp
cookbooks\mysql\CHANGELOG.md:320:- [COOK-684] remove mysql_database LWRP
cookbooks\mysql\libraries\provider_mysql_client.rb:5: class MysqlClient < Chef::Provider::LWRPBase
cookbooks\mysql\libraries\provider_mysql_client_debian.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_client_fedora.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_client_omnios.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_client_rhel.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_client_smartos.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_client_ubuntu.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_service.rb:5: class MysqlService < Chef::Provider::LWRPBase
cookbooks\mysql\libraries\provider_mysql_service_debian.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_service_fedora.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_service_omnios.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_service_rhel.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_service_smartos.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\provider_mysql_service_ubuntu.rb:1:require 'chef/provider/lwrp_base'
cookbooks\mysql\libraries\resource_mysql_client.rb:1:require 'chef/resource/lwrp_base'
cookbooks\mysql\libraries\resource_mysql_client.rb:5: class MysqlClient < Chef::Resource::LWRPBase
cookbooks\mysql\libraries\resource_mysql_service.rb:1:require 'chef/resource/lwrp_base'
3 ответа
Вы можете преодолеть это с помощью плагина vagrant omnibus
Просто запустите 'vagrant plugin install vagrant-omnibus', чтобы добавить его, и добавьте 'config.omnibus.chef_version =:latest' в начало вашего vagrantfile, вот так
Vagrant.configure("2") do |config|
config.omnibus.chef_version = :latest
...
end
В каталоге над вашими кулинарными книгами это может показать, что ссылается на lwrp:
найти кулинарные книги -exec grep lwrp {} \; -Распечатать
Хорошо, проблема была в том, что на моем бродячем ящике была установлена более старая версия Ruby и Chef. Теперь все работает, источник на https://github.com/fschwiet/helloVagrant/tree/ceafdc9916e788136ae79f20722e77d76e2f1eef