

Auto Scaling 弹性伸缩(运维释放人力)
source link: https://blog.51cto.com/shoufu/5540562
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Auto Scaling 弹性伸缩(运维释放人力)
原创什么是 Auto Sacling?
弹性伸缩(Auto Scaling,以下简称AS)是根据用户的业务需求,通过设置伸缩规则来自动增加/缩减业务资源。当业务需求增长时,AS自动为您增加弹性云服务器(ECS)实例或带宽资源,以保证业务能力;当业务需求下降时,AS自动为您缩减弹性云服务器(ECS)实例或带宽资源,以节约成本。AS支持自动调整弹性云服务器和带宽资源。
Auto Sacling的优势?
自动调整资源
弹性伸缩能够实现应用系统自动按需调整资源,即在业务增长时能够实现自动增加实例数量和带宽大小,以满足业务需求,业务下降时能够实现应用系统自动缩容,保障业务平稳运行。
按需调整云服务器资源
向应用系统中添加弹性伸缩,能够实现按需调整资源,即能够实现在业务增长时增加实例,业务下降时减少实例,这样加强了应用系统的成本管理。调整资源主要包括以下几种方式:
动态调整资源
动态调整资源是通过告警策略的触发来调整资源。
计划调整资源
计划调整资源是通过定时策略或周期策略的触发来调整资源。
手工调整资源
通过修改期望实例数或手动移入、移出实例来调整资源。
按需调整带宽资源
弹性伸缩能够实现按需调整带宽,即能够实现在业务增长时扩大带宽,业务下降时减小带宽,加强了应用系统的成本管理。
您可以根据实际情况选择如下伸缩带宽策略来实现按需调整IP带宽:
可设置出网流量、出网带宽等告警触发条件,系统检测到触发条件满足时,会自动调整带宽的大小。
系统可根据定时策略在固定的时间自动将带宽增大、减小或者调整到固定的值。
系统可根据周期策略周期性的调整带宽大小,减少了人工重复设置带宽的工作量。
实例分配在不同区
弹性伸缩尝试在为伸缩组使用的可用区之间均匀分配实例。弹性伸缩通过尝试向实例最少的可用区中移入新实例来实现此目标。
加强成本管理
弹性伸缩能够实现按需使用实例和带宽,并自动调整系统中的资源,节省了资源和人为调整资源带来的损耗,为您最大程度节约了成本。
提高可用性
弹性伸缩可确保应用系统始终拥有合适的容量以满足当前流量需求。
弹性伸缩和负载均衡结合使用
当您在使用弹性伸缩时,业务增长时应用系统自动扩容,业务下降时应用系统自动缩容,在伸缩组添加和删除实例时,须确保所有实例均可分配到应用程序的流量。弹性伸缩和负载均衡结合使用可以解决这个问题。
使用负载均衡后,伸缩组会自动地将加入伸缩组的实例绑定负载均衡监听器。访问流量将通过负载均衡监听器自动分发到伸缩组内的所有实例,提高了应用系统的可用性。若伸缩组中的实例上部署了多个业务,还可以添加多个负载均衡监听器到伸缩组,同时监听多个业务,从而提高业务的可扩展性。
提高容错能力
弹性伸缩可以检测到应用系统中实例的运行状况,并启用新实例以替换运行状况不佳的实例。
云厂商提供的文档地址
ali Cloud: https://help.aliyun.com/product/25855.html
Hw Cloud: https://support.huaweicloud.com/intl/zh-cn/as/index.html
我们这里以华为云为例
1,创建ECS,并制作镜像
创建一个新的ECS(建议只有系统盘);在上面部署我们需要的服务;需要注意:我们要做好服务开机自启动,确保创建完机器之后服务能自己启动;
服务安装好之后,直接基于当前的ECS 创建镜像;
2,创建ELB(弹性负载均衡)
“ELB” --> “创建ELB”
按照ECS所在地区购买ELB服务,购买完成之后创建“监听器”(ELB监听的端口),然后创建后端服务器组:在后端服务组里面我们可以选择轮训的算法,并且添加后端接口的健康检查(只有健康检查通过了之后ELB才会真正的将流量切换过去);
3,创建弹性伸缩
创建弹性伸缩配置
弹性伸缩AS --> 创建伸缩配置


这个地方就没什么好解释的了。
创建弹性伸缩组

当我们完成上面这几部的时候,弹性伸缩相关的配置我们就完成了。但是还没有办法自动的进行弹性扩容

我们可以手动扩容一个看一下是否正常:

将期望副本数改为1就行;
然后我们就可以请求ELB地址来请求后端服务来,如果需要自动伸缩,那我们就需要配置一下伸缩策略。

1,升级ECS实例里面的服务版本,然后创建镜像
2,创建新的伸缩配置
到弹性伸缩里面创建新的弹性伸缩配置,选择新的镜像版本
3,更改弹性伸缩组
更改弹性伸缩组里面弹性配置,选择新的弹性配置即可。
- 打赏
- 赞
- 收藏
- 评论
- 分享
- 举报
Recommend
-
94
今年一直在做的事情就是成本优化,今天分享的是如何打造一个弹性可伸缩服务。 why? 为什么需要弹性伸缩? 一个网站,通常流量大小不是每时每刻都一样,有高峰,有低谷,如果每时每刻都要保持能够扛住高峰流量的机器数...
-
40
5 月 30 日, 字节跳动技术沙龙 | 基础架构专场 进行了在线直播。我们邀请到了字节跳动基础架构团队资深研发工程师邵伟...
-
26
Rainbond 5.1.9发布,新增实例弹性伸缩、OAuth代码仓库互联功能 16 December 2019Rainbond 5.1.9发布,新增实例弹性伸缩、OAuth代码仓库互联功能 Rainbond 5.1.9发布,新增实例弹性伸缩、OAuth代码仓库互联功能
-
12
文章中使用的是keda 1.5版本,2.0还未release 1.5版本支持deployment,job两种资源。而在2.0增加了StatefulSet以及自定义资源 keda 是一个支持多种事件源来对应用进行弹性伸缩的控制器。 我...
-
17
美团弹性伸缩系统的技术演进与落地实践2021年04月01日 作者: tuyang 文章...
-
6
详细介绍CSS3弹性伸缩box布局爱前端不爱恋爱关注微信公众号:web前端学习圈,领取85G前端全套系统教程...
-
5
Fluid 给数据弹性一双隐形的翅膀 仅限深圳|现场揭秘:腾讯云原生数据库架构探索与实践 >>
-
6
Kubernetes自带的HPA是只支持CPU/MEM的,很多时候我们并不根据这两项指标来进行伸缩资源。比如消费者不断处理MQ的消息,我们希望MQ如果堆积过多,就启动更多的消费者来处理任务。而Keda给了我们很多选择。 KEDA...
-
9
联合作者 | Yan Xun,阿里云 EDAS 团队高级工程师 Andy Shi,阿里云开发者倡导者 Tom Kerkhove,Codit 容器化业务负责人兼 Azure 架构师、KEDA 维护者、CNCF 大使 来源 |
-
13
kubernetes pod的弹性伸缩(三)(基于事件驱动伸缩) 软件 版本 keda 2.3.0 Kubernetes 1.20.7 目前在Kubernetes中做POD弹性伸缩...
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK