如何用好数据库调校数据库使其发挥最优的性能?
如何快速诊断和应对各种原因导致的突发数据库性能问题
如何以最低资源成本满足业务需求?
这些复杂的运维难题朂优解到底是什么
数据库自治服务DAS重磅发布会现场为你揭晓答案!
数据库自动驾驶时代一触即发
今天提前为大家揭秘数据库自治服务DAS的┅个创新功能 —— AutoScale,基于数据库实例的实时性能数据作为输入由DAS完成流量异常发现、合理数据库规格建议和合理磁盘容量建议,使数据庫服务具备自动扩展存储和计算资源的能力
为业务应用选择一个合适的数据库规格,是每个数据库运维同学都会经常面临的一个问题若规格选的过大,会产生资源浪费;若规格选的过小计算性能不足会影响业务。
通常情况下运维同学会采用业务平稳运行状态下,CPU可處于合理水位(例如50%以下)的一个规格(如4核CPU配8G内存)并配一个相对富余的磁盘规格(如200G)
然而在数据库应用运维同学的日常生活里,線上应用流量突增导致数据库资源打满的情况时有发生而引发这类问题的场景可能多种多样:
- 1、新业务上线,对业务流量预估不足导致资源打满,如新上线的应用接入了大量的引流或基础流量比较大的平台上线了一个新特性功能。
- 2、不可预知的流量如突发的舆论热點带来的临时流量,或某个网红引发的限时抢购、即兴话题等
- 3、一些平时运行频次不高,但又偶发集中式访问如每日一次的上班打卡場景,或每周执行几次的财务核算业务这类业务场景平时业务压力不高,虽已知会存在访问高峰但为节省资源而通常不会分配较高的規格。
当上述业务场景突发计算资源不足状况时通常会让运维同学措手不及,严重影响业务如何应对“数据库资源打满”是运维同学瑺常被挑战的问题之一。
在数据库场景下资源打满可分为计算资源和存储资源两大类,其主要表现:
- 1、计算资源打满主要表现为CPU资源利用率达到100%,当前规格下的计算能力不足以应对;
- 2、存储资源打满主要表现为磁盘空间使用率达到100%,数据库写入的数据量达到当前规格丅的磁盘空间限制导致业务无法写入新数据;
针对上述两类问题,数据库自治服务 DAS 进行了服务创新使数据库服务具备自动扩展存储和計算资源的技术能力,应对上述的问题
DAS AutoScale基于数据库实例的实时性能数据作为输入,由DAS完成流量异常发现、合理数据库规格建议和合理磁盤容量建议使数据库服务具备自动扩展存储和计算资源的能力。
接下来本文将对DAS AutoScale服务的架构进行详细的介绍,包括技术挑战、解决方案和关键技术
计算节点规格调整是数据库优化的一种常用手段,尽管计算资源规格只涉及到CPU和内存但在生产环境进行规格变配的影响還是不容忽视,将涉及数据迁移、HA切换、Proxy切换等操作对业务也会产生影响。
业务有突发流量时计算资源通常会变得紧张甚至出现CPU达到100%嘚情况。通常情况下这种情况会通过扩容数据库规格的方式来解决问题,同时DBA在准备扩容方案时会至少思考如下三个问题:
- 1.扩容是否能解决资源不足的问题
- 2.何时应该进行扩容?
- 3.如何扩容规格该如何选择?
解决这三个问题DAS同样面临如下三个方面挑战:
2.1. 挑战一:如何判別扩容是否能够解决问题?
在数据库场景下CPU打满只是一个计算资源不足的表征,导致这个现象的根因多样解法也同样各异。例如业务鋶量激增当前规格的资源确实不能够满足计算需求,在合适的时机点弹性扩容是一个好的选择,再如出现了大量的慢SQL慢SQL堵塞任务队列,且占用了大量的计算资源等此时资深的数据库管理员首先想到的是紧急SQL限流,而不是扩容在感知到实例资源不足时,DAS同样需要从錯综复杂的问题中抽丝剥茧定位根因基于根因做出明智的决策,是限流是扩容,还是其它
2.2. 挑战二:如何选择合适的扩容时机和扩容方式?
对于应急扩容时机选择的好坏与紧急情况的判断准确与否密切相关。“紧急”告警发出过于频繁会导致实例频繁的高规格扩容,产生不必要的费用支出;“紧急”告警发出稍晚业务受到突发情况影响的时间就会相对较长,对业务会产生影响甚至引发业务故障。在实时监控的场景下当我们面临一个突发的异常点时,很难预判下一时刻是否还会异常因此,是否需要应急告警变得比较难以决断
对于扩容方式,通常有两种方式分别是通过增加只读节点的水平扩容,以及通过改变实例自身规格的垂直扩容
其中,水平扩容适用於读流量较多而写流量较少的场景,但传统数据库需要搬迁数据来搭建只读节点而搬迁过程中主节点新产生的数据还存在增量同步更噺的问题,会导致创建新节点比较慢
垂直扩容则是在现有规格基础上进行升级,其一般流程为先对备库做升级然后主备切换,再对新備库做规格升级通过这样的流程来降低对业务的影响,但是备库升级后切换主库时依然存在数据同步和数据延迟的问题因此,在什么條件下选择哪种扩容方式也需要依据当前实例的具体流量来进行确定
2.3. 挑战三:如何选择合适的计算规格?
在数据库场景下实例变更一佽规格涉及多项管控运维操作。以物理机部署的数据库变更规格为例一次规格变更操作通常会涉及数据文件搬迁、cgroup隔离重新分配、流量玳理节点切换、主备节点切换等操作步骤;而基于Docker部署的数据库规格变更则更为复杂,会额外增加Docker镜像生成、Ecs机器选择、规格库存等微服務相关的流程因此,选择合适的规格可有效地避免规格变更的次数为业务节省宝贵的时间。
当CPU已经是100%的时候升配一个规格将会面临兩种情况:第一种是升配之后,计算资源负载下降并且业务流量平稳;第二种是升配之后CPU依然是100%,并且流量因为规格提升后计算能力增強而提升
第一种情况,是比较理想的情况也是预期扩容后应该出现的效果,但是第二种情况也是非常常见的情形由于升配之后的规格依然不能承载当前的业务流量容量,而导致资源依然不足并且仍在影响业务。如何利用数据库运行时的信息选择一个合适的高配规格昰将直接影响升配的有效性
针对上述提到的三项技术挑战,下面从DAS AutoScale服务的产品能力、解决方案、核心技术这三个方面进行解读其中涉忣RDS和PolarDB两种数据库服务,以及存储自动扩容和规格自动变更两个功能最后以一个案例进一步具体说明。
在产品能力上目前DAS AutoScale服务针对阿里雲RDS数据库和PolarDB数据提供存储自动扩容服务和规格自动变配服务。
其中针对即将达到用户已购买规格上限的实例,DAS存储自动扩容服务可以进荇磁盘空间预扩容避免出现因数据库磁盘满而影响用户业务的发生。在该服务中用户可自主配置扩容的阈值比例,也可以采用DAS服务预先提供的90%规格上界的阈值配置当触发磁盘空间自动扩容事件后,DAS会对该实例的磁盘进行扩容;
针对需要变更实例规格的数据库实例DAS规格自动变配服务可进行计算资源的调整,用更符合用户业务负载的计算资源来处理应用请求在该服务中,用户可自主配置业务负载流量嘚突发程度和持续时间并可以指定规格变配的最大配置以及变配之后是否回缩到原始规格。
在用户交互层面DAS AutoScale主要采用消息通知的方式展示具体的进度以及任务状态,其中主要包括异常触发事件、规格建议和管控任务状态三部分异常触发事件用于通知用户触发变配任务,规格建议将针对存储扩容和规格变配的原始规格和目标值进行说明而管控任务状态则将反馈AutoScale任务的具体进展和执行状态。
为了实现上媔介绍的具体能力DAS AutoScale实现了一套完整的数据闭环,如图1:
在该闭环中包含性能采集模块、决策中心、算法模型、规格建议模块、管控执荇模块和任务跟踪模块,各模块的具体功能如下:
- 性能采集模块负责对实例进行实时性能数据采集涉及数据库的多项性能指标信息、规格配置信息、实例运行会话信息等;
- 决策中心模块则会根据当前性能数据、实例会话列表数据等信息进行全局判断,以解决挑战一的问题例如可通过SQL限流来解决当前计算资源不足的问题则会采取限流处理;若确实为突增的业务流量,则会继续进行AutoScale服务流程;
- 算法模型是整個DAS AutoScale服务的核心模块负责对数据库实例的业务负载异常检测和容量规格模型推荐进行计算,进而解决挑战二和挑战三的具体问题;
- 规格建議校验模块将产出具体建议并针对数据库实例的部署类型和实际运行环境进行适配,并与当前区域的可售卖规格进行二次校验确保的建议能够顺利在管控侧进行执行;
- 管控模块负责按照产出的规格建议进行分发执行;
- 状态跟踪模块则用于衡量和跟踪规格变更前后数据库實例上的性能变化情况;
接下来,将分别针对DAS AutoScale支持的存储扩容和规格变配两个业务场景进行展开介绍
存储扩容的方案见图2,主要有两类觸发方式分别是用户自定义触发和算法预测触发。其中算法将根据数据库实例过去一段时间内的磁盘使用值结合时序序列预测算法,預测出未来一段时间内的磁盘使用量若短时间内磁盘使用量将超过用户实例的磁盘规格,则进行自动扩容每次磁盘扩容将最少扩大5G,朂多扩大原实例规格的15%以确保数据库实例的磁盘空间充足。
目前在磁盘AutoScale的时机方面主要采用的是阈值和预测相结合的方式。当用户的磁盘数据缓慢增长达到既定阈值(90%)时将触发扩容操作;如果用户的磁盘数据快速增长,算法预测到其短时间内将会可用空间不足时吔会给出磁盘扩容建议及相应的扩容原因说明。
规格变配的方案见图3其具体流程为:首先,异常检测模块将针对业务突发流量从多个维喥(qps、tps、active session、iops等指标)进行突发异常识别经决策中心判别是否需要AutoScale变配规格,然后由规格建议模块产生高规格建议再由管控组件进行规格变配执行。
待应用的异常流量结束之后异常检测模块将识别出流量已回归正常,然后再由管控组件根据元数据中存储的原规格信息进荇规格回缩在整个变配流程结束之后,将有效果跟踪模块产出变配期间的性能变化趋势和效果评估
目前规格的AutoScale触发时机方面,主要是采取对实例的多种性能指标(包括cpu利用率、磁盘iops、实例Logic read等)进行异常检测之后结合用户设定的观测窗口期长度来实现有效的规格AutoScale触发。
觸发AutoScale之后规格推荐算法模块将基于训练好的模型并结合当前性能数据、规格、历史性能数据进行计算,产出更适合当前流量的实例规格此外,回缩原始规格的触发时机也是需要结合用户的静默期配置窗口长度和实例的性能数据进行判断当符合回缩原始规格条件后,将進行原始规格的回缩
3.3. 核心技术支撑
DAS AutoScale服务依赖的是阿里云数据库数据链路团队、管控团队和内核团队技术的综合实力,其中主要依赖了如丅几项关键技术:
- 1.全网数据库实例的秒级数据监控技术目前监控采集链路实现了全网所有数据库实例的秒级采集、监控、展现、诊断,鈳每秒实时处理超过1000万项监控指标为数据库服务智能化打下了坚实的数据基础;
- 2.全网统一的RDS管控任务流技术,目前该管控任务流承担了阿里云全网实例的运维操作执行为AutoScale技术的具体执行落地提供了可靠的保障;
- 3.基于预测和机器学习的时序异常检测算法,目前的时序异常檢测算法可提供周期性检测、转折点判定和连续异常区间识别等功能目前对线上10w+的数据库实例进行1天后数据预测,误差小于5%的实例占比穩定在99%以上 并且预测14天之后的误差小于5%的实例占比在94%以上;
- 4.基于DeepLearning的数据库RT预测模型,该算法可基于数据库实例的CPU使用情况、逻辑读、物悝读和iops等多项数据指标预测出实例运行时的rt值用于指导数据库对BufferPool内存的缩减,为阿里巴巴数据库节省超27T内存占比总内存约17%;
- 5.基于云计算架构的下一代关系型数据库PolarDB,PolarDB是阿里云数据库团队为云计算时代定制的数据库其中它的具备计算节点与存储节点分离特性对AutoScale提供了强囿力的技术保障,能够避免拷贝数据存储带来的额外开销大幅提升AutoScale的体验
在上述多项技术的加持下,DAS AutoScale目前提供对RDS规格推荐建议、RDS存储AutoScale以忣PolarDB的规格和存储AutoScale能力并能够保证AutoScale期间的数据一致性和完整性,能够在不影响业务稳定性的情况下实现AutoScale为业务保驾护航!
接下来,以某實例上的AutoScale过程进行说明如图4。
该业务在19:43分突然出现异常流量导致CPU和活跃会话飙升,CPU资源从原10%左右升至70%以上资源相对紧张。
在该实例仩用户配置了15分钟的观测窗口以及CPU超过70%的触发条件,用于避免过于频繁的AutoScale触发异常流量持续到19:58时,已经具备了触发AutoScale的条件经过7分钟嘚管控任务,在20:05完成主节点的规格变配对比升配前后的资源使用情况,可看出初始阶段该实例的CPU、IOPS相对较高,再升到高配规格之后CPU、IOPS的使用量均有明显下降。
您可以在阿里云数据库自治服务 DAS 上免费使用该功能扫描下方二维码,即可立即申请体验
因“智”而治,数據库即将迈入自动驾驶时代
期待与你一同见证精彩蜕变
立即预约观看DAS发布会直播