Изменения документа 08. Подключение Terraform к VCD

Редактировал(а) Ирина Сафонова 18.03.2024, 22:31

От версии 3.1
отредактировано Ирина Сафонова
на 01.05.2023, 00:55
Изменить комментарий: К данной версии нет комментариев
К версии 21.1
отредактировано Ирина Сафонова
на 01.05.2023, 16:58
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

Свойства страницы
Теги
... ... @@ -1,0 +1,1 @@
1 +Terraform
Содержимое
... ... @@ -1,15 +1,23 @@
1 -*
2 -** Содержание
1 +**Содержание**
3 3  
3 +{{toc/}}
4 +
4 4  == Подготовка файла конфигурации ==
5 5  
6 6  ----
7 7  
8 -Для подготовки:
9 +Для подготовки конфигурационного файла:
9 9  
10 -1. Создайте конфигурационный файл main.tf и файл с переменными{{code language="none"}}variables.tf{{/code}}.
11 -2. Перейдите по ссылкам ниже и скопируйте поддерживаемый provider в файл конфигурации {{code language="none"}}main.tf{{/code}}.
11 +1. Создайте конфигурационный файл {{code language="none"}}main.tf{{/code}}и файл с переменными{{code language="none"}}variables.tf{{/code}}.
12 +2. Перейдите по ссылкам ниже и скопируйте поддерживаемый **provider** в файл конфигурации {{code language="none"}}main.tf{{/code}}.
12 12  
14 +(% data-xwiki-non-generated-content="java.util.List" %)
15 +(((
16 +" class="xwiki-metadata-container">Для Cloud Director 10.2 максимально поддерживаемая версия провайдера 3.7.0, для Cloud Director 10.3 максимальная поддерживаемая версия 3.9.0.
17 +Провайдер 3.7.0 https://registry.terraform.io/providers/vmware/vcd/3.7.0/docs
18 +Провайдер 3.9.0 https://registry.terraform.io/providers/vmware/vcd/latest/docs
19 +)))
20 +
13 13  {{info}}
14 14  Для Cloud Director 10.2 максимально поддерживаемая версия провайдера 3.7.0, для Cloud Director 10.3 максимальная поддерживаемая версия 3.9.0.
15 15  Провайдер 3.7.0 https://registry.terraform.io/providers/vmware/vcd/3.7.0/docs
... ... @@ -16,25 +16,35 @@
16 16  Провайдер 3.9.0 https://registry.terraform.io/providers/vmware/vcd/latest/docs
17 17  {{/info}}
18 18  
19 -3. Инициализируйте Terraform в папке с конфигурационным файлом main.tf.
27 +[[image:Рисунок1.png]]
20 20  
29 +3. Инициализируйте Terraform в папке с конфигурационным файлом {{code language="none"}}main.tf{{/code}}.
30 +
31 +(% data-xwiki-non-generated-content="java.util.List" %)
32 +(((
33 +" class="xwiki-metadata-container">Команда {{code language="none"}}terraform init{{/code}} используется для инициализации рабочего каталога Terraform. При введении команды она автоматически загрузит и установит все необходимые провайдеры и плагины Terraform.
34 +)))
35 +
21 21  {{info}}
22 22  Команда {{code language="none"}}terraform init{{/code}} используется для инициализации рабочего каталога Terraform. При введении команды она автоматически загрузит и установит все необходимые провайдеры и плагины Terraform.
23 23  {{/info}}
24 24  
25 -[[image:__fileCreatedFromDataURI__.png]]
40 +[[image:Рисунок2.png]]
26 26  
27 -4. Для обновления версии провайдера измените версию в файле main.tf и введите команду {{code language="none"}}terraform init -upgrade{{/code}}.
42 +4. Для обновления версии провайдера измените версию в файле {{code language="none"}}main.tf{{/code}} и введите команду {{code language="none"}}terraform init -upgrade{{/code}}.
28 28  
29 -[[image:__fileCreatedFromDataURI__.png]]
44 +[[image:Рисунок3.png]]
30 30  
31 -5. Проверьте версию Terraform и установленного провайдера при помощи команды {{code language="none"}}terraform -version{{/code}}//.//
32 -[[image:__fileCreatedFromDataURI__.png]]
46 +5. Проверьте версию Terraform и установленного провайдера при помощи команды {{code language="none"}}terraform -version{{/code}}.
33 33  
48 +[[image:Рисунок5.png]]
49 +
34 34  == Подключение к Cloud Director ==
35 35  
36 36  ----
37 37  
54 +Для подключения:
55 +
38 38  ~1. Заполните файл {{code language="none"}}main.tf{{/code}} данными.
39 39  
40 40  {{code language="none"}}
... ... @@ -52,7 +52,7 @@
52 52  
53 53  2. Заполните {{code language="none"}}variables.tf{{/code}} данными:
54 54  
55 -* Используется логин для авторизации в Cloud Director
73 +* Используется логин для авторизации в Cloud Director.
56 56  
57 57  {{code language="none"}}
58 58  variable "vcd_user" {
... ... @@ -62,7 +62,7 @@
62 62  
63 63  {{/code}}
64 64  
65 -* Используется пароль для авторизации в Cloud Director
83 +* Используется пароль для авторизации в Cloud Director.
66 66  
67 67  {{code language="none"}}
68 68  variable "vcd_pass" {
... ... @@ -82,7 +82,7 @@
82 82  
83 83  {{/code}}
84 84  
85 -* Используется название Virtual Data Center
103 +* Используется название Virtual Data Center.
86 86  
87 87  {{code language="none"}}
88 88  variable "vcd_vdc" {
... ... @@ -92,7 +92,7 @@
92 92  
93 93  {{/code}}
94 94  
95 -* Используется ссылка на подключение
113 +* Используется ссылка на подключение.
96 96  
97 97  {{code language="none"}}
98 98  variable "vcd_url" {
... ... @@ -109,4 +109,161 @@
109 109  
110 110  {{/code}}
111 111  
130 +=== Основные команды ===
112 112  
132 +* {{code language="none"}}terraform -help{{/code}} – вывод справок.
133 +* {{code language="none"}}terraform -version{{/code}} – вывод версии Terraform и установленных провайдеров.
134 +* {{code language="none"}}terraform init{{/code}} – инициализация каталога Terraform.
135 +* {{code language="none"}}terraform plan{{/code}} – генерация файла изменений и вывод изменений в инфраструктуре.
136 +* {{code language="none"}}terraform apply{{/code}} – применение изменений конфигурации, изначально выводит список изменений и/или добавлений в инфраструктуру.
137 +* {{code language="none"}}terraform destroy{{/code}} – удаление инфраструктуры.
138 +* {{code language="none"}}terraform refresh{{/code}} – обновление состояния с локальным файлом и состоянием реальных ресурсов.
139 +
140 +== Пример настройки ==
141 +
142 +----
143 +
144 +В примере создается **vApp**, в него помещается виртуальная машина и подключается к существующей сети. В файле {{code language="none"}}main.tf{{/code}}:
145 +
146 +1. Укажите провайдер поддерживаемой версии Cloud Director.
147 +
148 +{{code language="none"}}
149 +terraform {
150 + required_providers {
151 + vcd = {
152 + source = "vmware/vcd"
153 + version = "3.7.0"
154 + }
155 + }
156 +}
157 +
158 +{{/code}}
159 +
160 +2. Подключитесь к **Tenant**.
161 +
162 +{{code language="none"}}
163 +provider "vcd" {
164 + user = var.vcd_user
165 + password = var.vcd_pass
166 + auth_type = "integrated"
167 + org = var.vcd_org
168 + vdc = var.vcd_vdc
169 + url = var.vcd_url
170 + max_retry_timeout = var.vcd_max_retry_timeout
171 + allow_unverified_ssl = var.vcd_allow_unverified_ssl
172 +}
173 +
174 +{{/code}}
175 +
176 +3. Создайте **vApp**.
177 +
178 +{{code language="none"}}
179 +resource "vcd_vapp" "vapp1" {
180 + name = "my-first-vapp"
181 + vdc = var.vcd_vdc
182 + org = var.vcd_org
183 +}
184 +
185 +{{/code}}
186 +
187 +4. Подключитесь в ручную созданную сеть **network** к **vApp** **my-first-vapp**.
188 +
189 +{{code language="none"}}
190 +resource "vcd_vapp_org_network" "is-net" {
191 + vapp_name = "my-first-vapp"
192 + vdc = var.vcd_vdc
193 + org_network_name = "network"
194 + depends_on = [vcd_vapp.vapp1]
195 +}
196 +
197 +{{/code}}
198 +
199 +5. Создайте виртуальную машину (ВМ) из шаблона в **vApp my-first-vapp** и включите кастомизацию ВМ с подключением сети **network**.
200 +
201 +{{code language="none"}}
202 +resource "vcd_vapp_vm" "vm1" {
203 + vapp_name = vcd_vapp.vapp1.name
204 + name = "my-first-vm"
205 + computer_name = "myvm"
206 + cpus = 4
207 + cpu_cores = 2
208 + memory = 4096
209 + org = var.vcd_org
210 + vdc = var.vcd_vdc
211 + storage_profile = var.storage_br
212 + os_type = "windows9Server64Guest"
213 + catalog_name = var.catalog_name_templates
214 + template_name = var.name_templates
215 + depends_on = [vcd_vapp.vapp1, vcd_vapp_org_network.is-net]
216 + customization {
217 + enabled = true
218 + force = true
219 + change_sid = true
220 + allow_local_admin_password = true
221 + auto_generate_password = false
222 + admin_password = "my-secure-password"
223 + }
224 +
225 + network {
226 + adapter_type = "VMXNET3"
227 + connected = true
228 + ip_allocation_mode = "POOL"
229 + is_primary = true
230 + name = "network"
231 + type = "org"
232 + }
233 +}
234 +
235 +{{/code}}
236 +
237 +Файл {{code language="none"}}variables.tf{{/code}}.
238 +
239 +{{code language="none"}}
240 +variable "vcd_user" {
241 + default = "my-terraform"
242 + description = "Cloud Director tenant user"
243 +}
244 +variable "vcd_pass" {
245 + default = "my-password"
246 + description = "Cloud Director tenant password"
247 +}
248 +variable "vcd_org" {
249 + default = "DataFort"
250 + description = "Tenant name"
251 +}
252 +variable "vcd_vdc" {
253 + default = "MY-VDC"
254 + description = "Name VDC"
255 +}
256 +variable "vcd_url" {
257 + default = "https://cloud3.datafort.ru/api"
258 + description = "URL Cloud Director API"
259 +}
260 +variable "vcd_max_retry_timeout" {
261 + default = "60"
262 +}
263 +variable "vcd_allow_unverified_ssl" {
264 + default = "true"
265 + description = "Disable SSL certificate"
266 +}
267 +variable "storage_br" {
268 + default = "HP3.1-VCD-Templates-Bronze-6"
269 +}
270 +variable "catalog_name_templates" {
271 + default = "Windows"
272 + description = "Name catalog templates"
273 +}
274 +variable "name_templates" {
275 + default = "Win2016_DE_RUS DC3 vCD_tmp"
276 + description = "Name templates"
277 +}
278 +
279 +{{/code}}
280 +
281 +== Ссылки на документацию ==
282 +
283 +----
284 +
285 +* [[https:~~/~~/registry.terraform.io/providers/vmware/vcd/latest/docs/resources/vapp_vm>>url:https://registry.terraform.io/providers/vmware/vcd/latest/docs/resources/vapp_vm]]  — конфигурация виртуальных машин и список типов операционных систем.
286 +* [[https:~~/~~/registry.terraform.io/providers/vmware/vcd/3.7.0/docs>>url:https://registry.terraform.io/providers/vmware/vcd/3.7.0/docs]] — перечисленные ресурсы для Cloud Director.
287 +* [[https:~~/~~/developer.hashicorp.com/terraform/downloads>>url:https://developer.hashicorp.com/terraform/downloads]] — ссылка на скачивание Terraform.
Рисунок1.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.ISafonova
Размер
... ... @@ -1,0 +1,1 @@
1 +54.7 KB
Содержимое
Рисунок2.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.ISafonova
Размер
... ... @@ -1,0 +1,1 @@
1 +123.7 KB
Содержимое
Рисунок3.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.ISafonova
Размер
... ... @@ -1,0 +1,1 @@
1 +119.1 KB
Содержимое
Рисунок5.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.ISafonova
Размер
... ... @@ -1,0 +1,1 @@
1 +14.2 KB
Содержимое