From 168bb6e0181a9a837131cedac4edd16e36315b94 Mon Sep 17 00:00:00 2001 From: andramariaglavan Date: Thu, 8 Sep 2022 08:27:44 +0000 Subject: [PATCH] GitBook: [#26] edit welcome v2 + small checks --- README.md | 28 +++++++++---------- code-structure.md | 14 +++++----- examples/README.md | 10 +++---- ...arge-size-infrastructure-with-terraform.md | 2 +- .../terraform/medium-size-infrastructure.md | 6 ++-- .../terraform/small-size-infrastructure.md | 2 +- key-concepts.md | 6 ++-- naming.md | 10 +++---- 8 files changed, 39 insertions(+), 39 deletions(-) diff --git a/README.md b/README.md index 3fb2b93..6ebec04 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ description: >- # Bine ați venit -[Terraform](https://www.terraform.io/) este un proiect nou (ca și concept-ul de DevOps) și a fost creat în 2014. +[Terraform](https://www.terraform.io/) este un proiect nou (ca și majoritatea tool-urilor de DevOps) și a fost creat în 2014. Terraform este unul din cele mai puternice (poate chiar cel mai puternic) instrumente și unul din cele mai folosite pentru a defini infrastructura ca și cod. Le permite dezvoltatorilor să facă o mulțime de lucruri și nu îi împiedică să facă lucruri în moduri care vor fi greu de susținut sau de integrat în viitor. @@ -59,28 +59,28 @@ Câțiva ani mai târziu, a fost actualizată cu mai multe bune practici disponi [Українська (Ukrainian)](https://app.gitbook.com/o/-LMqIrDlzEiI-N4uHrWg/s/tXRvMPILxeJaJTM2CsSq/) {% endcontent-ref %} -Contact me if you want to help translate this book into other languages. +Contactați-mă dacă doriți să ajutați la traducerea acestei cărți în alte limbi. -## Contributions +## Contribuții -I always want to get feedback and update this book as the community mature and new ideas are implemented and verified over time. +Îmi doresc întotdeauna să primesc feedback și să actualizez această carte pe măsură ce comunitatea se maturizează și noi idei sunt implementate și verificate în timp. -If you are interested in certain topics please [open an issue](https://github.com/antonbabenko/terraform-best-practices/issues), or thumb up an issue you want to be covered most. If you feel that **you have content** and you want to contribute, write a draft and submit a pull request (don't worry about writing good text at this point!) +Dacă sunteți interesați de anumite subiecte vă rog[ ](https://github.com/antonbabenko/terraform-best-practices/issues)deschideți [un issue](https://github.com/antonbabenko/terraform-best-practices/issues) (o problemă), sau dați "Like" la o problemă existentă pe care doriți să o abordați cel mai mult. Dacă simțiți că aveți conținut și doriți să contribui, scrieți un text și trimiteți un pull request (nu vă faceți griji dacă scrieți un text bun în acest moment!). -## Authors +## Autori -This book is maintained by [Anton Babenko](https://github.com/antonbabenko) with the help of different contributors and translators. +Această carte este menținută de [Anton Babenko](https://github.com/antonbabenko) cu ajutorul diferiților colaboratori și traducători. -## Sponsors +## Sponsori -| [![](.gitbook/assets/cluster-dev-logo-site.png)](https://cluster.dev) | [Cluster.dev](http://cluster.dev) — the only manager for cloud-native infrastructures. | -| --------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------- | -| [![](.gitbook/assets/coder-logo-for-sponsor.png)](http://coder.com/) | [Coder.com](http://coder.com/) — create remote development machines for your team, powered by Terraform. | +| [![](.gitbook/assets/cluster-dev-logo-site.png)](https://cluster.dev) | [Cluster.dev](http://cluster.dev) — singurul manager pentru infrastructurile cloud native. | +| --------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------- | +| [![](.gitbook/assets/coder-logo-for-sponsor.png)](http://coder.com/) | [Coder.com](http://coder.com/) — creați mașini de dezvoltare la distanță (remote) pentru echipa voastră, susținut de Terraform. | -## License +## Licență -This work is licensed under Apache 2 License. See LICENSE for full details. +Această lucrare este licențiată sub Apache 2 License. Consultați LICENSE pentru detalii complete. -The authors and contributors to this content cannot guarantee the validity of the information found here. Please make sure that you understand that the information provided here is being provided freely, and that no kind of agreement or contract is created between you and any persons associated with this content or project. The authors and contributors do not assume and hereby disclaim any liability to any party for any loss, damage, or disruption caused by errors or omissions in the information contained in, associated with, or linked from this content, whether such errors or omissions result from negligence, accident, or any other cause. +Autorii și colaboratorii la acest conținut nu pot garanta valabilitatea informațiilor găsite aici. Vă rugăm să vă asigurați că înțelegeți că informațiile furnizate aici sunt furnizate în mod liber și că nu este creat niciun fel de acord sau contract între dvs. și orice persoană asociată cu acest conținut sau proiect. Autorii și colaboratorii nu își asumă și nu își declină nicio responsabilitate față de orice parte pentru orice pierdere, daune sau întrerupere cauzată de erori sau omisiuni în informațiile conținute în, asociate cu sau legate de acest conținut, indiferent dacă astfel de erori sau omisiuni rezultă din neglijență, accident sau orice altă cauză. Copyright © 2018-2022 Anton Babenko. diff --git a/code-structure.md b/code-structure.md index f6bf50d..20a0811 100644 --- a/code-structure.md +++ b/code-structure.md @@ -4,7 +4,7 @@ ## Cum ar trebui să-mi structurez configurațiile Terraform? -Aceasta este una dintre întrebările pentru care există o mulțime de soluții și este foarte greu să dai sfaturi universale, așa că să începem cu a înțelege cu ce avem de-a face. +Aceasta este una dintre întrebările pentru care există o mulțime de soluții și este foarte greu să dai sfaturi universale, așa că este util să începem prin a înțelege cu ce avem de-a face. * Care este complexitatea proiectului? * Numărul de resurse aferente @@ -12,8 +12,8 @@ Aceasta este una dintre întrebările pentru care există o mulțime de soluții * Cât de des se schimbă infrastructura proiectului? * **De la** o dată pe lună/săptămână/zi * **La** continuu (de fiecare dată când există un nou commit) -* Tirggeri pentru schimbari in cod? _Permiteți serverului CI să actualizeze depozitul Gitatunci când este construit un nou artefact?_ - * Doar dezvoltatorii pot face push în depozitul de infrastructură +* Tirggeri pentru schimbari in cod? _Permiteți serverului CI să actualizeze Git repository atunci când este construit un nou artefact?_ + * Doar dezvoltatorii pot face push în repository-ul de infrastructură * Toată lumea poate propune o schimbare la orice, deschizând un PR (inclusiv activități automate care rulează pe serverul CI) * Ce platformă de implementare sau serviciu de implementare utilizați? * AWS CodeDeploy, Kubernetes, sau OpenShift au nevoie de o abordare ușor diferită @@ -38,7 +38,7 @@ Punerea întregului cod în `main.tf` este o idee bună atunci când începeți ## Cum să ne gândim la structura fișierelor de configurație Terraform? {% hint style="info" %} -Vă rugăm să vă asigurați că înțelegeți conceptele cheie - [modulul de resurse](key-concepts.md#modul-de-resurse), [modulul de infrastructură](key-concepts.md#modulul-de-infrastructura) și [compoziția de infrastructură](key-concepts.md#compozitia-de-infrastructura), așa cum sunt utilizate în exemplele următoare. +Vă rog să vă asigurați că înțelegeți conceptele cheie - [modulul de resurse](key-concepts.md#modul-de-resurse), [modulul de infrastructură](key-concepts.md#modulul-de-infrastructura) și [compoziția de infrastructură](key-concepts.md#compozitia-de-infrastructura), așa cum sunt utilizate în exemplele următoare. {% endhint %} ### Recomandări uzuale pentru structurarea codului @@ -53,7 +53,7 @@ Vă rugăm să vă asigurați că înțelegeți conceptele cheie - [modulul de r * Gestionarea unui fișier`tfstate` în git este un coșmar * Mai târziu, când straturile de infrastructură vor începe să crească în mai multe direcții (număr de dependențe sau resurse), va fi mai ușor să țineți lucrurile sub control * Practicați o structură consecventă și o convenție de denumire a resurselor ([naming](naming.md) convention): - * La fel ca în cazul codului procedural, codul Terraform ar trebui scris pentru ca oamenii să-l citească mai întâi, consecvența va ajuta atunci când vor avea loc schimbări peste șase luni. + * La fel ca în cazul codului procedural, codul Terraform ar trebui scris pentru ca oamenii să-l citească mai întâi, consecvența va ajuta atunci când vor avea loc schimbări peste șase luni * Este posibil să mutați resurse în fișierul de stare Terraform, dar poate fi mai greu de făcut dacă aveți o structură și o denumire inconsecventă * Păstrați modulele de resurse cât mai simple posibil * Nu puneți simplu text (hardcoded) valorile care pot fi transmise ca variabile sau descoperite folosind surse de date @@ -63,7 +63,7 @@ Vă rugăm să vă asigurați că înțelegeți conceptele cheie - [modulul de r ### Orchestrarea modulelor și compozițiilor de infrastructură -A avea o infrastructură mică înseamnă că există un număr mic de dependențe și puține resurse. Pe măsură ce proiectul crește, necesitatea de a înlănțui execuția configurațiilor Terraform, conectarea diferitelor module de infrastructură și transmiterea valorilor într-o compoziție devine evidentă. +A avea o infrastructură mică înseamnă că există un număr mic de dependențe și puține resurse. Pe măsură ce proiectul crește, necesitatea de a înlănțui execuția configurațiilor Terraform, conectarea diferitelor module de infrastructură și transmiterea valorilor într-o compoziție, devine evidentă. Există cel puțin 5 grupuri distincte de soluții de orchestrare pe care dezvoltatorii le folosesc: @@ -71,7 +71,7 @@ Există cel puțin 5 grupuri distincte de soluții de orchestrare pe care dezvol 2. Terragrunt. Instrument de orchestrare pur, care poate fi folosit pentru a orchestra întreaga infrastructură, precum și pentru a gestiona dependențe. Terragrunt operează cu module de infrastructură și compoziții în mod nativ, astfel încât reduce duplicarea codului. 3. Scripturi interne. Adesea, acest lucru se întâmplă ca punct de plecare către orchestrare și înainte de a descoperi Terragrunt. 4. Instrument de automatizare Ansible sau altceva asemănător. Utilizat de obicei atunci când Terraform este adoptat după Ansible sau când Ansible UI este utilizat în mod activ. -5. [Crossplane](https://crossplane.io/) și alte soluții inspirate de Kubernetes. Uneori, este logic să utilizați ecosistemul Kubernetes și să folosiți o funcție de buclă de reconciliere pentru a obține starea dorită a configurațiilor dvs. Terraform. Vizualizați videoclipul [Crossplane vs Terraform](https://www.youtube.com/watch?v=ELhVbSdcqSY) pentru mai multe informatii. +5. [Crossplane](https://crossplane.io/) și alte soluții inspirate de Kubernetes. Uneori, este logic să utilizați ecosistemul Kubernetes și să folosiți o funcție de buclă de reconciliere pentru a obține starea dorită a configurațiilor Terraform. Vizualizați videoclipul [Crossplane vs Terraform](https://www.youtube.com/watch?v=ELhVbSdcqSY) pentru mai multe informații. Având în vedere acest lucru, această carte trece în revistă primele două dintre aceste structuri de proiect, doar Terraform și Terragrunt. diff --git a/examples/README.md b/examples/README.md index 15fa5f9..b71b00f 100644 --- a/examples/README.md +++ b/examples/README.md @@ -15,8 +15,8 @@ Exemplele următoare prezintă cazul în care AWS a fost ales ca furnizor, dar m ## Structuri de cod Terragrunt -| Tip | Descriere | Disponibilitate | -| ----------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------- | -| medie | Mai multe conturi de AWS și medii de lucru, module de infrastructură gata de folosire, model de compoziție folosind Terragrunt. | Nu | -| mare | Mai multe conturi de AWS, multiple regiuni many regions, nevoie urgentă de a reduce folosirea metodei copy-paste, module de infrastructură personalizate, utilizare ridicata a compoziției de cod. Folosind Terragrunt. | Nu | -| foarte mare | Furnizori multiplii (AWS, GCP, Azure). Implementări multi-cloud. Folosind Terragrunt. | Nu | +| Tip | Descriere | Disponibilitate | +| ----------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------- | +| medie | Mai multe conturi de AWS și medii de lucru, module de infrastructură gata de folosire, model de compoziție folosind Terragrunt. | Nu | +| mare | Mai multe conturi de AWS, multiple regiuni, nevoie urgentă de a reduce folosirea metodei copy-paste, module de infrastructură personalizate, utilizare ridicata a compoziției de cod. Folosind Terragrunt. | Nu | +| foarte mare | Furnizori multiplii (AWS, GCP, Azure). Implementări multi-cloud. Folosind Terragrunt. | Nu | diff --git a/examples/terraform/large-size-infrastructure-with-terraform.md b/examples/terraform/large-size-infrastructure-with-terraform.md index a7e7b12..d68d2e1 100644 --- a/examples/terraform/large-size-infrastructure-with-terraform.md +++ b/examples/terraform/large-size-infrastructure-with-terraform.md @@ -8,7 +8,7 @@ Acest exemplu conține un cod ca exemplu de structurare a configuraților Terraf * 2 regiuni * 2 medii de lucru separate (`prod` și `stage` care nu au procese comune). Fiecare mediu de lucru există într-un cont AWS separat și conține resurse în două regiuni * Fiecare mediu de lucru folosește o altă versiune a modulelor de infrastructură gata de folosire (`alb`) provenite din [Terraform Registry](https://registry.terraform.io/) -* Fiecare mediu de lucru folosește aceeași versiune a unui modul intern `modules/network` provenind din aceeași sursă locală (local directory). +* Fiecare mediu de lucru folosește aceeași versiune a unui modul intern `modules/network` provenind din aceeași sursă locală (local directory) {% hint style="info" %} Într-un proiect de dimensiuni mari ca cel descris aici, beneficiile utilizării Terragrunt devin foarte vizibile. Vezi [Exemple de structuri de cod - Terragrunt](../terragrunt.md). diff --git a/examples/terraform/medium-size-infrastructure.md b/examples/terraform/medium-size-infrastructure.md index 464c5b7..1838783 100644 --- a/examples/terraform/medium-size-infrastructure.md +++ b/examples/terraform/medium-size-infrastructure.md @@ -5,9 +5,9 @@ Sursă: [https://github.com/antonbabenko/terraform-best-practices/tree/master/ex Acest exemplu conține un cod ca exemplu de structurare a configuraților Terraform pentru o infrastructură de dimensiuni medii care folosește: * 2 conturi AWS -* 2 medii de lucru separate (`prod` și `stage` care nu au procese comune). Fiecare mediu de lucru există într-un cont AWS separat. -* Fiecare mediu de lucru folosește o altă versiune a modulelor de infrastructură gata de folosire (`alb`) provenite din [Terraform Registry](https://registry.terraform.io/). -* Fiecare mediu de lucru folosește aceeași versiune a unui modul intern `modules/network` provenind din aceeași sursă locală (local directory). +* 2 medii de lucru separate (`prod` și `stage` care nu au procese comune). Fiecare mediu de lucru există într-un cont AWS separat +* Fiecare mediu de lucru folosește o altă versiune a modulelor de infrastructură gata de folosire (`alb`) provenite din [Terraform Registry](https://registry.terraform.io/) +* Fiecare mediu de lucru folosește aceeași versiune a unui modul intern `modules/network` provenind din aceeași sursă locală (local directory) {% hint style="success" %} * Perfect pentru proiecte în care infrastructura este separată logic (conturi AWS separate) diff --git a/examples/terraform/small-size-infrastructure.md b/examples/terraform/small-size-infrastructure.md index fa331df..e9373ce 100644 --- a/examples/terraform/small-size-infrastructure.md +++ b/examples/terraform/small-size-infrastructure.md @@ -12,5 +12,5 @@ Acest exemplu conține un cod ca exemplu de structurare a configuraților Terraf {% endhint %} {% hint style="warning" %} -Un singur fișier de stare pentru toate resursele poate face procesul de lucru cu Terraform să încetinească dacă numărul de resurse crește (considerați folosirea unui argument ca `-target` pentru a limita numărul de resurse). +Un singur fișier de stare pentru toate resursele poate face procesul de lucru cu Terraform să încetinească dacă numărul de resurse crește (considerați folosirea unui argument ca`-target` pentru a limita numărul de resurse). {% endhint %} diff --git a/key-concepts.md b/key-concepts.md index 21caafe..a68632f 100644 --- a/key-concepts.md +++ b/key-concepts.md @@ -8,7 +8,7 @@ Acest capitol descrie conceptele cheie folosite în această carte. Resursele sunt, de exemplu, `aws_vpc`, `aws_db_instance`, etc. O resursă aparține unui furnizor (provider), acceptă argumente, întoarce atribute și are cicluri de viață. O resursă poate fi creată, preluată, actualizată și ștearsă. -## Modul de resurse +## Modulul de resurse Modulul de resurse este o colecție de resurse conectate care realizează împreună o acțiune comună (de exemplu, [modulul Terraform pentru AWS VPC](https://github.com/terraform-aws-modules/terraform-aws-vpc/) creează VPC, subrețele, NAT gateway etc.). Depinde de configurația furnizorului, care poate fi definită în acesta, sau în structuri de nivel superior (de exemplu, în modulul de infrastructură). @@ -24,7 +24,7 @@ Un alt exemplu este modulul [terraform-aws-cloudquery](https://github.com/cloudq Compoziţia este o colecție de module de infrastructură, care se pot întinde pe mai multe zone separate logic (de exemplu, regiuni AWS, mai multe conturi AWS). Compoziţia este utilizată pentru a descrie infrastructura completă necesară pentru întreaga organizație sau întreagul proiect. -O compoziţie constă din module de infrastructură, care constau din module de resurse, care implementează resurse individuale. +O compoziţie este constituită din module de infrastructură, care sunt constituite din module de resurse, care implementează resurse individuale. ![O compoziţie de infrastructură simplă ](.gitbook/assets/composition-1.png) @@ -40,7 +40,7 @@ Sursa de date [http ](https://registry.terraform.io/providers/hashicorp/http/lat ## Remote state -Modulele de infrastructură și compozițiile ar trebui să-și păstreze [starea Terraform](https://www.terraform.io/language/state) într-o locație la distanță numită remote state, unde pot fi preluate de către alții într-un mod controlabil (de exemplu, specificați ACL, versionări, logging). +Modulele de infrastructură și compozițiile ar trebui să-și păstreze [starea Terraform](https://www.terraform.io/language/state) într-o locație la distanță numită remote state, unde pot fi preluate de către alții într-un mod controlabil (de exemplu, specificații ACL, versionări, logging). ## Provider, provisioner, etc diff --git a/naming.md b/naming.md index fe55ca9..ec41d7e 100644 --- a/naming.md +++ b/naming.md @@ -7,7 +7,7 @@ Nu există niciun motiv să nu se respecte măcar aceste convenții :) {% endhint %} {% hint style="info" %} -Atenție că resursele din cloud în realitate au adesea restricții în numele permise. Unele resurse, de exemplu, nu pot conține cratimă, unele trebuie sa fie cu majuscule mediale (CamelCase). Convenția din aceasta carte se referă la numele din Terraform în sine. +Atenție că resursele din cloud în realitate au adesea restricții în numele permise. Unele resurse, de exemplu, nu pot conține cratimă, unele trebuie sa fie scrise cu majuscule mediale (CamelCase). Convenția din aceasta carte se referă la numele din Terraform în sine. {% endhint %} 1. Folosiți `_` (underscore) în loc de `-` (cratimă) peste tot (numele resurselor, numele surselor de date, numele variabilelor, outputs, etc). @@ -28,7 +28,7 @@ Atenție că resursele din cloud în realitate au adesea restricții în numele {% hint style="danger" %} `resource "aws_route_table" "public_aws_route_table" {}` {% endhint %} -2. Numele resursei ar trebui să fie ales `this` dacă nu mai există un nume descriptiv și general disponibil sau dacă modulul de resurse creează o singură resursă de acest tip (ex.: în [AWS VPC module](https://github.com/terraform-aws-modules/terraform-aws-vpc) există o singură resursă de tip `aws_nat_gateway` ași resurse multiple de tip`aws_route_table`, așadar `aws_nat_gateway` ar trebui să primească numele `this` și `aws_route_table` ar trebui să primească nume mai descriptive - cum ar fi `private`, `public`, `database`). +2. Numele resursei ar trebui să fie ales `this` dacă nu mai există un nume descriptiv și general disponibil sau dacă modulul de resurse creează o singură resursă de acest tip (ex.: în [AWS VPC module](https://github.com/terraform-aws-modules/terraform-aws-vpc) există o singură resursă de tip `aws_nat_gateway` și resurse multiple de tip`aws_route_table`, așadar `aws_nat_gateway` ar trebui să primească numele `this` și `aws_route_table` ar trebui să primească nume mai descriptive - cum ar fi `private`, `public`, `database`). 3. Folosiți întotdeauna substantive la singular pentru nume. 4. Folosiți `-` în interiorul valorilor argumentelor și în locurile în care valoarea va fi expusă unui om (ex.: în interiorul numelui DNS al instanței RDS). 5. Includeți argumentul`count` / `for_each` în interiorul blocului de resurse sau sursă de date ca prim argument în partea de sus și separat prin linie nouă după acesta. @@ -140,11 +140,11 @@ resource "aws_nat_gateway" "this" { # Good 2. Suportul pentru validarea variabilelor este destul de limitat (de exemplu, nu pot accesa alte variabile sau nu pot face căutări). Planificați în consecință, deoarece în multe cazuri această caracteristică este inutilă. 3. Utilizați forma de plural într-un nume de variabilă atunci când tipul este `list(...)` sau `map(...)`. 4. Ordonați cheile într-un bloc de variabilă astfel: `description` , `type`, `default`, `validation`. -5. Includeți întotdeauna `description` pentru toate variabilele chiar dacă vi se pare că este evident (veți avea nevoie de aceasta în viitor). +5. Includeți întotdeauna `description` pentru toate variabilele chiar dacă vi se pare că este evident ce fac (veți avea nevoie de această informație în viitor). 6. De preferință, alegeți folosirea unor tipuri simple (`number`, `string`, `list(...)`, `map(...)`, `any`) în loc de tipuri ca `object()` cu excepția cazului în care trebuie să aveți constrângeri stricte pentru fiecare cheie. 7. De preferință, alegeți folosirea tipurilor specifice, ca`map(map(string))` dacă toate elementele din map au același tip (ex.: `string`) sau pot fi convertite (ex.: tipul `number` poate fi convertit la tipul `string`). 8. Utilizați tipul `any` pentru a dezactiva validarea tipului începând de la o anumită adâncime sau atunci când mai multe tipuri ar trebui să fie acceptate. -9. Valoarea `{}` este uneori de tip map (hartă), dar alteori un obiect. Utilizați `tomap(...)` pentru a face o hartă pentru că nu există nicio modalitate de a face un obiect. +9. Valoarea `{}` este uneori de tip map (hartă), dar alteori un obiect. Utilizați `tomap(...)` pentru a o face de tip map pentru că nu există nicio modalitate de a face un obiect. ## Outputs @@ -158,7 +158,7 @@ Faceți rezultatele (outputs) consistente și ușor de înțeles în afara domen 4. [Vezi exemple](naming.md#exemple-de-cod-pentru-output). 3. Dacă rezultatul returnează o valoare cu funcții de interpolare și resurse multiple, `{name}` și `{type}` ar trebui să fie cât mai generice (`this` ca prefix ar trebui să fie omis). [Vezi exemple](naming.md#exemple-de-cod-pentru-output). 4. Dacă valoarea returnată este o listă, aceasta ar trebui să aibă un nume la plural.[ Vezi exemplu](naming.md#folositi-numele-la-plural). -5. Includeți întotdeauna `description` pentru toate rezultatele (outputs) chiar dacă credeți că este ceva evident. +5. Includeți întotdeauna `description` pentru toate rezultatele (outputs) chiar dacă vi se pare că este ceva evident. 6. Evitați setarea `sensitive` pentru argumente cu excepția cazului în care controlați pe deplin utilizarea acestui rezultat în toate locurile din toate modulele. 7. De preferință, alegeți`try()` (disponibil începând cu Terraform 0.13) în loc de `element(concat(...))` (abordarea legacy folosită înainte de versiunea 0.13)