Я пытаюсь создать DR-реплику чтения в другом регионе на основе этого ресурса в Terraform:
# Define the read replica
resource "aws_db_instance" "read_replica" {
identifier = "my-read-replica"
engine = data.aws_db_instance.existing.engine
instance_class = "db.t3.medium"
publicly_accessible = true
db_subnet_group_name = data.aws_db_instance.existing.db_subnet_group
availability_zone = data.aws_db_instance.existing.availability_zone
db_parameter_group_name = aws_db_parameter_group.custom.name
multi_az = false
storage_type = "gp2"
replicate_source_db = data.aws_db_instance.existing.identifier
}
У меня есть следующее db_paramater_group_name
:
resource "aws_db_parameter_group" "custom" {
name = var.custom_parameter_group
family = "postgres12" # Replace with the appropriate family for your PostgreSQL version
description = "Custom parameter group for PostgreSQL RDS instance"
parameter {
name = "max_connections"
value = "200"
}
parameter {
name = "log_statement"
value = "all"
}
}
Однако, когда я terraform apply
, я получаю эту ошибку:
│ Ошибка: создание экземпляра базы данных RDS (реплика чтения) (my-read-replica): InvalidParameterCombination: невозможно указать группу параметров во время создания реплики чтения для следующего механизма БД: postgres
Можно ли не указывать db_parameter_group_name
для реплики чтения в другом регионе?
Ответ - нет.
При создании реплики чтения в AWS RDS не следует указывать группу параметров независимо от ее местоположения. Реплика чтения наследует группу параметров от основного экземпляра, чтобы обеспечить согласованность процесса репликации, поскольку это важно для бесперебойной работы.
Что касается экземпляров AWS Primary и Replica RDS:
Группы параметров: они настраивают параметры ядра базы данных, которые применяются к одному или нескольким экземплярам RDS. Поскольку реплика чтения должна оставаться согласованной с основным экземпляром, она наследует группу параметров основного экземпляра. Такое наследование гарантирует, что параметры одинаковы для обоих экземпляров, что облегчает правильную репликацию.
Группы опций: они включают дополнительные функции для ваших экземпляров RDS, такие как MySQL, аудит SQL Server или Oracle Enterprise Manager. У вас могут быть разные группы параметров для первичной реплики и реплики чтения, поскольку эти функции могут зависеть от роли экземпляра (основной или реплики) и не влиять напрямую на процесс репликации. PostgreSQL не использует группы опций. Вместо этого PostgreSQL полагается на расширения для предоставления дополнительных функций.
Расширения. Для PostgreSQL расширения добавляют дополнительные функции в ядро базы данных. И основной экземпляр, и реплика должны иметь одни и те же расширения, чтобы обеспечить согласованность и правильную функциональность. Эти расширения управляются в базе данных и должны быть согласованными между первичными экземплярами и репликами.
Вкратце, для ваших основных экземпляров RDS и реплик:
Ниже представлена измененная версия терраформирования:
# Define the read replica
resource "aws_db_instance" "read_replica" {
identifier = "my-read-replica"
engine = data.aws_db_instance.existing.engine
instance_class = "db.t3.medium"
publicly_accessible = true
db_subnet_group_name = data.aws_db_instance.existing.db_subnet_group
availability_zone = data.aws_db_instance.existing.availability_zone
multi_az = false
storage_type = "gp2"
replicate_source_db = data.aws_db_instance.existing.identifier
}