terraform中的appAutoScaling属性和autoscaling属性之间有什么区别?

如何解决terraform中的appAutoScaling属性和autoscaling属性之间有什么区别?

我正在尝试使用terraform扩展Aurora的RDS集群。

我正在设置一个具有3个服务器的RDS实例-1个写入器和2个只读副本。这是我的要求

  • 当任何服务器出现故障时,请添加新服务器,以使副本始终至少具有3台服务器。

  • 当任何主机的CPU使用率超过50%时,请向群集添加新服务器。服务器的最大数量为4。

  1. 是否可以创建一个策略,以便当3个服务器中的任何一个发生故障时,然后为该RDS实例创建一个新服务器?是,如何监控服务器故障?

  2. 我需要使用appAutoScaling还是同时使用autoScaling? 这是与我的用例匹配的链接: https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/appautoscaling_policy

解决方法

我针对您的问题开发了 terraform配置文件的示例。它已准备就绪,可以使用,但仅出于学习和测试目的而应作为示例。已在us-east-1区域中使用带有terraform 0.13的默认VPC和AWS提供程序3.6对它进行了测试。

示例terraform配置文件创建的关键资源是:

  • 公共MySQL aurora集群1个编写器和2个副本。
  • 基于CPU利用率(50%)的Aurora副本的应用程序自动缩放策略,最小和最大容量分别为2和4。
  • SNS主题和SQS队列已订阅该主题。使用队列,可以轻松查看SNS消息,而无需配置电子邮件或lambda。
  • 两个RDS事件订阅。一次(例如失败)用于集群级事件,第二次用于实例级事件。在这两种情况下,事件都将发布到SNS主题,然后在SQS中可供查看。

下面,我将详细介绍所问的问题和示例配置文件。

具有1个编写器和2个副本的Aurora MySQL群集

该群集将配备1个编写器和2个副本。

副本的自动缩放策略

一个基于TargetTrackingScaling的{​​{1}}的{​​{3}}。扩展策略基于副本的总体CPU利用率(50%),而不是其单个副本。

这是一个好习惯,因为aurora副本在连接级别自动负载均衡。这意味着在您使用application-auto-scaling的情况下,新连接将大致平均地分布在可用副本之间。

一旦副本被扩展/扩展活动或故障替换,您可能应用于单个副本的任何警报或扩展策略都将无效。这是因为任何扩展策略都将绑定到特定的数据库实例。实例消失后,警报将不起作用。

可以在CLoudWatch警报控制台中查看与AWS代表您创建的策略相关的警报。

Aurora数据库实例失败

如果任何数据库实例失败,Aurora将自动继续解决该问题,其中包括重新启动数据库实例,将只读副本升级为新的主副本,重新串连MySQL或完全替换发生故障的实例

您可以自己{strong>模拟这些事件,如reader enpoint中所述。

测试故障转移以读取副本

RDSReaderAverageCPUUtilization

主实例的测试崩溃

这将导致实例的自动重启

aws rds failover-db-cluster --db-cluster-identifier aurora-cluster-demo

读取器实例的测试崩溃

这将导致重新启动MySQL。

mysql -h <endpoint> -u root -e "ALTER SYSTEM CRASH INSTANCE;"

测试阅读器的更换

您可以通过手动将其删除来模拟读取器实例的完全故障 控制台。删除后,Aurora将自动提供替换

监控群集故障

您可以使用Testing Amazon Aurora Using Fault Injection Queries 自动检测和响应与您的Aurora群集及其实例相关的各种事件。失败是RDS事件通知机制捕获的事件之一。

您可以订阅感兴趣的事件类别,并接收SNS的通知。一旦检测到事件并将其发布到SNS中,您就可以使用它进行所需的操作。例如,调用lambda事件以分析该事件和Aurora群集的当前状态,执行纠正措施或发送电子邮件通知。

例如,当您像之前那样手动强制故障转移时,您会收到一条消息 具有以下信息(仅显示片段):

mysql -h <endpoint> -u root -e "ALTER SYSTEM SIMULATE 100 PERCENT READ REPLICA FAILURE TO ALL FOR INTERVAL 10 MINUTE;"

及更高版本:

\"Event Message\":\"Started cross AZ failover to DB instance: aurora-cluster-demo-1\"

示例Terraform配置文件订阅了许多类别。因此,您必须将它们精确地调整到所需的位置。您还可以订阅所有这些文件,并具有 lambda函数,在它们发生时进行分析,并决定是否仅将其归档,或者该函数应执行一些自动化过程。

AppAutoScaling或AutoScaling

Aurora读取副本是使用Amazon RDS Event Notification而不是AutoScaling缩放的(在这里我假设您是指EC2 AutoScaling)。 EC2 AutoScaling仅用于常规EC2实例,而不用于RDS。

示例地形配置文件

\"Event Message\":\"Completed failover to DB instance: aurora-cluster-demo-1\"}"

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-