Проект отказоустойчивого веб-приложения с возможностью автоматического разворота, резервного копирования, мониторинга и централизованного журналирования. Использованы Ansible, borgbackup, nginx, apache2, prometheus, alertmanager, mysql, php, wordpress и т.д.
Схема инфраструктуры приведена на рисунке: Для разворота:
-
Склонируйте репозиторий;
-
Скачайте файл с rpm отсюда;
-
Разверните архив с rpm в ansible/files
-
Установите коллекции ansible:
- ansible-galaxy collection install ansible.posix
- ansible-galaxy collection install community.mysql
- ansible-galaxy collection install community.crypto
- ansible-galaxy collection install community.general
-
Разрешите в vagrant использовать сети:
- 192.168.11.0/24
- 172.16.1.0/24
- 10.0.10.0/24
-
Измените значения переменных в group_vars/all:
- wpdb_site_host (требуется указать ip хост-машины с vagrant, порт обязателен)
- ssl_common_name (требуется указать ip хост-машины с vagrant)
-
Создайте файл files/telebot.token, указав в нём токен от https://t.me/MiddlemanBot
-
Запустите vagrant up
-
Запустите разворот командой
ansible-playbook playbook.yml --extra-vars='{"bootstrap_cluster":true, "restore_wpbackup":true}'
В случае, если всё сделано верно, то станут доступны следующие машины
- monitoring (172.16.1.2) - сервер мониторинга (prometheus, elk, alertmanager)
- fw (10.0.10.10) - сервер файрволла (firewalld)
- backup (172.16.1.3) - сервер РК (borgbackup)
- balancer1 (10.0.10.2) - сервер балансировки и reverse proxy (nginx)
- balancer2 (10.0.10.3) - сервер балансировки и reverse proxy (nginx)
- dbnode1 (192.168.11.2) - сервер БД (находится в кластере galera)
- dbnode2 (192.168.11.3) - сервер БД (находится в кластере galera)
- dbnode3 (192.168.11.4) - сервер БД (находится в кластере galera)
- apnode1 (192.168.11.5) - веб-сервер бэкенда (apache)
- apnode2 (192.168.11.6) - веб-сервер бэкенда (apache)
- prxnode1 (192.168.11.7) - HAProxy для балансировки нагрузки между нодами кластера galera
- prxnode2 (192.168.11.8) - HAProxy для балансировки нагрузки между нодами кластера galera