-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathVagrantfile
executable file
·44 lines (43 loc) · 1.54 KB
/
Vagrantfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
Vagrant.require_version ">= 1.4.3"
VAGRANTFILE_API_VERSION = "2"
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
numNodes = 1
r = numNodes..1
(r.first).downto(r.last).each do |i|
config.vm.define "nifi-sandbox#{i}" do |node|
node.vm.box = "geerlingguy/centos7"
node.vm.provider "virtualbox" do |v|
v.name = "nifi-sandbox#{i}"
v.customize ["modifyvm", :id, "--memory", "4096"]
v.customize ["modifyvm", :id, "--cpus", 1]
end
node.vm.synced_folder '.', '/vagrant', type: :virtualbox
node.vm.network :private_network, ip: "10.10.10.1%02d" % i
node.vm.hostname = "nifi-sandbox#{i}.example.com"
node.vm.provision "shell", path: "scripts/setup-centos.sh"
node.vm.provision "shell" do |s|
s.path = "scripts/setup-centos-hosts.sh"
s.args = "-t #{numNodes}"
end
if i == 1
node.vm.provision "shell" do |s|
s.path = "scripts/setup-centos-ssh.sh"
s.args = "-s 1 -t #{numNodes}"
end
end
node.vm.provision "shell", path: "scripts/setup-basic-packages.sh"
node.vm.provision "shell", path: "scripts/setup-java.sh"
node.vm.provision "shell", path: "scripts/setup-hadoop.sh"
node.vm.provision "shell" do |s|
s.path = "scripts/setup-hadoop-slaves.sh"
s.args = "-s 1 -t #{numNodes}"
end
node.vm.provision "shell", path: "scripts/setup-kafka.sh"
if i == 1
node.vm.provision "shell", path: "scripts/setup-nifi.sh"
node.vm.provision "shell", path: "scripts/setup-nifi-registry.sh"
node.vm.provision "shell", path: "scripts/init-start-all-services.sh"
end
end
end
end