Compare commits
14 Commits
4709d4c0e7
...
9b72646537
Author | SHA1 | Date | |
---|---|---|---|
9b72646537 | |||
0c531fc919 | |||
06af6df556 | |||
3ca1df03ec | |||
37b5eca152 | |||
dd893a00cb | |||
b75c012ddd | |||
adb27b3be7 | |||
43f18ee37c | |||
bb79295969 | |||
5bc41c853f | |||
0474fb6047 | |||
24fbd9246f | |||
9a069a5c6b |
182
README.md
182
README.md
@ -2,28 +2,33 @@
|
|||||||
|
|
||||||
## Обзор
|
## Обзор
|
||||||
|
|
||||||
Этот репозиторий содержит проект Ansible, интегрированный с Jenkins, для автоматизации развёртывания двух веб-сайтов (`SiteA` и `SiteB`) и прокси-сервера (`Proxy`). Настройка обеспечивает балансировку нагрузки, автоматические проверки состояния (health checks) и динамическое обновление контента без ручного вмешательства.
|
Этот репозиторий содержит проект Ansible, интегрированный с Jenkins, для автоматизации развёртывания двух веб-сайтов (`SiteA` и `SiteB`) и прокси-сервера (`Proxy`). Настройка обеспечивает балансировку нагрузки, автоматические проверки состояния (health checks) и динамическое обновление контента без ручного вмешательства. Дополнительно внедрены обработчики для перезапуска служб при изменении конфигурации и централизованное управление основным конфигурационным файлом Nginx через `group_vars`.
|
||||||
|
|
||||||
## Описание Структуры
|
## Описание Компонентов
|
||||||
|
|
||||||
- **group_vars/**: Содержит файлы с переменными групп хостов. В данном случае `all.yml` содержит общие переменные для всех ролей и хостов.
|
- **group_vars/**: Содержит файлы с переменными групп хостов. В `all.yml` определены общие переменные для всех ролей и хостов, включая параметры для Nginx и контент для сайтов.
|
||||||
|
|
||||||
- **roles/**: Основная директория с ролями Ansible.
|
- **roles/**: Основная директория с ролями Ansible.
|
||||||
- **firewall/**: Роль для настройки и конфигурирования файрвола (`firewalld`), открытия необходимых портов.
|
|
||||||
- **tasks/**: Задачи для установки и настройки `firewalld`.
|
- **firewall/**:
|
||||||
|
- **handlers/**: Содержит обработчики для перезапуска `firewalld`.
|
||||||
|
- **tasks/**: Задачи для установки и настройки `firewalld`, открытия необходимых портов.
|
||||||
- **vars/**: Переменные, используемые в роли `firewall`.
|
- **vars/**: Переменные, используемые в роли `firewall`.
|
||||||
|
|
||||||
- **nginx_proxy/**: Роль для установки и настройки Nginx как прокси-сервера с балансировкой нагрузки и проверкой состояния.
|
- **nginx_proxy/**:
|
||||||
- **tasks/**: Задачи для установки Nginx и деплоя конфигурации прокси.
|
- **handlers/**: Содержит обработчики для перезапуска Nginx.
|
||||||
- **templates/**: Шаблоны конфигурационных файлов Nginx для прокси-сервера.
|
- **tasks/**: Задачи для установки Nginx, создания директорий, деплоя конфигураций и тестирования конфигурации.
|
||||||
|
- **templates/**: Шаблоны конфигурационных файлов Nginx для прокси-сервера и страниц ошибок.
|
||||||
|
|
||||||
- **nginx_site/**: Роль для установки и настройки Nginx на целевых сайтах (`SiteA` и `SiteB`), а также деплоя HTML контента.
|
- **nginx_site/**:
|
||||||
- **tasks/**: Задачи для установки Nginx, создания корневых директорий сайтов, деплоя конфигураций и HTML файлов.
|
- **handlers/**: Содержит обработчики для перезапуска Nginx.
|
||||||
|
- **tasks/**: Задачи для установки Nginx, создания корневых директорий сайтов, деплоя конфигураций и HTML файлов, а также тестирования конфигурации.
|
||||||
- **templates/**: Шаблоны конфигурационных файлов Nginx и HTML страниц для сайтов.
|
- **templates/**: Шаблоны конфигурационных файлов Nginx и HTML страниц для сайтов.
|
||||||
|
|
||||||
- **ssl_certificate/**: Роль для генерации самоподписанных SSL сертификатов для прокси-сервера.
|
- **ssl_certificate/**:
|
||||||
|
- **handlers/**: Содержит обработчики для перезапуска Nginx после генерации SSL сертификатов.
|
||||||
- **tasks/**: Задачи для установки OpenSSL, создания директории для сертификатов и генерации самоподписанных сертификатов.
|
- **tasks/**: Задачи для установки OpenSSL, создания директории для сертификатов и генерации самоподписанных сертификатов.
|
||||||
- **vars/**: Переменные, используемые в роли `ssl_certificate`.
|
- **templates/**: Шаблоны или скрипты для генерации SSL сертификатов.
|
||||||
|
|
||||||
- **playbook.yml**: Основной Ansible playbook, который связывает все роли и определяет порядок их выполнения на соответствующих хостах.
|
- **playbook.yml**: Основной Ansible playbook, который связывает все роли и определяет порядок их выполнения на соответствующих хостах.
|
||||||
|
|
||||||
@ -31,33 +36,52 @@
|
|||||||
|
|
||||||
- **ansible.cfg**: Конфигурационный файл Ansible, определяющий пути к ролям и другие настройки.
|
- **ansible.cfg**: Конфигурационный файл Ansible, определяющий пути к ролям и другие настройки.
|
||||||
|
|
||||||
- **Jenkinsfile**: Скрипт для Jenkins Pipeline, который управляет процессом деплоя, включая расшифровку SSH ключей, передачу переменных и запуск Ansible playbook.
|
- **jenkinsfile**: Скрипт для Jenkins Pipeline, который управляет процессом деплоя, включая расшифровку SSH ключей, передачу переменных и запуск Ansible playbook.
|
||||||
|
|
||||||
## Параметры и Их Назначение
|
## Параметры и Их Назначение
|
||||||
|
|
||||||
### В `group_vars/all.yml`
|
### В `group_vars/all.yml`
|
||||||
|
|
||||||
- **siteA**:
|
```yaml
|
||||||
- `site_title`: Заголовок страницы SiteA.
|
# group_vars/all.yml
|
||||||
- `site_h1`: Основной заголовок `<h1>` на странице SiteA.
|
ansible_python_interpreter: /usr/bin/python3.6
|
||||||
- `site_h2`: Дополнительный заголовок `<h2>` для SiteA.
|
|
||||||
- `site_p`: Параграф `<p>` контента для SiteA.
|
|
||||||
- `site_domain`: Доменное имя SiteA.
|
|
||||||
- `site_ip`: IP-адрес сервера SiteA.
|
|
||||||
|
|
||||||
- **siteB**:
|
# Общие переменные для Nginx
|
||||||
- `site_title`: Заголовок страницы SiteB.
|
nginx_worker_processes: auto
|
||||||
- `site_h1`: Основной заголовок `<h1>` на странице SiteB.
|
nginx_error_log: /var/log/nginx/error.log
|
||||||
- `site_h2`: Дополнительный заголовок `<h2>` для SiteB.
|
nginx_error_log_level: warn
|
||||||
- `site_p`: Параграф `<p>` контента для SiteB.
|
nginx_worker_connections: 1024
|
||||||
- `site_domain`: Доменное имя SiteB.
|
nginx_access_log: /var/log/nginx/access.log
|
||||||
- `site_ip`: IP-адрес сервера SiteB.
|
nginx_keepalive_timeout: 65
|
||||||
|
nginx_types_hash_max_size: 2048
|
||||||
|
|
||||||
- **proxy**:
|
# Переменные для сайтов SiteA и SiteB
|
||||||
- `proxy_domain`: Доменное имя прокси-сервера.
|
siteA:
|
||||||
- `proxy_ip`: IP-адрес прокси-сервера.
|
site_title: "SiteA - Добро пожаловать"
|
||||||
|
site_h1: "Добро пожаловать на SiteA"
|
||||||
|
site_h2: "Дефолтный заголовок H2 для SiteA"
|
||||||
|
site_p: "Дефолтный параграф для SiteA"
|
||||||
|
site_domain: "siteA.example.com"
|
||||||
|
site_ip: "192.168.0.61"
|
||||||
|
|
||||||
- **ansible_python_interpreter**: Явное указание пути к Python-интерпретатору на всех хостах.
|
siteB:
|
||||||
|
site_title: "SiteB - Добро пожаловать"
|
||||||
|
site_h1: "Добро пожаловать на SiteB"
|
||||||
|
site_h2: "Дефолтный заголовок H2 для SiteB"
|
||||||
|
site_p: "Дефолтный параграф для SiteB"
|
||||||
|
site_domain: "siteB.example.com"
|
||||||
|
site_ip: "192.168.0.62"
|
||||||
|
|
||||||
|
proxy:
|
||||||
|
proxy_domain: "proxy.example.com"
|
||||||
|
proxy_ip: "192.168.0.63"
|
||||||
|
|
||||||
|
# SSL переменные
|
||||||
|
ssl_cert_path: "/etc/nginx/ssl"
|
||||||
|
ssl_cert_file: "proxy.crt"
|
||||||
|
ssl_key_file: "proxy.key"
|
||||||
|
ssl_subject: "/C=RU/ST=Some-State/L=Some-City/O=Your Company/CN={{ proxy.proxy_domain }}"
|
||||||
|
```
|
||||||
|
|
||||||
### В `Jenkinsfile`
|
### В `Jenkinsfile`
|
||||||
|
|
||||||
@ -101,4 +125,98 @@ all:
|
|||||||
hosts:
|
hosts:
|
||||||
192.168.0.63:
|
192.168.0.63:
|
||||||
ansible_user: ansible
|
ansible_user: ansible
|
||||||
ansible_python_interpreter: /usr/bin/python3.6
|
ansible_python_interpreter: /usr/bin/python3.6
|
||||||
|
```
|
||||||
|
|
||||||
|
### Настройка Переменных
|
||||||
|
|
||||||
|
Все переменные, используемые в проектах, определены в `group_vars/all.yml`. При необходимости, вы можете переопределить их через Jenkins параметры или добавить дополнительные переменные.
|
||||||
|
|
||||||
|
### Запуск Jenkins Pipeline
|
||||||
|
|
||||||
|
1. **Дешифровка SSH ключей**: Jenkins автоматически расшифровывает SSH ключи для доступа к серверам.
|
||||||
|
|
||||||
|
2. **Выбор Цели Развертывания**: Выберите, какой сайт (`SiteA`, `SiteB`) или все (`All`) нужно развернуть.
|
||||||
|
|
||||||
|
3. **Передача Дополнительных Переменных**: Введите дополнительные параметры контента для выбранных сайтов.
|
||||||
|
|
||||||
|
4. **Запуск Ansible Playbook**: Jenkins запускает Ansible playbook с переданными параметрами, развертывая конфигурации и контент на целевых хостах.
|
||||||
|
|
||||||
|
## Проверка и Отладка
|
||||||
|
|
||||||
|
Если при развертывании возникают ошибки:
|
||||||
|
|
||||||
|
1. **Просмотрите Логи Jenkins**: Получите подробную информацию об ошибках.
|
||||||
|
|
||||||
|
2. **Подключитесь к Целевым Серверам**: Проверьте статус служб и конфигурационных файлов.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
systemctl status nginx
|
||||||
|
systemctl status firewalld
|
||||||
|
```
|
||||||
|
|
||||||
|
3. **Проверьте Конфигурацию Nginx**: Убедитесь, что конфигурационные файлы корректны.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
nginx -t
|
||||||
|
```
|
||||||
|
|
||||||
|
4. **Просмотрите Логи Nginx**:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo journalctl -xeu nginx.service
|
||||||
|
sudo tail -n 100 /var/log/nginx/error.log
|
||||||
|
```
|
||||||
|
|
||||||
|
### Пример Запуска Playbook Локально
|
||||||
|
|
||||||
|
Для локального тестирования или отладки вы можете запустить playbook вручную:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ansible-playbook playbook.yml
|
||||||
|
```
|
||||||
|
|
||||||
|
## Дополнительные Возможности
|
||||||
|
|
||||||
|
- **Автоматическое Тестирование Конфигураций**: Playbook включает задачи для тестирования конфигурации Nginx перед запуском службы, предотвращая запуск с ошибками.
|
||||||
|
|
||||||
|
- **Обработчики (Handlers)**: Автоматический перезапуск служб `nginx` и `firewalld` при изменении конфигурационных файлов.
|
||||||
|
|
||||||
|
- **Централизованное Управление Конфигурацией**: Основной конфигурационный файл Nginx управляется через шаблоны и переменные в `group_vars/all.yml`.
|
||||||
|
|
||||||
|
## Рекомендации и Лучшие Практики
|
||||||
|
|
||||||
|
1. **Безопасность**:
|
||||||
|
- Используйте Ansible Vault для защиты чувствительных данных.
|
||||||
|
- Убедитесь, что SSH ключи и другие секреты не попадают в систему контроля версий.
|
||||||
|
|
||||||
|
2. **Документация**:
|
||||||
|
- Поддерживайте актуальную документацию, описывающую структуру проекта и инструкции по развертыванию.
|
||||||
|
|
||||||
|
3. **Тестирование**:
|
||||||
|
- Используйте инструменты вроде [Molecule](https://molecule.readthedocs.io/en/latest/) для тестирования Ansible ролей.
|
||||||
|
- Внедрите проверку конфигураций перед применением изменений.
|
||||||
|
|
||||||
|
4. **Управление Конфигурациями**:
|
||||||
|
- Централизуйте общие конфигурационные файлы для облегчения управления и уменьшения дублирования.
|
||||||
|
- Используйте обработчики для автоматического применения изменений.
|
||||||
|
|
||||||
|
5. **Мониторинг и Логирование**:
|
||||||
|
- Внедрите системы мониторинга для отслеживания состояния сервисов.
|
||||||
|
- Анализируйте логи для своевременного обнаружения и устранения проблем.
|
||||||
|
|
||||||
|
## Заключение
|
||||||
|
|
||||||
|
Этот проект демонстрирует эффективное использование Ansible и Jenkins для автоматизации развёртывания веб-сайтов и прокси-сервера с учётом безопасности, надёжности и удобства управления. Следуя приведённым инструкциям и рекомендациям, вы сможете быстро адаптировать и расширять данное решение под свои нужды.
|
||||||
|
|
||||||
|
Если у вас возникнут дополнительные вопросы или потребуется помощь с настройкой, не стесняйтесь обращаться!
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**Примечания:**
|
||||||
|
|
||||||
|
- Убедитесь, что все переменные правильно определены и соответствуют вашим требованиям.
|
||||||
|
- При необходимости, обновите пути и имена файлов в соответствии с вашей инфраструктурой.
|
||||||
|
- Для улучшения безопасности рассмотрите использование Ansible Vault для хранения чувствительных данных, таких как SSH ключи и пароли.
|
||||||
|
|
||||||
|
Если возникнут дополнительные вопросы или потребуется помощь с настройкой, не стесняйтесь обращаться!
|
57
ansible/Jenkinsfile
vendored
57
ansible/Jenkinsfile
vendored
@ -13,22 +13,27 @@ pipeline {
|
|||||||
parameters {
|
parameters {
|
||||||
choice(
|
choice(
|
||||||
name: 'DEPLOY_TARGET',
|
name: 'DEPLOY_TARGET',
|
||||||
choices: ['SiteA', 'SiteB', 'All'],
|
choices: ['SiteA', 'SiteB', 'proxy', 'SiteA&proxy', 'SiteB&proxy', 'All'],
|
||||||
description: 'Выберите сайты для развертывания'
|
description: 'Выберите цели для развертывания'
|
||||||
)
|
)
|
||||||
|
|
||||||
string(name: 'ADDITIONAL_CONTENT_SITEA_H2', defaultValue: 'Новое сообщение для SiteA', description: 'Дополнительный <h2> контент для SiteA')
|
string(
|
||||||
string(name: 'ADDITIONAL_CONTENT_SITEA_P', defaultValue: 'Дополнительный параграф для SiteA', description: 'Дополнительный <p> контент для SiteA')
|
name: 'ADDITIONAL_CONTENT_H2',
|
||||||
|
defaultValue: 'Новое сообщение',
|
||||||
string(name: 'ADDITIONAL_CONTENT_SITEB_H2', defaultValue: 'Новое сообщение для SiteB', description: 'Дополнительный <h2> контент для SiteB')
|
description: 'Дополнительный <h2> контент'
|
||||||
string(name: 'ADDITIONAL_CONTENT_SITEB_P', defaultValue: 'Дополнительный параграф для SiteB', description: 'Дополнительный <p> контент для SiteB')
|
)
|
||||||
|
string(
|
||||||
|
name: 'ADDITIONAL_CONTENT_P',
|
||||||
|
defaultValue: 'Дополнительный параграф',
|
||||||
|
description: 'Дополнительный <p> контент'
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
stage('Decrypt SSH Key') {
|
stage('Decrypt SSH Key') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
def tempDir = '/tmp/' + UUID.randomUUID().toString()
|
def tempDir = "/tmp/${UUID.randomUUID().toString()}"
|
||||||
env.TEMP_DIR = tempDir
|
env.TEMP_DIR = tempDir
|
||||||
sh "mkdir -p ${tempDir}"
|
sh "mkdir -p ${tempDir}"
|
||||||
|
|
||||||
@ -38,7 +43,7 @@ pipeline {
|
|||||||
writeFile file: vaultPassFile, text: VAULT_PASSWORD
|
writeFile file: vaultPassFile, text: VAULT_PASSWORD
|
||||||
|
|
||||||
sh """
|
sh """
|
||||||
ansible-vault decrypt ./ansible/id_ed25519_vault --output=${decryptedKeyFile} --vault-password-file=${vaultPassFile}
|
ansible-vault decrypt ./ansible/id_ed25519_vault --output=${decryptedKeyFile} --vault-password-file=${vaultPassFile}
|
||||||
"""
|
"""
|
||||||
|
|
||||||
env.DECYPTED_KEY_FILE = decryptedKeyFile
|
env.DECYPTED_KEY_FILE = decryptedKeyFile
|
||||||
@ -56,21 +61,34 @@ pipeline {
|
|||||||
|
|
||||||
switch(params.DEPLOY_TARGET) {
|
switch(params.DEPLOY_TARGET) {
|
||||||
case 'SiteA':
|
case 'SiteA':
|
||||||
selectedHosts = 'SiteA,proxy'
|
selectedHosts = 'SiteA'
|
||||||
extraVars.siteA_h2 = params.ADDITIONAL_CONTENT_SITEA_H2
|
extraVars.siteA_h2 = params.ADDITIONAL_CONTENT_H2
|
||||||
extraVars.siteA_p = params.ADDITIONAL_CONTENT_SITEA_P
|
extraVars.siteA_p = params.ADDITIONAL_CONTENT_P
|
||||||
break
|
break
|
||||||
case 'SiteB':
|
case 'SiteB':
|
||||||
|
selectedHosts = 'SiteB'
|
||||||
|
extraVars.siteB_h2 = params.ADDITIONAL_CONTENT_H2
|
||||||
|
extraVars.siteB_p = params.ADDITIONAL_CONTENT_P
|
||||||
|
break
|
||||||
|
case 'proxy':
|
||||||
|
selectedHosts = 'proxy'
|
||||||
|
break
|
||||||
|
case 'SiteA&proxy':
|
||||||
|
selectedHosts = 'SiteA,proxy'
|
||||||
|
extraVars.siteA_h2 = params.ADDITIONAL_CONTENT_H2
|
||||||
|
extraVars.siteA_p = params.ADDITIONAL_CONTENT_P
|
||||||
|
break
|
||||||
|
case 'SiteB&proxy':
|
||||||
selectedHosts = 'SiteB,proxy'
|
selectedHosts = 'SiteB,proxy'
|
||||||
extraVars.siteB_h2 = params.ADDITIONAL_CONTENT_SITEB_H2
|
extraVars.siteB_h2 = params.ADDITIONAL_CONTENT_H2
|
||||||
extraVars.siteB_p = params.ADDITIONAL_CONTENT_SITEB_P
|
extraVars.siteB_p = params.ADDITIONAL_CONTENT_P
|
||||||
break
|
break
|
||||||
case 'All':
|
case 'All':
|
||||||
selectedHosts = 'SiteA,SiteB,proxy'
|
selectedHosts = 'SiteA,SiteB,proxy'
|
||||||
extraVars.siteA_h2 = params.ADDITIONAL_CONTENT_SITEA_H2
|
extraVars.siteA_h2 = params.ADDITIONAL_CONTENT_H2
|
||||||
extraVars.siteA_p = params.ADDITIONAL_CONTENT_SITEA_P
|
extraVars.siteA_p = params.ADDITIONAL_CONTENT_P
|
||||||
extraVars.siteB_h2 = params.ADDITIONAL_CONTENT_SITEB_H2
|
extraVars.siteB_h2 = params.ADDITIONAL_CONTENT_H2
|
||||||
extraVars.siteB_p = params.ADDITIONAL_CONTENT_SITEB_P
|
extraVars.siteB_p = params.ADDITIONAL_CONTENT_P
|
||||||
break
|
break
|
||||||
default:
|
default:
|
||||||
error "Неизвестный DEPLOY_TARGET: ${params.DEPLOY_TARGET}"
|
error "Неизвестный DEPLOY_TARGET: ${params.DEPLOY_TARGET}"
|
||||||
@ -80,7 +98,8 @@ pipeline {
|
|||||||
playbook: 'ansible/playbook.yml',
|
playbook: 'ansible/playbook.yml',
|
||||||
inventory: "ansible/inventory.yml",
|
inventory: "ansible/inventory.yml",
|
||||||
extraVars: extraVars,
|
extraVars: extraVars,
|
||||||
limit: selectedHosts
|
limit: selectedHosts,
|
||||||
|
colorized: true
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,12 @@
|
|||||||
ansible_python_interpreter: /usr/bin/python3.6
|
ansible_python_interpreter: /usr/bin/python3.6
|
||||||
|
|
||||||
siteA_h2: "Дефолтный заголовок H2 для SiteA"
|
nginx_worker_processes: auto
|
||||||
siteA_p: "Дефолтный параграф для SiteA"
|
nginx_error_log: /var/log/nginx/error.log
|
||||||
siteB_h2: "Дефолтный заголовок H2 для SiteB"
|
nginx_error_log_level: warn
|
||||||
siteB_p: "Дефолтный параграф для SiteB"
|
nginx_worker_connections: 1024
|
||||||
|
nginx_access_log: /var/log/nginx/access.log
|
||||||
|
nginx_keepalive_timeout: 65
|
||||||
|
nginx_types_hash_max_size: 2048
|
||||||
|
|
||||||
siteA:
|
siteA:
|
||||||
site_title: "SiteA - Добро пожаловать"
|
site_title: "SiteA - Добро пожаловать"
|
||||||
@ -23,4 +26,9 @@ siteB:
|
|||||||
|
|
||||||
proxy:
|
proxy:
|
||||||
proxy_domain: "proxy.example.com"
|
proxy_domain: "proxy.example.com"
|
||||||
proxy_ip: "192.168.0.63"
|
proxy_ip: "192.168.0.63"
|
||||||
|
|
||||||
|
siteA_h2: "Новое сообщение для SiteA"
|
||||||
|
siteA_p: "Дополнительный параграф для SiteA"
|
||||||
|
siteB_h2: "Новое сообщение для SiteB"
|
||||||
|
siteB_p: "Дополнительный параграф для SiteB"
|
4
ansible/roles/firewall/handlers/main.yml
Normal file
4
ansible/roles/firewall/handlers/main.yml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
- name: Restart firewalld
|
||||||
|
systemd:
|
||||||
|
name: firewalld
|
||||||
|
state: restarted
|
@ -2,12 +2,16 @@
|
|||||||
zypper:
|
zypper:
|
||||||
name: firewalld
|
name: firewalld
|
||||||
state: present
|
state: present
|
||||||
|
notify:
|
||||||
|
- Restart firewalld
|
||||||
|
|
||||||
- name: Ensure firewalld is enabled and started
|
- name: Ensure firewalld is enabled and started
|
||||||
systemd:
|
systemd:
|
||||||
name: firewalld
|
name: firewalld
|
||||||
enabled: yes
|
enabled: yes
|
||||||
state: started
|
state: started
|
||||||
|
notify:
|
||||||
|
- Restart firewalld
|
||||||
|
|
||||||
- name: Open specified firewall ports
|
- name: Open specified firewall ports
|
||||||
firewalld:
|
firewalld:
|
||||||
@ -15,4 +19,6 @@
|
|||||||
permanent: yes
|
permanent: yes
|
||||||
state: enabled
|
state: enabled
|
||||||
immediate: yes
|
immediate: yes
|
||||||
loop: "{{ firewall_ports }}"
|
loop: "{{ firewall_ports }}"
|
||||||
|
notify:
|
||||||
|
- Restart firewalld
|
4
ansible/roles/nginx_proxy/handlers/main.yml
Normal file
4
ansible/roles/nginx_proxy/handlers/main.yml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
- name: Restart Nginx
|
||||||
|
systemd:
|
||||||
|
name: nginx
|
||||||
|
state: restarted
|
@ -2,12 +2,8 @@
|
|||||||
zypper:
|
zypper:
|
||||||
name: nginx
|
name: nginx
|
||||||
state: present
|
state: present
|
||||||
|
notify:
|
||||||
- name: Ensure Nginx is enabled and started
|
- Restart Nginx
|
||||||
systemd:
|
|
||||||
name: nginx
|
|
||||||
enabled: yes
|
|
||||||
state: started
|
|
||||||
|
|
||||||
- name: Create directory for error pages
|
- name: Create directory for error pages
|
||||||
file:
|
file:
|
||||||
@ -16,19 +12,36 @@
|
|||||||
owner: nginx
|
owner: nginx
|
||||||
group: nginx
|
group: nginx
|
||||||
mode: '0755'
|
mode: '0755'
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Deploy custom error page
|
- name: Deploy custom error page
|
||||||
template:
|
template:
|
||||||
src: site_down.html.j2
|
src: site_down.html.j2
|
||||||
dest: /var/www/errors/site_down.html
|
dest: /var/www/errors/site_down.html
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Deploy Proxy Configuration
|
- name: Deploy Proxy Configuration
|
||||||
template:
|
template:
|
||||||
src: proxy.conf.j2
|
src: proxy.conf.j2
|
||||||
dest: /etc/nginx/conf.d/proxy.conf
|
dest: /etc/nginx/conf.d/proxy.conf
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Reload Nginx
|
- name: Deploy Main Nginx Configuration
|
||||||
|
template:
|
||||||
|
src: nginx.conf.j2
|
||||||
|
dest: /etc/nginx/nginx.conf
|
||||||
|
mode: '0644'
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
|
- name: Ensure Nginx is enabled and started
|
||||||
systemd:
|
systemd:
|
||||||
name: nginx
|
name: nginx
|
||||||
state: reloaded
|
enabled: yes
|
||||||
|
state: started
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
27
ansible/roles/nginx_proxy/templates/nginx.conf.j2
Normal file
27
ansible/roles/nginx_proxy/templates/nginx.conf.j2
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
user nginx;
|
||||||
|
worker_processes auto;
|
||||||
|
error_log /var/log/nginx/error.log warn;
|
||||||
|
pid /var/run/nginx.pid;
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 1024;
|
||||||
|
}
|
||||||
|
|
||||||
|
http {
|
||||||
|
include mime.types;
|
||||||
|
default_type application/octet-stream;
|
||||||
|
|
||||||
|
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
|
||||||
|
'$status $body_bytes_sent "$http_referer" '
|
||||||
|
'"$http_user_agent" "$http_x_forwarded_for"';
|
||||||
|
|
||||||
|
access_log /var/log/nginx/access.log main;
|
||||||
|
|
||||||
|
sendfile on;
|
||||||
|
tcp_nopush on;
|
||||||
|
tcp_nodelay on;
|
||||||
|
keepalive_timeout 65;
|
||||||
|
types_hash_max_size 2048;
|
||||||
|
|
||||||
|
include /etc/nginx/conf.d/*.conf;
|
||||||
|
}
|
@ -9,6 +9,11 @@ upstream backend {
|
|||||||
|
|
||||||
server {
|
server {
|
||||||
listen 80;
|
listen 80;
|
||||||
|
server_name {{ proxy.proxy_domain }};
|
||||||
|
return 301 https://$host$request_uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
listen 443 ssl;
|
listen 443 ssl;
|
||||||
server_name {{ proxy.proxy_domain }};
|
server_name {{ proxy.proxy_domain }};
|
||||||
|
|
||||||
|
4
ansible/roles/nginx_site/handlers/main.yml
Normal file
4
ansible/roles/nginx_site/handlers/main.yml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
- name: Restart Nginx
|
||||||
|
systemd:
|
||||||
|
name: nginx
|
||||||
|
state: restarted
|
@ -2,12 +2,32 @@
|
|||||||
zypper:
|
zypper:
|
||||||
name: nginx
|
name: nginx
|
||||||
state: present
|
state: present
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Ensure Nginx is enabled and started
|
- name: Deploy Main Nginx Configuration
|
||||||
systemd:
|
template:
|
||||||
name: nginx
|
src: nginx.conf.j2
|
||||||
enabled: yes
|
dest: /etc/nginx/nginx.conf
|
||||||
state: started
|
mode: '0644'
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
|
- name: Deploy SiteA Configuration
|
||||||
|
template:
|
||||||
|
src: siteA.conf.j2
|
||||||
|
dest: /etc/nginx/conf.d/siteA.conf
|
||||||
|
when: "'SiteA' in group_names"
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
|
- name: Deploy SiteB Configuration
|
||||||
|
template:
|
||||||
|
src: siteB.conf.j2
|
||||||
|
dest: /etc/nginx/conf.d/siteB.conf
|
||||||
|
when: "'SiteB' in group_names"
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Create web root for SiteA
|
- name: Create web root for SiteA
|
||||||
file:
|
file:
|
||||||
@ -17,6 +37,8 @@
|
|||||||
group: nginx
|
group: nginx
|
||||||
mode: '0755'
|
mode: '0755'
|
||||||
when: "'SiteA' in group_names"
|
when: "'SiteA' in group_names"
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Create web root for SiteB
|
- name: Create web root for SiteB
|
||||||
file:
|
file:
|
||||||
@ -26,18 +48,8 @@
|
|||||||
group: nginx
|
group: nginx
|
||||||
mode: '0755'
|
mode: '0755'
|
||||||
when: "'SiteB' in group_names"
|
when: "'SiteB' in group_names"
|
||||||
|
notify:
|
||||||
- name: Deploy SiteA Configuration
|
- Restart Nginx
|
||||||
template:
|
|
||||||
src: siteA.conf.j2
|
|
||||||
dest: /etc/nginx/conf.d/siteA.conf
|
|
||||||
when: "'SiteA' in group_names"
|
|
||||||
|
|
||||||
- name: Deploy SiteB Configuration
|
|
||||||
template:
|
|
||||||
src: siteB.conf.j2
|
|
||||||
dest: /etc/nginx/conf.d/siteB.conf
|
|
||||||
when: "'SiteB' in group_names"
|
|
||||||
|
|
||||||
- name: Deploy SiteA HTML
|
- name: Deploy SiteA HTML
|
||||||
template:
|
template:
|
||||||
@ -49,6 +61,8 @@
|
|||||||
site_h2: "{{ siteA.site_h2 }}"
|
site_h2: "{{ siteA.site_h2 }}"
|
||||||
site_p: "{{ siteA.site_p }}"
|
site_p: "{{ siteA.site_p }}"
|
||||||
when: "'SiteA' in group_names"
|
when: "'SiteA' in group_names"
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Deploy SiteB HTML
|
- name: Deploy SiteB HTML
|
||||||
template:
|
template:
|
||||||
@ -60,8 +74,13 @@
|
|||||||
site_h2: "{{ siteB.site_h2 }}"
|
site_h2: "{{ siteB.site_h2 }}"
|
||||||
site_p: "{{ siteB.site_p }}"
|
site_p: "{{ siteB.site_p }}"
|
||||||
when: "'SiteB' in group_names"
|
when: "'SiteB' in group_names"
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
||||||
|
|
||||||
- name: Reload Nginx
|
- name: Ensure Nginx is enabled and started
|
||||||
systemd:
|
systemd:
|
||||||
name: nginx
|
name: nginx
|
||||||
state: reloaded
|
enabled: yes
|
||||||
|
state: started
|
||||||
|
notify:
|
||||||
|
- Restart Nginx
|
27
ansible/roles/nginx_site/templates/nginx.conf.j2
Normal file
27
ansible/roles/nginx_site/templates/nginx.conf.j2
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
user nginx;
|
||||||
|
worker_processes auto;
|
||||||
|
error_log /var/log/nginx/error.log warn;
|
||||||
|
pid /var/run/nginx.pid;
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 1024;
|
||||||
|
}
|
||||||
|
|
||||||
|
http {
|
||||||
|
include mime.types;
|
||||||
|
default_type application/octet-stream;
|
||||||
|
|
||||||
|
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
|
||||||
|
'$status $body_bytes_sent "$http_referer" '
|
||||||
|
'"$http_user_agent" "$http_x_forwarded_for"';
|
||||||
|
|
||||||
|
access_log /var/log/nginx/access.log main;
|
||||||
|
|
||||||
|
sendfile on;
|
||||||
|
tcp_nopush on;
|
||||||
|
tcp_nodelay on;
|
||||||
|
keepalive_timeout 65;
|
||||||
|
types_hash_max_size 2048;
|
||||||
|
|
||||||
|
include /etc/nginx/conf.d/*.conf;
|
||||||
|
}
|
@ -1,4 +0,0 @@
|
|||||||
siteA_h2: "Дефолтный заголовок H2 для SiteA"
|
|
||||||
siteA_p: "Дефолтный параграф для SiteA"
|
|
||||||
siteB_h2: "Дефолтный заголовок H2 для SiteB"
|
|
||||||
siteB_p: "Дефолтный параграф для SiteB"
|
|
Loading…
Reference in New Issue
Block a user