update: enhance Vagrantfile with workstation configuration and adjust network settings for VMs

This commit is contained in:
jon brookes 2025-08-07 10:22:11 +01:00
parent 9ce3197c0b
commit e9e05d1c60
3 changed files with 60 additions and 109 deletions

View file

@ -8,60 +8,17 @@
Vagrant.configure("2") do |config|
config.vbguest.auto_update = false
# Ansible Controller/Workstation Configuration
config.vm.define "workstation" do |ws|
ws.vm.box = "ubuntu/jammy64"
ws.vm.hostname = "ansible-workstation"
ws.vm.synced_folder ".", "/vagrant"
# Fixed private network IP
ws.vm.network "private_network", ip: "192.168.56.10"
ws.vm.provider "virtualbox" do |vb|
vb.memory = "1024" # Less memory needed for control node
vb.cpus = 1
end
ws.vm.provision "shell", inline: <<-SHELL
sudo apt-get update
sudo apt-get install -y software-properties-common
sudo apt-add-repository --yes --update ppa:ansible/ansible
sudo apt-get install -y ansible git vim
# Set up ansible environment for vagrant user
sudo -u vagrant mkdir -p /home/vagrant/.ansible
sudo -u vagrant touch /home/vagrant/.ansible/ansible.cfg
# Create workspace and SSH directories
sudo -u vagrant mkdir -p /home/vagrant/ansible
sudo -u vagrant mkdir -p /home/vagrant/.ssh
sudo chmod 700 /home/vagrant/.ssh
# Copy the Vagrant private keys (these will be synced by Vagrant)
for i in {1..3}; do
sudo -u vagrant cp /vagrant/.vagrant/machines/vm$i/virtualbox/private_key /home/vagrant/.ssh/vm${i}_key
sudo chmod 600 /home/vagrant/.ssh/vm${i}_key
done
# Disable host key checking for easier learning
echo "[defaults]" > /home/vagrant/.ansible/ansible.cfg
echo "host_key_checking = False" >> /home/vagrant/.ansible/ansible.cfg
SHELL
end
# VM 1 Configuration
config.vm.define "vm1" do |vm1|
vm1.vm.box = "ubuntu/jammy64"
vm1.vm.hostname = "vm1"
# Fixed private network IP
vm1.vm.network "private_network", ip: "192.168.56.80"
# Public network for external access
vm1.vm.network "public_network", bridge: "wlp0s20f3"
vm1.vm.network "public_network", bridge: "Intel(R) Wi-Fi 6E AX211 160MHz"
vm1.vm.provider "virtualbox" do |vb|
vb.memory = "2048" # 2GB memory
@ -78,12 +35,13 @@ Vagrant.configure("2") do |config|
# VM 2 Configuration
config.vm.define "vm2" do |vm2|
vm2.vm.box = "ubuntu/jammy64"
vm2.vm.hostname = "vm2"
# Fixed private network IP
vm2.vm.network "private_network", ip: "192.168.56.81"
# Public network for external access
vm2.vm.network "public_network", bridge: "wlp0s20f3"
vm2.vm.network "public_network", bridge: "Intel(R) Wi-Fi 6E AX211 160MHz"
vm2.vm.provider "virtualbox" do |vb|
vb.memory = "2048" # 2GB memory
@ -100,12 +58,13 @@ Vagrant.configure("2") do |config|
# VM 3 Configuration
config.vm.define "vm3" do |vm3|
vm3.vm.box = "ubuntu/jammy64"
vm3.vm.hostname = "vm3"
# Fixed private network IP
vm3.vm.network "private_network", ip: "192.168.56.82"
# Public network for external access
vm3.vm.network "public_network", bridge: "wlp0s20f3"
vm3.vm.network "public_network", bridge: "Intel(R) Wi-Fi 6E AX211 160MHz"
vm3.vm.provider "virtualbox" do |vb|
vb.memory = "2048" # 2GB memory
@ -118,4 +77,24 @@ Vagrant.configure("2") do |config|
# python3 -m pip install --upgrade pip
SHELL
end
# Ansible Controller/Workstation Configuration
config.vm.define "workstation" do |ws|
ws.vm.box = "ubuntu/jammy64"
ws.vm.hostname = "ansible-workstation"
ws.vm.synced_folder ".", "/vagrant"
# Fixed private network IP
ws.vm.network "private_network", ip: "192.168.56.10"
ws.vm.provider "virtualbox" do |vb|
vb.memory = "1024" # Less memory needed for control node
vb.cpus = 1
end
ws.vm.provision "shell", path: "ansible/provision_workstation.sh"
end
end