InvalidParameterCombination: группу параметров невозможно указать во время создания реплики чтения

Я пытаюсь создать 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 для реплики чтения в другом регионе?

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
131
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Ответ - нет.

При создании реплики чтения в AWS RDS не следует указывать группу параметров независимо от ее местоположения. Реплика чтения наследует группу параметров от основного экземпляра, чтобы обеспечить согласованность процесса репликации, поскольку это важно для бесперебойной работы.

Что касается экземпляров AWS Primary и Replica RDS:

Группы параметров: они настраивают параметры ядра базы данных, которые применяются к одному или нескольким экземплярам RDS. Поскольку реплика чтения должна оставаться согласованной с основным экземпляром, она наследует группу параметров основного экземпляра. Такое наследование гарантирует, что параметры одинаковы для обоих экземпляров, что облегчает правильную репликацию.

Группы опций: они включают дополнительные функции для ваших экземпляров RDS, такие как MySQL, аудит SQL Server или Oracle Enterprise Manager. У вас могут быть разные группы параметров для первичной реплики и реплики чтения, поскольку эти функции могут зависеть от роли экземпляра (основной или реплики) и не влиять напрямую на процесс репликации. PostgreSQL не использует группы опций. Вместо этого PostgreSQL полагается на расширения для предоставления дополнительных функций.

Расширения. Для PostgreSQL расширения добавляют дополнительные функции в ядро ​​базы данных. И основной экземпляр, и реплика должны иметь одни и те же расширения, чтобы обеспечить согласованность и правильную функциональность. Эти расширения управляются в базе данных и должны быть согласованными между первичными экземплярами и репликами.

Вкратце, для ваших основных экземпляров RDS и реплик:

  • Группы параметров должны быть согласованными между основной и репликой, чтобы обеспечить правильную репликацию.
  • Группы параметров неприменимы к PostgreSQL. Вместо этого управляйте расширениями, чтобы обеспечить их согласованность между основным и репликой, чтобы поддерживать функциональность и совместимость.

Ниже представлена ​​измененная версия терраформирования:

# 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
}

Другие вопросы по теме