# Größere Infrastruktur mit Terraform

Quellcode: <https://github.com/antonbabenko/terraform-best-practices/tree/master/examples/large-terraform>

Dieses Beispiel enthält Code als Beispiel für die Strukturierung von Terraform-Konfigurationen für eine groß angelegte Infrastruktur, dazu werden verwendet:

* 2 AWS-Konten
* 2 Regionen
* 2 separate Umgebungen (`prod` und `stage`, die sich nichts teilen). Jede Umgebung befindet sich in einem separaten AWS-Konto und verteilt die Ressourcen auf 2 Regionen.
* Jede Umgebung verwendet eine andere Version des Standard-Infrastrukturmoduls (`alb`), das aus der [Terraform-Registry](https://registry.terraform.io/) stammt.
* Jede Umgebung verwendet die gleiche Version eines internen Moduls `modules/network`, da es aus einem lokalen Verzeichnis stammt.

{% hint style="info" %}
In einem großen Projekt wie dem hier beschriebenen werden die Vorteile der Verwendung von Terragrunt sehr deutlich. Siehe [Beispiele für Code-Strukturen mit Terragrunt](/de/examples/terragrunt.md).
{% endhint %}

{% hint style="success" %}

* Perfekt für Projekte, bei denen die Infrastruktur logisch getrennt ist (separate AWS-Konten)
* Gut, wenn keine Notwendigkeit besteht, zwischen AWS-Konten geteilte Ressourcen zu ändern (eine Umgebung = ein AWS-Konto = eine Statusdatei)
* Gut, wenn kein Bedarf an der Orchestrierung von Änderungen zwischen den Umgebungen besteht
* Gut, wenn die Infrastrukturressourcen pro Umgebung absichtlich unterschiedlich sind und nicht verallgemeinert werden können (z. B. sind einige Ressourcen in einer Umgebung oder in einigen Regionen nicht vorhanden)
  {% endhint %}

{% hint style="warning" %}
Je größer das Projekt wird, desto schwieriger wird es, diese Umgebungen untereinander auf dem neuesten Stand zu halten. Erwägen Sie den Einsatz von Infrastrukturmodulen (von der Stange oder intern) für wiederholbare Aufgaben.
{% endhint %}

##


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://www.terraform-best-practices.com/de/examples/terraform/large-size-infrastructure-with-terraform.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
