0

我有以下内容Vagrantfile

VAGRANTFILE_API_VERSION = "2"

$script = <<SCRIPT
  apt-get install -y mongodb
  mongo dummydb -u admin -p admin --eval "db.addUser('dummyuser', 'dummypass')"
SCRIPT

Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
  config.vm.box = "precise64"
  config.vm.box_url = "http://files.vagrantup.com/precise64_vmware_fusion.box"

  # MongoDB ports
  config.vm.network "forwarded_port", guest: 27017, host: 27017

  # RabbitMQ ports
  config.vm.network "forwarded_port", guest: 5672, host: 5672
  config.vm.network "forwarded_port", guest: 55672, host: 55672

  config.vm.provision "docker" do |docker|
    docker.run "tutum/mongodb", daemonize: true, args: "-p 27017:27017 -e MONGODB_PASS=\"admin\""
    docker.run "tutum/rabbitmq", daemonize: true, args: "-p 5672:5672 -p 55672:55672 -e RABBITMQ_PASS=\"admin\""
  end

  # config.vm.provision "shell", inline: $script
end

当我使用

$ vagrant up --provider=vmware_fusion

这很完美:创建了虚拟机,安装了 Docker,并设置了 MongoDB 和 RabbitMQ,并相应地分配了密码。到目前为止,一切都很好。

当我现在取消注释执行 shell 配置程序的最后一行时(根据文档,它应该像这样工作),我得到一个非常奇怪的错误:Vagrant 安装 Docker,拉取tutum/mongodb图像,然后告诉我运行容器失败:

==> default: Starting Docker containers...
==> default: -- Container: tutum/mongodb
The following SSH command responded with a non-zero exit status.
Vagrant assumes that this means the command failed!

          rm -f /var/lib/vagrant/cids/1bef9ddec8969e37432fbe8c55f6d9452cd61e4a
          docker run -cidfile=/var/lib/vagrant/cids/1bef9ddec8969e37432fbe8c55f6d9452cd61e4a -d -name tutum/mongodb -p 27017:27017 -e MONGODB_PASS="admin" tutum/mongodb 

Stdout from the command:

Stderr from the command:

stdin: is not a tty
Warning: '-cidfile' is deprecated, it will be replaced by '--cidfile' soon. See usage.
Warning: '-name' is deprecated, it will be replaced by '--name' soon. See usage.
Unable to find image 'tutum/mongodb' locally
Pulling repository tutum/mongodb

2014/03/27 01:31:40 Error: Invalid container name (tutum/mongodb), only [a-zA-Z0-9_.-] are allowed

我想问题是-name tutum/mongodbVagrant 自动应用于docker run调用的参数。

我不明白为什么只有在我添加 shell 配置程序时才会发生这种情况(这显然与设置 Docker 或 Docker 容器无关)。

有人知道这是为什么吗?

我在 OS X 10.9.2 上使用 Vagrant 1.5.1、Vagrant VMWare Fusion provider 2.3.4 和 VMWare 6.0.2。

有谁知道可能导致此问题的原因以及如何解决?

PS:我目前的解决方法是在 中应用auto_assign_name: falseVagrantfile但这只是一种解决方法。我很好奇实际问题是什么以及如何正确解决它。

4

1 回答 1

3

Docker 抱怨是因为单-而不是双-。检查文档以了解指定它们的新方法。

要成功运行命令,请使用

docker run --cidfile=/var/lib/vagrant/cids/1bef9ddec8969e37432fbe8c55f6d9452cd61e4a -d --name="tutum/mongodb" -p 27017:27017 -e MONGODB_PASS="admin" tutum/mongodb

但是在 vagrant 中解决这个问题需要更新核心供应商代码。

更新

这已在版本 1.5.2 中修复,查看此提交似乎他们正在使用--name--cidfile现在。

于 2014-04-10T11:10:44.760 回答