Локальная разработка критически важна. Не стоит жертвовать возможностью тестировать и отлаживать код на локальной машине, используя динамические словари (maps) как универсальные переменные модулей. Определяйте параметры как отдельные переменные или объекты с известными атрибутами, чтобы избежать слепой работы.
При создании модулей Terraform нужно учитывать, кто будет их использовать. Инженеры хотят видеть детали и контролировать конфигурацию, программистам же требуется быстро разворачивать инфраструктуру с минимальным количеством решений. Стремитесь к разумным умолчаниям, минимизируйте обязательные параметры и сделайте модули максимально удобными для всех пользователей.
Модули должны «трамбовать сложность», предоставляя сбалансированные абстракции. Это достигается за счет уменьшения количества обязательных параметров, с предоставлением достаточного количества опциональных параметров с разумными умолчаниями. Это позволяет разработчикам быстро начать работу, сохраняя при этом возможность переопределить настройки при необходимости. Такие модули образуют высокоуровневые пакеты, описывающие паттерны платформ.
Структурируйте код Terraform с помощью модулей (описывающих отдельные ресурсы), стеков (собирающих решения из модулей) и развертываний (инстансы или окружения стеков). Используйте каталоги modules, stacks и deployments. Это позволит поддерживать чистый, масштабируемый и понятный код, упростит управление сложной инфраструктурой и позволит повторно использовать код.
Изображение носит иллюстративный характер
При создании модулей Terraform нужно учитывать, кто будет их использовать. Инженеры хотят видеть детали и контролировать конфигурацию, программистам же требуется быстро разворачивать инфраструктуру с минимальным количеством решений. Стремитесь к разумным умолчаниям, минимизируйте обязательные параметры и сделайте модули максимально удобными для всех пользователей.
Модули должны «трамбовать сложность», предоставляя сбалансированные абстракции. Это достигается за счет уменьшения количества обязательных параметров, с предоставлением достаточного количества опциональных параметров с разумными умолчаниями. Это позволяет разработчикам быстро начать работу, сохраняя при этом возможность переопределить настройки при необходимости. Такие модули образуют высокоуровневые пакеты, описывающие паттерны платформ.
Структурируйте код Terraform с помощью модулей (описывающих отдельные ресурсы), стеков (собирающих решения из модулей) и развертываний (инстансы или окружения стеков). Используйте каталоги modules, stacks и deployments. Это позволит поддерживать чистый, масштабируемый и понятный код, упростит управление сложной инфраструктурой и позволит повторно использовать код.