gpt4 book ai didi

postgresql - 如何从 terraform 中 Azure 托管 PostgreSQL 的现有备份文件恢复数据库?

转载 作者:行者123 更新时间:2023-12-03 02:05:49 30 4
gpt4 key购买 nike

我正在使用 terraform 在 azure PG 灵活服务器数据库中自动部署。但是,对于托管 PostgreSQL,没有从备份文件创建数据库的选项。

resource "azurerm_postgresql_flexible_server_database" "db" {
depends_on = [azurerm_sql_firewall_rule.allowAzureServices]
name = var.db_name
server_id = azurerm_postgresql_flexible_server.postgreSQL.id
collation = "en_US.UTF8"
charset = "UTF8"

}

对于 azure terraform 中的 SQL DB 具有如下所述的支持:azure sql db有https://www.terraform.io/docs/providers/azurerm/r/sql_database.html与“create_mode”=“恢复”

但我没有找到 PostgreSql 的任何选项 https://registry.terraform.io/providers/hashicorp/azurerm/3.37.0/docs/resources/postgresql_flexible_server_database

如何使用terraform恢复备份文件来实现数据库的创建?

最佳答案

这里是PostgreSQL灵活服务器的备份和恢复实现,这里是code样本。

最初我们需要为 PostgreSQL 灵活服务器创建备份恢复,它与普通 PostgreSQL 服务器有些不同。

主tf文件如下

resource "azurerm_resource_group" "default" {
name = "*********"
location = "West Europe"
}

resource "azurerm_virtual_network" "default" {
name = "demo-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 = "demo-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 = "demo-subnets"
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 = "demo-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 = "demo-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 = "demonew-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 = "********"
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]
}

resource "azurerm_postgresql_flexible_server_database" "default" {
name = "demo-db"
server_id = azurerm_postgresql_flexible_server.default.id
collation = "en_US.UTF8"
charset = "UTF8"
}

提供者文件如下:

terraform {

required_version = "~>1.3.3"
required_providers {
azurerm = {
source = "hashicorp/azurerm"
version = ">=3.5.0"
}
}
}

provider "azurerm" {
features {}
skip_provider_registration = true
}

根据计划和申请,这里是输出

enter image description here

来自门户的验证:

enter image description here

数据库验证 enter image description here

备份和恢复配置

enter image description here

关于postgresql - 如何从 terraform 中 Azure 托管 PostgreSQL 的现有备份文件恢复数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74884451/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com