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

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

От версии 23.1
отредактировано Ирина Сафонова
на 01.05.2023, 16:58
Изменить комментарий: К данной версии нет комментариев
К версии 13.1
отредактировано Ирина Сафонова
на 01.05.2023, 01:08
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

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