This README provides instructions for deploying using Ansible playbooks. Please follow the steps below for a successful deployment.
- Ansible installed on your local machine.
- Access to the required secrets stored in
pass
for deployment. - Knowledge of how to obtain Telegram
chat_id
andtoken
.
-
Access the Metal Folder
- Navigate to the
metal
folder in your terminal.
- Navigate to the
-
Install
pass
on Ubuntu- If
pass
is not already installed on your Ubuntu system, follow these instructions:- Open your terminal.
- Run the following command to install
pass
:sudo apt update sudo apt-get install pass sudo apt install -y python3 python3-pip sudo apt install -y ansible
- If
-
Set Secrets in
pass
- Use the
pass
command-line tool to set the following secrets:k8s.dabol/telegram/chat_id
k8s.dabol/telegram/token
k8s.dabol/prepare_password
k8s.dabol/smtp
For example:
pass insert k8s.dabol/telegram/chat_id
- Use the
-
Run Prepare Playbook
- Execute the following command to prepare the deployment:
make prepare
- Execute the following command to prepare the deployment:
-
Run Cluster Playbook
- Once the preparation is complete, run the following command to deploy the cluster:
make cluster
- Once the preparation is complete, run the following command to deploy the cluster:
Before deploying, ensure the following configurations are correctly set up:
-
Check Email Address Configuration:
- Verify the email address configuration in the following files:
/metal/roles/setup/templates/sasl_passwd.j2
bootstrap/argocd/values.yaml
/metal/roles/setup/tasks/main.yml
/metal/roles/setup/templates/telegram-notification.j2
- Verify the email address configuration in the following files:
-
Check Certificates:
- Ensure the certificates are correctly configured in:
/metal/inventory/group_vars/all/prepare.yml
- Ensure the certificates are correctly configured in:
-
Check Inventory:
- Verify the inventory in:
/metal/inventory/hosts.ini
- Verify the inventory in:
-
Check Hosts Matching:
- Make sure the hosts are matching in the following playbooks:
/metal/playbooks/install/backup-etcd.yml
/metal/playbooks/install/cluster.yml
/metal/playbooks/install/prepare.yml
- Make sure the hosts are matching in the following playbooks:
Ansible is an open-source automation tool used for configuration management, application deployment, and task automation. It allows you to automate repetitive tasks, making it easier to manage and deploy infrastructure.
pass
is a simple command-line password manager for Unix systems. It stores each password in a GPG-encrypted file and allows you to organize them into folders. In this setup, pass
is used to securely store sensitive information such as API tokens and passwords required for deployment.
To obtain the Telegram chat_id
and token
, follow these steps:
- Create a Telegram Bot:
- Start a conversation with the BotFather on Telegram.
- Use the
/newbot
command to create a new bot and follow the instructions. - Once the bot is created, BotFather will provide you with a
token
.
- Get Chat ID:
- Add your bot to the desired Telegram group or channel.
- Send a message to the group/channel.
- Use the following API call to get the
chat_id
:curl https://api.telegram.org/bot<YOUR_TOKEN_HERE>/getUpdates
- Look for the
chat
object within the response JSON. Theid
field within thechat
object represents thechat_id
of the group/channel.
Make sure to keep the token
and chat_id
secure and not expose them publicly. These credentials are required for integrating Telegram notifications with your deployment setup.
Feel free to reach out if you have any questions or need further assistance.