forked from rdbreak/rhcsa8env
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathVagrantfile
executable file
·97 lines (83 loc) · 4.06 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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
VAGRANTFILE_API_VERSION = "2"
VAGRANT_DISABLE_VBOXSYMLINKCREATE = "1"
file_to_disk1 = './disk-0-1.vdi'
file_to_disk2 = './disk-0-2.vdi'
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
# Use same SSH key for each machine
config.ssh.insert_key = false
config.vm.box_check_update = false
# Server 2 Configuration
config.vm.define "server2" do |server2|
server2.vm.box = "rdbreak/rhel8node"
# server2.vm.hostname = "server2.eight.example.com"
server2.vm.network "private_network", ip: "192.168.55.151"
server2.vm.network "private_network", ip: "192.168.55.175"
server2.vm.network "private_network", ip: "192.168.55.176"
server2.vm.synced_folder ".", "/vagrant", type: "rsync", rsync__exclude: ".git/"
server2.vm.provider "virtualbox" do |server2|
server2.customize ['storagectl', :id, '--name', 'SATA Controller', '--add', 'sata', '--portcount', 2]
unless File.exist?(file_to_disk1)
server2.customize ['createhd', '--filename', file_to_disk1, '--variant', 'Fixed', '--size', 16 * 1024]
end
unless File.exist?(file_to_disk2)
server2.customize ['createhd', '--filename', file_to_disk2, '--variant', 'Fixed', '--size', 16 * 1024]
end
server2.memory = "2048"
server2.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 1, '--device', 0, '--type', 'hdd', '--medium', file_to_disk1]
server2.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 2, '--device', 0, '--type', 'hdd', '--medium', file_to_disk2]
end
server2.vm.provision "shell", inline: <<-SHELL
yes| mkfs.ext4 -L extradisk1 /dev/sdb
SHELL
server2.vm.provision "shell", inline: <<-SHELL
mkdir /extradisk1 ; echo \'LABEL=extradisk1 /extradisk1 ext4 defaults 0 0\' >> /etc/fstab
SHELL
server2.vm.provision "shell", inline: <<-SHELL
yes| mkfs.ext4 -L extradisk2 /dev/sdc
SHELL
server2.vm.provision "shell", inline: <<-SHELL
mkdir /extradisk2 ; echo \'LABEL=extradisk2 /extradisk2 ext4 defaults 0 0\' >> /etc/fstab
SHELL
server2.vm.provision :ansible_local do |ansible|
ansible.playbook = "/vagrant/playbooks/server2.yml"
ansible.install = false
ansible.compatibility_mode = "2.0"
ansible.inventory_path = "/vagrant/inventory"
ansible.config_file = "/vagrant/ansible.cfg"
ansible.limit = "all"
end
server2.vm.provision :shell, :inline => "reboot", run: "always"
end
# Repo Configuration
config.vm.define "repo" do |repo|
repo.vm.box = "rdbreak/rhel8repo"
# repo.vm.hostname = "repo.example.com"
repo.vm.provision :shell, :inline => "sudo sed -i 's/PasswordAuthentication no/PasswordAuthentication yes/g' /etc/ssh/sshd_config; sudo systemctl restart sshd;", run: "always"
repo.vm.provision :shell, :inline => "yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm -y; sudo yum install -y sshpass python3-pip python3-devel httpd sshpass vsftpd createrepo", run: "always"
repo.vm.provision :shell, :inline => " python3 -m pip install -U pip ; python3 -m pip install pexpect; python3 -m pip install ansible", run: "always"
repo.vm.synced_folder ".", "/vagrant", type: "rsync", rsync__exclude: ".git/"
repo.vm.network "private_network", ip: "192.168.55.149"
repo.vm.provider "virtualbox" do |repo|
repo.memory = "1024"
end
end
# Server 1 Configuration
config.vm.define "server1" do |server1|
server1.vm.box = "rdbreak/rhel8node"
server1.vm.synced_folder ".", "/vagrant", type: "rsync", rsync__exclude: ".git/"
# server1.vm.hostname = "server1.eight.example.com"
server1.vm.network "private_network", ip: "192.168.55.150"
server1.vm.provider :virtualbox do |server1|
server1.customize ['modifyvm', :id,'--memory', '2048']
end
server1.vm.provision :ansible_local do |ansible|
ansible.playbook = "/vagrant/playbooks/master.yml"
ansible.install = false
ansible.compatibility_mode = "2.0"
ansible.inventory_path = "/vagrant/inventory"
ansible.config_file = "/vagrant/ansible.cfg"
ansible.limit = "all"
end
server1.vm.provision :shell, :inline => "reboot", run: "always"
end
end