feat: env INSTALL_LONGHORN
Add Ansible playbooks for Longhorn, MetalLB, and Traefik installation conditional on presence of INSTALL_LONGHORN=true
This commit is contained in:
parent
80f4e5a53b
commit
8faa97a8bb
6 changed files with 129 additions and 44 deletions
|
|
@ -4,7 +4,8 @@
|
|||
sudo apt-get update
|
||||
sudo apt-get install -y software-properties-common git vim python3.10-venv jq figlet
|
||||
|
||||
source /vagrant/.envrc
|
||||
# shellcheck disable=SC1091
|
||||
source /vagrant/.envrc
|
||||
|
||||
# Set up ansible environment for vagrant user
|
||||
sudo -u vagrant mkdir -p /home/vagrant/.ansible
|
||||
|
|
@ -24,10 +25,10 @@ sudo chmod +x /home/vagrant/pipelines/*.sh
|
|||
|
||||
# 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 -u root cp /vagrant/.vagrant/machines/vm$i/virtualbox/private_key /root/.ssh/vm${i}_key
|
||||
sudo chmod 600 /home/vagrant/.ssh/vm${i}_key
|
||||
sudo chmod 600 /root/.ssh/vm${i}_key
|
||||
sudo -u vagrant cp "/vagrant/.vagrant/machines/vm$i/virtualbox/private_key" "/home/vagrant/.ssh/vm${i}_key"
|
||||
sudo -u root cp "/vagrant/.vagrant/machines/vm$i/virtualbox/private_key" "/root/.ssh/vm${i}_key"
|
||||
sudo chmod 600 "/home/vagrant/.ssh/vm${i}_key"
|
||||
sudo chmod 600 "/root/.ssh/vm${i}_key"
|
||||
done
|
||||
|
||||
# Disable host key checking for easier learning
|
||||
|
|
@ -46,18 +47,17 @@ cd "$ANSIBLE_DIR" || {
|
|||
if [ ! -d "venv" ]; then
|
||||
echo "Creating Python virtual environment in ./venv..."
|
||||
python3 -m venv venv
|
||||
source "venv/bin/activate"
|
||||
if [ $? -ne 0 ]; then
|
||||
# shellcheck disable=SC1091
|
||||
if ! source "venv/bin/activate"; then
|
||||
echo "Failed to activate virtual environment. Please check your Python installation."
|
||||
exit 1
|
||||
fi
|
||||
echo "Virtual environment created and activated."
|
||||
cp /vagrant/ansible/requirements.txt .
|
||||
cp "/vagrant/ansible/requirements.txt" .
|
||||
if [ -f "requirements.txt" ]; then
|
||||
echo "Installing dependencies from requirements.txt..."
|
||||
pip install --upgrade pip
|
||||
pip install -r requirements.txt
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! pip install -r requirements.txt; then
|
||||
echo "Failed to install dependencies from requirements.txt."
|
||||
exit 1
|
||||
fi
|
||||
|
|
@ -76,7 +76,13 @@ ls -al "$ANSIBLE_VENV_DIR/bin/activate"
|
|||
|
||||
if [ -d "$ANSIBLE_VENV_DIR" ]; then
|
||||
echo "Activating Ansible virtual environment..."
|
||||
source "$ANSIBLE_VENV_DIR/bin/activate"
|
||||
if [ -f "$ANSIBLE_VENV_DIR/bin/activate" ]; then
|
||||
# shellcheck source=/dev/null
|
||||
source "$ANSIBLE_VENV_DIR/bin/activate"
|
||||
else
|
||||
echo "Virtualenv activate script not found!" >&2
|
||||
exit 1
|
||||
fi
|
||||
else
|
||||
echo "Ansible virtual environment not found at $ANSIBLE_VENV_DIR. Please create it before running this script."
|
||||
exit 1
|
||||
|
|
@ -86,13 +92,13 @@ echo ""
|
|||
|
||||
ansible --version
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! ansible --version; then
|
||||
echo "Ansible is not installed or not found in the virtual environment. Please check your installation."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
|
||||
eval `ssh-agent -s`
|
||||
eval "$(ssh-agent -s)"
|
||||
ssh-add # ~/machines/*/virtualbox/private_key
|
||||
|
||||
BASHRC="/home/vagrant/.bashrc"
|
||||
|
|
@ -103,10 +109,11 @@ if ! grep -qF "$BLOCK_START" "$BASHRC"; then
|
|||
cat <<'EOF' >> "$BASHRC"
|
||||
|
||||
# ADDED BY infctl provisioning
|
||||
eval `ssh-agent -s`
|
||||
eval "$(ssh-agent -s)"
|
||||
ssh-add ~/machines/*/virtualbox/private_key
|
||||
ssh-add -L
|
||||
source /vagrant/.envrc
|
||||
# shellcheck disable=SC1091
|
||||
source /vagrant/.envrc
|
||||
EOF
|
||||
else
|
||||
echo "Provisioning block already present in $BASHRC"
|
||||
|
|
@ -114,7 +121,7 @@ fi
|
|||
|
||||
echo
|
||||
echo -------------------------
|
||||
echo
|
||||
echo
|
||||
|
||||
su - vagrant
|
||||
id
|
||||
|
|
@ -125,48 +132,63 @@ echo
|
|||
|
||||
ssh-add ~/.ssh/vm*_key
|
||||
|
||||
ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible --inventory-file /home/vagrant/ansible/ansible_inventory.ini -m ping vm1,vm2,vm3
|
||||
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible --inventory-file /home/vagrant/ansible/ansible_inventory.ini -m ping vm1,vm2,vm3; then
|
||||
echo "Ansible ping failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# install_keepalived.yaml
|
||||
ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_keepalived.yaml --inventory-file ansible_inventory.ini
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_keepalived.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
echo "Keepalived installation completed."
|
||||
|
||||
# install_k3s_3node.yaml
|
||||
ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_k3s_3node.yaml --inventory-file ansible_inventory.ini
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_k3s_3node.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# copy_k8s_config.yaml
|
||||
ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook copy_k8s_config.yaml --inventory-file ansible_inventory.ini
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook copy_k8s_config.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_dnsmasq.yaml --inventory-file ansible_inventory.ini
|
||||
if [ $? -ne 0 ]; then
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_dnsmasq.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Wait for Kubernetes API to be ready
|
||||
echo "Waiting for 30 seconds for Kubernetes API to be ready..."
|
||||
sleep 30
|
||||
echo "done waiting for kubernetes API"
|
||||
|
||||
# check infctl
|
||||
cd /home/vagrant
|
||||
bash /home/vagrant/scripts/check_install_infctl.sh
|
||||
if [ $? -ne 0 ]; then
|
||||
cd /home/vagrant || exit
|
||||
if ! bash /home/vagrant/scripts/check_install_infctl.sh; then
|
||||
echo "infctl check failed. Please check your installation."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Optionally install Longhorn, MetalLB, and Traefik
|
||||
if [ "${INSTALL_LONGHORN}" = "true" ]; then
|
||||
cd /home/vagrant/ansible || { echo "Failed to change directory to /home/vagrant/ansible"; exit 1; }
|
||||
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_longhorn.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_metallb.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! ANSIBLE_SUPPRESS_INTERPRETER_DISCOVERY_WARNING=1 ANSIBLE_HOST_KEY_CHECKING=False ansible-playbook install_traefik.yaml --inventory-file ansible_inventory.ini; then
|
||||
echo "Ansible playbook failed. Please check your Vagrant VMs and network configuration."
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue