update: enhance Vagrantfile with workstation configuration and adjust network settings for VMs
This commit is contained in:
parent
9ce3197c0b
commit
e9e05d1c60
3 changed files with 60 additions and 109 deletions
|
|
@ -46,19 +46,17 @@ running_vms=$(vagrant status | grep "running" | awk '{print $1}')
|
|||
|
||||
for vm in $running_vms; do
|
||||
|
||||
# Check network interfaces
|
||||
vm_info=$(vagrant ssh "$vm" -c "ip -j addr" | jq -r '
|
||||
.[] |
|
||||
"Interface: \(.ifname)\n" +
|
||||
(if .addr_info then
|
||||
(.addr_info | map(" IP (\(.family)): \(.local)") | join("\n"))
|
||||
else
|
||||
""
|
||||
end)
|
||||
')
|
||||
# Check network interfaces and get specific IPs
|
||||
vm_ips=$(vagrant ssh "$vm" -c "ip -j addr" | jq -r '.[] |
|
||||
select(.addr_info != null) |
|
||||
.addr_info[] |
|
||||
select(.family == "inet" and (.local | startswith("192.168.56.8"))) |
|
||||
.local')
|
||||
|
||||
# Save the VM's network info to the array
|
||||
network_info+=("$vm:\n$vm_info")
|
||||
# Save the VM's IP to the array if it matches our pattern
|
||||
if [ ! -z "$vm_ips" ]; then
|
||||
network_info+=("$vm:$vm_ips")
|
||||
fi
|
||||
|
||||
done
|
||||
|
||||
|
|
@ -74,7 +72,7 @@ echo "Network information gathered successfully."
|
|||
|
||||
|
||||
# get vagrant ports
|
||||
echo "Gathering Vagrant port information..."
|
||||
# echo "Gathering Vagrant port information..."
|
||||
|
||||
|
||||
# Ensure unique ports are added to the vagrant_ports array
|
||||
|
|
@ -89,29 +87,27 @@ add_unique_port() {
|
|||
}
|
||||
|
||||
while read -r line; do
|
||||
echo "Processing line: $line"
|
||||
|
||||
# Extract the port number
|
||||
port=$(echo "$line" | awk '{print $2}')
|
||||
echo "Extracted port: $port"
|
||||
vagrant_ports+=("$port")
|
||||
vagrant_ports+=("$line")
|
||||
done < <(vagrant ssh-config | grep Port)
|
||||
|
||||
while read -r line; do
|
||||
echo "Processing line: $line"
|
||||
|
||||
# Extract the port number
|
||||
port=$(echo "$line" | awk '{print $2}')
|
||||
echo "Extracted port: $port"
|
||||
add_unique_port "$port"
|
||||
done < <(vagrant ssh-config | grep Port)
|
||||
|
||||
|
||||
|
||||
ips=()
|
||||
# Print network information
|
||||
for info in "${network_info[@]}"; do
|
||||
echo "----------------------------------------"
|
||||
echo -e "$info"
|
||||
# vm2:192.168.56.81
|
||||
ip_addr=$(echo "$info" | cut -d':' -f2)
|
||||
ips+=("$ip_addr")
|
||||
echo "----------------------------------------"
|
||||
done
|
||||
|
||||
|
|
@ -122,54 +118,26 @@ for port in "${vagrant_ports[@]}"; do
|
|||
done
|
||||
|
||||
echo "Creating Ansible inventory file..."
|
||||
inventory_file="$SCRIPT_DIR/ansible_inventory.ini"
|
||||
echo "[all]" > "$inventory_file"
|
||||
ANSIBLE_DIR="$VAGRANT_DIR/ansible"
|
||||
mkdir -p "$ANSIBLE_DIR"
|
||||
INVENTORY_FILE="$ANSIBLE_DIR/ansible_inventory.ini"
|
||||
echo "[all]" > "$INVENTORY_FILE"
|
||||
i=0
|
||||
for vm in $running_vms; do
|
||||
port="${vagrant_ports[$i]}"
|
||||
echo "$vm ansible_host=127.0.0.1 ansible_port=$port ansible_user=vagrant ansible_ssh_private_key_file=.vagrant/machines/$vm/virtualbox/private_key ansible_python_interpreter=/usr/bin/python3" >> "$inventory_file"
|
||||
for info in "${network_info[@]}"; do
|
||||
port="22"
|
||||
vm=$(echo "$info" | cut -d':' -f1)
|
||||
host_ip=$(echo "$info" | cut -d':' -f2)
|
||||
echo "$vm ansible_host=$host_ip ansible_port=$port ansible_user=vagrant ansible_ssh_private_key_file=.vagrant/machines/$vm/virtualbox/private_key ansible_python_interpreter=/usr/bin/python3" >> "$INVENTORY_FILE"
|
||||
((i++))
|
||||
done
|
||||
|
||||
echo "" >> "$inventory_file"
|
||||
echo "[vms]" >> "$inventory_file"
|
||||
echo "" >> "$INVENTORY_FILE"
|
||||
echo "[vms]" >> "$INVENTORY_FILE"
|
||||
for vm in $running_vms; do
|
||||
echo $vm >> "$inventory_file"
|
||||
echo $vm >> "$INVENTORY_FILE"
|
||||
done
|
||||
|
||||
echo "Ansible inventory file created at: $inventory_file"
|
||||
echo "Ansible inventory file created at: $INVENTORY_FILE"
|
||||
|
||||
# source venv ansible
|
||||
ANSIBLE_VENV_DIR="$SCRIPT_DIR/../ansible/venv"
|
||||
if [ -d "$ANSIBLE_VENV_DIR" ]; then
|
||||
echo "Activating Ansible virtual environment..."
|
||||
source "$ANSIBLE_VENV_DIR/bin/activate"
|
||||
else
|
||||
echo "Ansible virtual environment not found at $ANSIBLE_VENV_DIR. Please create it before running this script."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
ANSIBLE_HOST_KEY_CHECKING=False ansible --inventory-file ../../../scripts/ansible_inventory.ini -m ping all | cat
|
||||
|
||||
# exit if error from ping
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Ansible ping failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook ../../../ansible/install_keepalived.yaml --inventory-file ../../../scripts/ansible_inventory.ini | cat
|
||||
# exit if error from playbook
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
echo "Keepalived installation completed successfully."
|
||||
|
||||
|
||||
ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook ../../../ansible/install_k3s_3node.yaml --inventory-file ../../../scripts/ansible_inventory.ini | cat
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
echo "K3s installation completed successfully."
|
||||
fi
|
||||
Loading…
Add table
Add a link
Reference in a new issue