This commit is contained in:
Пётр Крутов
2022-09-21 12:11:42 +00:00
parent b152359706
commit 1a983e945b
78 changed files with 5009 additions and 87 deletions

View File

@@ -0,0 +1,37 @@
/*
Пример использования
Получение информации о load balancer (балансировщик нагрузок)
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
data "decort_lb" "lb" {
#id балансировщика нагрузок
#обязательный параметр
#тип - число
lb_id = 238
}
output "test" {
value = data.decort_lb.lb
}

View File

@@ -0,0 +1,52 @@
/*
Пример использования
Получение списка load balancer (балансировщиков нагрузки)
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
data "decort_lb_list" "lbl" {
#флаг влючения в результат удаленных балансироващиков нагрузки
#опциональный параметр
#тип - булев тип
#значение по-умолчанию - false
#если не задан - выводятся все доступные неудаленные балансировщики
#includedeleted = true
#номер страницы для отображения
#опциональный параметр
#тип - число
#если не задан - выводятся все доступные данные
#page = 1
#размер страницы
#опциональный параметр
#тип - число
#если не задан - выводятся все доступные данные
#size = 1
}
output "test" {
value = data.decort_lb_list.lbl
}

View File

@@ -0,0 +1,45 @@
/*
Пример использования
Получение списка удаленных load balancer (балансировщиков нагрузок)
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
data "decort_lb_list_deleted" "lbld" {
#номер страницы для отображения
#опциональный параметр
#тип - число
#если не задан - выводятся все доступные данные
#page = 1
#размер страницы
#опциональный параметр
#тип - число
#если не задан - выводятся все доступные данные
#size = 1
}
output "test" {
value = data.decort_lb_list_deleted.lbld
}

View File

@@ -0,0 +1,80 @@
/*
Пример использования
Работа с ресурсом kvmvm (compute)
Ресурс позволяет:
1. Создавать compute
2. Редактировать compute
3. Удалять compute
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
resource "decort_kvmvm" "comp" {
#имя compute
#обязательный параметр
#мб изменен
#тип - строка
name = "test-tf-compute-update-new"
#id resource group
#обязательный параметр
#тип - число
rg_id = 1111
#тип драйвера для compute
#обязательный параметр
#тип - строка
driver = "KVM_X86"
#число cpu
#обязательный параметр
#тип - число
cpu = 1
#кол-во оперативной памяти, МБ
#обязательный параметр
#тип - число
ram = 2048
#id образа диска для создания compute
#обязательный параметр
#тип - число
image_id = 111
#размер загрузочного диска
#обязательный параметр
#тип - число
boot_disk_size = 20
#описание compute
#опциональный параметр
#тип - строка
description = "test update description in tf words update"
}
output "test" {
value = decort_kvmvm.comp
}

View File

@@ -0,0 +1,108 @@
/*
Пример использования
Ресурса load balancer
Ресурс позволяет:
1. Создавать load balancer
2. Редактировать load balancer
3. Удалять load balancer
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
resource "decort_lb" "lb" {
#id ресурсной группы для со
#обязательный параметр
#тип - число
rg_id = 1111
#наименование load balancer
#обязательный параметр
#тип - строка
name = "tf-test-lb"
#id внешней сети
#обязательный параметр
#тип - число
extnet_id = 6
#id виртуальной сети
#обязательный параметр
#тип - число
vins_id = 758
#флаг запуска load balancer
#обязательный параметр
#тип - булев тип
#по умолчанию - true
#если load balancer был в статусе "stopped" (start = false),
#то для успешного старта, он должен быть доступен (enable = true)
start = true
#описание
#опциональный параметр
#тип - строка
#desc = "temp super lb for testing tf provider"
#флаг доступности load balancer
#необязательный параметр
#тип - булев тип
#enable = true
#флаг перезапуска load balancer
#необязательный параметр
#тип - булев тип
#перезагрузка срабатывает только при изменении флага с false на true
#restart = false
#флаг сброса конфигурации load balancer
#необязательный параметр
#тип - булев тип
#сброс срабатывает только при изменении флага с false на true
#config_reset = false
#флаг моментального удаления load balancer
#необязательный параметр
#тип - булев тип
#по умолчанию - false
#применяется при выполнении команды terraform destroy
#permanently = false
#флаг восстановления load balancer
#необязательный параметр
#тип - булев тип
#восстановить можно load balancer, удаленным с флагом permanently = false
#restore = true
timeouts {
create = "5m"
read = "5m"
update = "5m"
delete = "5m"
}
}
output "test" {
value = decort_lb.lb
}

View File

@@ -0,0 +1,115 @@
/*
Пример использования
Ресурса load balancer backend
Ресурс позволяет:
1. Создавать backend
2. Редактировать backend
3. Удалять backend
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
resource "decort_lb_backend" "lb" {
#id балансировщика нагрузок
#обязательный параметр
#тип - число
lb_id = 668
#имя бекенда для создания сервера
#обязательный параметр
#тип - строка
name = "testBackend"
#алгоритм балансировки
#опицональный параметр
#тип - строка
#по умолчанию - "roundrobin"
#доступные значения - "roundrobin", "static-rr", "leastconn"
#algorithm = "roundrobin"
#-------------------
#настройки для серверов по умолчанию
#-------------------
#интервал между проверками, в миллисекундах
#опицональный параметр
#тип - число
#по умолчанию - 5000
#inter = 5000
#интервал между проверками доступности сервера после восстановления, в миллисекундах
#опицональный параметр
#тип - число
#по умолчанию - 1000
#downinter = 1000
#кол-во проверок, которые сервер должен успешно пройти
#опицональный параметр
#тип - число
#по умолчанию - 2
#rise = 2
#кол-во проверок, которые сервер может не пройти и после этого получить статус "unavailable"
#опицональный параметр
#тип - число
#по умолчанию - 2
#fall = 2
#кол-во миллисекунд - время между получением сервера статуса "available" и открытием соединений
#опицональный параметр
#тип - число
#по умолчанию - 60000
#slowstart = 60000
#максимальное кол-во соединений сервера, при достижении этого кол-ва, сервер выходит из схемы балансирования
#опицональный параметр
#тип - число
#по умолчанию - 250
#maxconn = 250
#максимальное кол-во соединений в очереди серевера, при достижении этого кол-ва, соединения будут перенаправлены на другой сервер
#опицональный параметр
#тип - число
#по умолчанию - 256
#maxqueue = 256
#вес сервера для балансировки
#опицональный параметр
#тип - число
#мин - 0
#макс - 255
#по умолчанию - 100
#weight = 100
timeouts {
create = "5m"
read = "5m"
update = "5m"
delete = "5m"
}
}
output "test" {
value = decort_lb_backend.lb
}

View File

@@ -0,0 +1,126 @@
/*
Пример использования
Ресурса load balancer backend server
Ресурс позволяет:
1. Создавать server
2. Редактировать server
3. Удалять server
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
resource "decort_lb_backend_server" "lb" {
#id балансировщика нагрузок
#обязательный параметр
#тип - число
lb_id = 668
#имя бекенда для создания сервера
#обязательный параметр
#тип - строка
backend_name = "testBackend"
#имя сервера
#обязательный параметр
#тип - строка
name = "testServer"
#ip адрес сервера
#обязательный параметр
#тип - строка
address = "192.168.5.33"
#порт сервера
#обязательный параметр
#тип - число
port = 6553
#проверка доступности сервера
#опицональный параметр
#тип - строка
#по умолчанию - "enabled"
#доступные значения - "disabled", "enabled"
#check = "enabled"
#интервал между проверками, в миллисекундах
#опицональный параметр
#тип - число
#по умолчанию - 5000
#inter = 5000
#интервал между проверками доступности сервера после восстановления, в миллисекундах
#опицональный параметр
#тип - число
#по умолчанию - 1000
#downinter = 1000
#кол-во проверок, которые сервер должен успешно пройти
#опицональный параметр
#тип - число
#по умолчанию - 2
#rise = 2
#кол-во проверок, которые сервер может не пройти и после этого получить статус "unavailable"
#опицональный параметр
#тип - число
#по умолчанию - 2
#fall = 2
#кол-во миллисекунд - время между получением сервера статуса "available" и открытием соединений
#опицональный параметр
#тип - число
#по умолчанию - 60000
#slowstart = 60000
#максимальное кол-во соединений сервера, при достижении этого кол-ва, сервер выходит из схемы балансирования
#опицональный параметр
#тип - число
#по умолчанию - 250
#maxconn = 250
#максимальное кол-во соединений в очереди серевера, при достижении этого кол-ва, соединения будут перенаправлены на другой сервер
#опицональный параметр
#тип - число
#по умолчанию - 256
#maxqueue = 256
#вес сервера для балансировки
#опицональный параметр
#тип - число
#мин - 0
#макс - 255
#по умолчанию - 100
#weight = 100
timeouts {
create = "5m"
read = "5m"
update = "5m"
delete = "5m"
}
}
output "test" {
value = decort_lb_backend_server.lb
}

View File

@@ -0,0 +1,58 @@
/*
Пример использования
Ресурса load balancer frontend
Ресурс позволяет:
1. Создавать frontend
2. Удалять frontend
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
resource "decort_lb_frontend" "lb" {
#id балансировщика нагрузок
#обязательный параметр
#тип - число
lb_id = 668
#имя бекенда для создания фронтенда
#обязательный параметр
#тип - строка
backend_name = "testBackend"
#имя фронтенда
#обязательный параметр
#тип - строка
name = "testFrontend"
timeouts {
create = "5m"
read = "5m"
update = "5m"
delete = "5m"
}
}
output "test" {
value = decort_lb_frontend.lb
}

View File

@@ -0,0 +1,69 @@
/*
Пример использования
Ресурса load balancer frontend bind (привязка фронтенда балансировщика нагрузок)
Ресурс позволяет:
1. Создавать привязку
2. Редактировать привязку
3. Удалять привязку
*/
#Расскомментируйте этот код,
#и внесите необходимые правки в версию и путь,
#чтобы работать с установленным вручную (не через hashicorp provider registry) провайдером
/*
terraform {
required_providers {
decort = {
version = "1.1"
source = "digitalenergy.online/decort/decort"
}
}
}
*/
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
resource "decort_lb_frontend_bind" "lb" {
#id балансировщика нагрузок
#обязательный параметр
#тип - число
lb_id = 668
#имя фронтенда для создания привязки
#обязательный параметр
#тип - строка
frontend_name = "testFrontend"
#наименование привязки
#обязательный параметр
#тип - строка
name = "testBinding"
#адрес привязки фронтенда
#обязательный параметр
#тип - строка
address = "111.111.111.111"
#порт для привязки фронтенда
#обязательный параметр
#тип - число
port = 1111
timeouts {
create = "5m"
read = "5m"
update = "5m"
delete = "5m"
}
}
output "test" {
value = decort_lb_frontend_bind.lb
}