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

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

От версии 2.1
отредактировано Ирина Сафонова
на 01.05.2023, 00:49
Изменить комментарий: К данной версии нет комментариев
К версии 18.1
отредактировано Ирина Сафонова
на 01.05.2023, 01:27
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

Свойства страницы
Теги
... ... @@ -1,0 +1,1 @@
1 +Terraform
Содержимое
... ... @@ -1,14 +1,15 @@
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  
13 13  {{info}}
14 14  Для Cloud Director 10.2 максимально поддерживаемая версия провайдера 3.7.0, для Cloud Director 10.3 максимальная поддерживаемая версия 3.9.0.
... ... @@ -16,27 +16,32 @@
16 16  Провайдер 3.9.0 https://registry.terraform.io/providers/vmware/vcd/latest/docs
17 17  {{/info}}
18 18  
19 -3. Инициализируйте Terraform в папке с конфигурационным файлом main.tf.
20 +[[image:Рисунок1.png]]
20 20  
22 +3. Инициализируйте Terraform в папке с конфигурационным файлом {{code language="none"}}main.tf{{/code}}.
23 +
21 21  {{info}}
22 22  Команда {{code language="none"}}terraform init{{/code}} используется для инициализации рабочего каталога Terraform. При введении команды она автоматически загрузит и установит все необходимые провайдеры и плагины Terraform.
23 23  {{/info}}
24 24  
25 -[[image:__fileCreatedFromDataURI__.png]]
28 +[[image:Рисунок2.png]]
26 26  
27 -4. Для обновления версии провайдера измените версию в файле main.tf и введите команду {{code language="none"}}terraform init -upgrade{{/code}}.
30 +4. Для обновления версии провайдера измените версию в файле {{code language="none"}}main.tf{{/code}} и введите команду {{code language="none"}}terraform init -upgrade{{/code}}.
28 28  
29 -[[image:__fileCreatedFromDataURI__.png]]
32 +[[image:Рисунок3.png]]
30 30  
31 -5. Проверьте версию Terraform и установленного провайдера при помощи команды {{code language="none"}}terraform -version{{/code}}//.//
32 -[[image:__fileCreatedFromDataURI__.png]]
34 +5. Проверьте версию Terraform и установленного провайдера при помощи команды {{code language="none"}}terraform -version{{/code}}.
33 33  
36 +[[image:Рисунок5.png]]
37 +
34 34  == Подключение к Cloud Director ==
35 35  
36 36  ----
37 37  
38 38  ~1. Заполните файл {{code language="none"}}main.tf{{/code}} данными.
39 -{{code language="none"}}provider "vcd" {
43 +
44 +{{code language="none"}}
45 +provider "vcd" {
40 40   user = var.vcd_user
41 41   password = var.vcd_pass
42 42   auth_type = "integrated"
... ... @@ -45,6 +45,223 @@
45 45   max_retry_timeout = var.vcd_max_retry_timeout
46 46   allow_unverified_ssl = var.vcd_allow_unverified_ssl
47 47  }
54 +
48 48  {{/code}}
49 49  
50 -
57 +2. Заполните {{code language="none"}}variables.tf{{/code}} данными:
58 +
59 +* Используется логин для авторизации в Cloud Director.
60 +
61 +{{code language="none"}}
62 +variable "vcd_user" {
63 + default = "my-terraform"
64 + description = "Cloud Director tenant user"
65 +}
66 +
67 +{{/code}}
68 +
69 +* Используется пароль для авторизации в Cloud Director.
70 +
71 +{{code language="none"}}
72 +variable "vcd_pass" {
73 + default = "my-password"
74 + description = " Cloud Director tenant password"
75 +}
76 +
77 +{{/code}}
78 +
79 +* Используется название Tenant Cloud Director
80 +
81 +{{code language="none"}}
82 +variable "vcd_org" {
83 + default = "DataFort "
84 + description = "Name tenant"
85 +}
86 +
87 +{{/code}}
88 +
89 +* Используется название Virtual Data Center.
90 +
91 +{{code language="none"}}
92 +variable "vcd_vdc" {
93 + default = "MY-VDC "
94 + description = "Name Virtual Data Center"
95 +}
96 +
97 +{{/code}}
98 +
99 +* Используется ссылка на подключение.
100 +
101 +{{code language="none"}}
102 +variable "vcd_url" {
103 + default = " https://cloud3.datafort.ru/api"
104 + description = "Cloud Director URL API"
105 +}
106 +variable "vcd_max_retry_timeout" {
107 + default = "60"
108 +}
109 +variable "vcd_allow_unverified_ssl" {
110 + default = "true"
111 + description = "Disable SSL certificate"
112 +}
113 +
114 +{{/code}}
115 +
116 +=== Основные команды ===
117 +
118 +* {{code language="none"}}terraform -help{{/code}} – вывод справок.
119 +* {{code language="none"}}terraform -version{{/code}} – вывод версии Terraform и установленных провайдеров.
120 +* {{code language="none"}}terraform init{{/code}} – инициализация каталога Terraform.
121 +* {{code language="none"}}terraform plan{{/code}} – генерация файла изменений и вывод изменений в инфраструктуре.
122 +* {{code language="none"}}terraform apply{{/code}} – применение изменений конфигурации, изначально выводит список изменений и/или добавлений в инфраструктуру.
123 +* {{code language="none"}}terraform destroy{{/code}} – удаление инфраструктуры.
124 +* {{code language="none"}}terraform refresh{{/code}} – обновление состояния с локальным файлом и состоянием реальных ресурсов.
125 +
126 +== Пример настройки ==
127 +
128 +----
129 +
130 +В примере создается **vApp**, в него помещается виртуальная машина и подключается к существующей сети. В файле {{code language="none"}}main.tf{{/code}}:
131 +
132 +1. Укажите провайдер поддерживаемой версии Cloud Director.
133 +
134 +{{code language="none"}}
135 +terraform {
136 + required_providers {
137 + vcd = {
138 + source = "vmware/vcd"
139 + version = "3.7.0"
140 + }
141 + }
142 +}
143 +
144 +{{/code}}
145 +
146 +2. Подключитесь к **Tenant**.
147 +
148 +{{code language="none"}}
149 +provider "vcd" {
150 + user = var.vcd_user
151 + password = var.vcd_pass
152 + auth_type = "integrated"
153 + org = var.vcd_org
154 + vdc = var.vcd_vdc
155 + url = var.vcd_url
156 + max_retry_timeout = var.vcd_max_retry_timeout
157 + allow_unverified_ssl = var.vcd_allow_unverified_ssl
158 +}
159 +
160 +{{/code}}
161 +
162 +3. Создайте **vApp**.
163 +
164 +{{code language="none"}}
165 +resource "vcd_vapp" "vapp1" {
166 + name = "my-first-vapp"
167 + vdc = var.vcd_vdc
168 + org = var.vcd_org
169 +}
170 +
171 +{{/code}}
172 +
173 +4. Подключитесь в ручную созданную сеть **network** к **vApp** **my-first-vapp**.
174 +
175 +{{code language="none"}}
176 +resource "vcd_vapp_org_network" "is-net" {
177 + vapp_name = "my-first-vapp"
178 + vdc = var.vcd_vdc
179 + org_network_name = "network"
180 + depends_on = [vcd_vapp.vapp1]
181 +}
182 +
183 +{{/code}}
184 +
185 +5. Создайте виртуальную машину из шаблона в **vApp my-first-vapp** и включите кастомизацию ВМ с подключением сети **network**.
186 +
187 +{{code language="none"}}
188 +resource "vcd_vapp_vm" "vm1" {
189 + vapp_name = vcd_vapp.vapp1.name
190 + name = "my-first-vm"
191 + computer_name = "myvm"
192 + cpus = 4
193 + cpu_cores = 2
194 + memory = 4096
195 + org = var.vcd_org
196 + vdc = var.vcd_vdc
197 + storage_profile = var.storage_br
198 + os_type = "windows9Server64Guest"
199 + catalog_name = var.catalog_name_templates
200 + template_name = var.name_templates
201 + depends_on = [vcd_vapp.vapp1, vcd_vapp_org_network.is-net]
202 + customization {
203 + enabled = true
204 + force = true
205 + change_sid = true
206 + allow_local_admin_password = true
207 + auto_generate_password = false
208 + admin_password = "my-secure-password"
209 + }
210 +
211 + network {
212 + adapter_type = "VMXNET3"
213 + connected = true
214 + ip_allocation_mode = "POOL"
215 + is_primary = true
216 + name = "network"
217 + type = "org"
218 + }
219 +}
220 +
221 +{{/code}}
222 +
223 +Файл {{code language="none"}}variables.tf{{/code}}.
224 +
225 +{{code language="none"}}
226 +variable "vcd_user" {
227 + default = "my-terraform"
228 + description = "Cloud Director tenant user"
229 +}
230 +variable "vcd_pass" {
231 + default = "my-password"
232 + description = "Cloud Director tenant password"
233 +}
234 +variable "vcd_org" {
235 + default = "DataFort"
236 + description = "Tenant name"
237 +}
238 +variable "vcd_vdc" {
239 + default = "MY-VDC"
240 + description = "Name VDC"
241 +}
242 +variable "vcd_url" {
243 + default = "https://cloud3.datafort.ru/api"
244 + description = "URL Cloud Director API"
245 +}
246 +variable "vcd_max_retry_timeout" {
247 + default = "60"
248 +}
249 +variable "vcd_allow_unverified_ssl" {
250 + default = "true"
251 + description = "Disable SSL certificate"
252 +}
253 +variable "storage_br" {
254 + default = "HP3.1-VCD-Templates-Bronze-6"
255 +}
256 +variable "catalog_name_templates" {
257 + default = "Windows"
258 + description = "Name catalog templates"
259 +}
260 +variable "name_templates" {
261 + default = "Win2016_DE_RUS DC3 vCD_tmp"
262 + description = "Name templates"
263 +}
264 +
265 +{{/code}}
266 +
267 +== Документация ==
268 +
269 +----
270 +
271 +* [[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]]  — конфигурация виртуальных машин и список типов операционных систем.
272 +* [[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.
273 +* [[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
Содержимое