vagrant/website/docs/source/v2/vagrantfile/tips.html.md

50 lines
1.5 KiB
Markdown
Raw Normal View History

---
page_title: "Tips & Tricks - Vagrantfile"
sidebar_current: "vagrantfile-tips"
---
# Tips & Tricks
The Vagrantfile is a very flexible configuration format. Since it is just
Ruby, there is a lot you can do with it. However, in that same vein, since
it is Ruby, there are a lot of ways you can shoot yourself in the foot. When
using some of the tips and tricks on this page, please take care to use them
correctly.
## Loop Over VM Definitions
If you want to apply a slightly different configuration to many
multi-machine machines, you can use a loop to do this. For example, if
you wanted to create three machines:
<pre class="prettyprint">
(1..3).each do |i|
config.vm.define "slave-#{i}" do |slave|
slave.vm.provision "shell",
inline: "echo hello from slave #{i}"
end
end
</pre>
<strong>Warning:</strong> The inner portion of multi-machine definitions
and provider overrides are lazy-loaded. This can cause issues if you change
the value of a variable used within the configs. For example, the loop below
<em>does not work</em>:
<pre class="prettyprint">
# THIS DOES NOT WORK!
for i in 1..3 do
config.vm.define "slave-#{i}" do |slave|
slave.vm.provision "shell",
inline: "echo hello from slave #{i}"
end
end
</pre>
The "for i in ..." construct in Ruby actually modifies the value of `i`
for each iteration, rather than making a copy. Therefore, when you run this,
every slave will actually provision with the same text.
This is an easy mistake to make, and Vagrant can't really protect against it,
so the best we can do is mention it here.