Add example for PostgreSQL Flexible Server Database
This commit is contained in:
100
quickstart/201-postgresql-fs-db/main.tf
Normal file
100
quickstart/201-postgresql-fs-db/main.tf
Normal file
@ -0,0 +1,100 @@
|
||||
terraform {
|
||||
required_version = ">=1.0"
|
||||
|
||||
required_providers {
|
||||
azurerm = {
|
||||
source = "hashicorp/azurerm"
|
||||
version = "=2.95.0"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
provider "azurerm" {
|
||||
features {}
|
||||
}
|
||||
|
||||
resource "azurerm_resource_group" "default" {
|
||||
name = "${var.name}-${var.environment}-rg"
|
||||
location = var.location
|
||||
}
|
||||
|
||||
resource "azurerm_virtual_network" "default" {
|
||||
name = "${var.name}-${var.environment}-vnet"
|
||||
location = azurerm_resource_group.default.location
|
||||
resource_group_name = azurerm_resource_group.default.name
|
||||
address_space = ["10.0.0.0/16"]
|
||||
}
|
||||
|
||||
resource "azurerm_network_security_group" "default" {
|
||||
name = "${var.name}-${var.environment}-nsg"
|
||||
location = azurerm_resource_group.default.location
|
||||
resource_group_name = azurerm_resource_group.default.name
|
||||
|
||||
security_rule {
|
||||
name = "test123"
|
||||
priority = 100
|
||||
direction = "Inbound"
|
||||
access = "Allow"
|
||||
protocol = "Tcp"
|
||||
source_port_range = "*"
|
||||
destination_port_range = "*"
|
||||
source_address_prefix = "*"
|
||||
destination_address_prefix = "*"
|
||||
}
|
||||
}
|
||||
|
||||
resource "azurerm_subnet" "default" {
|
||||
name = "${var.name}-${var.environment}-subnet"
|
||||
virtual_network_name = azurerm_virtual_network.default.name
|
||||
resource_group_name = azurerm_resource_group.default.name
|
||||
address_prefixes = ["10.0.2.0/24"]
|
||||
service_endpoints = ["Microsoft.Storage"]
|
||||
|
||||
delegation {
|
||||
name = "fs"
|
||||
|
||||
service_delegation {
|
||||
name = "Microsoft.DBforPostgreSQL/flexibleServers"
|
||||
|
||||
actions = [
|
||||
"Microsoft.Network/virtualNetworks/subnets/join/action",
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
resource "azurerm_subnet_network_security_group_association" "default" {
|
||||
subnet_id = azurerm_subnet.default.id
|
||||
network_security_group_id = azurerm_network_security_group.default.id
|
||||
}
|
||||
|
||||
resource "azurerm_private_dns_zone" "default" {
|
||||
name = "${var.name}-${var.environment}-pdz.postgres.database.azure.com"
|
||||
resource_group_name = azurerm_resource_group.default.name
|
||||
|
||||
depends_on = [azurerm_subnet_network_security_group_association.default]
|
||||
}
|
||||
|
||||
resource "azurerm_private_dns_zone_virtual_network_link" "default" {
|
||||
name = "${var.name}-${var.environment}-pdzvnetlink.com"
|
||||
private_dns_zone_name = azurerm_private_dns_zone.default.name
|
||||
virtual_network_id = azurerm_virtual_network.default.id
|
||||
resource_group_name = azurerm_resource_group.default.name
|
||||
}
|
||||
|
||||
resource "azurerm_postgresql_flexible_server" "default" {
|
||||
name = "${var.name}-${var.environment}-server"
|
||||
resource_group_name = azurerm_resource_group.default.name
|
||||
location = azurerm_resource_group.default.location
|
||||
version = "13"
|
||||
delegated_subnet_id = azurerm_subnet.default.id
|
||||
private_dns_zone_id = azurerm_private_dns_zone.default.id
|
||||
administrator_login = "adminTerraform"
|
||||
administrator_password = "QAZwsx123"
|
||||
zone = "1"
|
||||
storage_mb = 32768
|
||||
sku_name = "GP_Standard_D2s_v3"
|
||||
backup_retention_days = 7
|
||||
|
||||
depends_on = [azurerm_private_dns_zone_virtual_network_link.default]
|
||||
}
|
Reference in New Issue
Block a user