Terraform:将 Elasticache 复制组从 2 个缓存节点更新为 1 个时出错

问题描述

目前我们有 2 个 redis 缓存节点。我们正在尝试使用 terraform apply 将其减少到 1。将值更改为 1 并执行 terraform 时,请申请以下示例代码

resource "aws_elasticache_replication_group" "node-1" {
  automatic_failover_enabled    = true
  availability_zones            = ["eu-central-1a","eu-central-1b"]
  replication_group_id          = "tf-rep-group-1"
  replication_group_description = "test description"
  node_type                     = "cache.t3.micro"
  number_cache_clusters         = 2
  parameter_group_name          = "default.redis5.0"
  port                          = 6379
}

我们收到以下错误

Error: error updating Elasticache Replication Group (replicationgrp): InvalidParameterValue: Cannot disable Automatic Failover for Multi-AZ enabled Replication Group. To disable Automatic Failover,please disable Multi-AZ and Automatic Failover.

在尝试更改和 automatic_failover_enabled = 'false' 运行 apply 后,它仍然抛出相同的错误

automatic_failover_enabled = 'false'

没有可用的 multi_az,文档似乎说 automatic_failover_enabled 确实意味着 MultiAZ:https://www.terraform.io/docs/providers/aws/r/elasticache_replication_group.html#automatic_failover_enabled

automatic_failover_enabled -(可选)指定是否为只读 副本将自动提升为读/写主,如果 现有的主要失败。如果为 true,则为此启用多可用区 复制组。如果为 false,则为此复制禁用多可用区 团体。必须为 Redis(已启用集群模式)复制启用 组。认为 false。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...