写点什么

为什么基础服务不应该高可用(一)

  • 2019-12-27
  • 本文字数:1126 字

    阅读完需:约 4 分钟

为什么基础服务不应该高可用(一)

为什么这么设计(Why’s THE Design)是一系列关于计算机领域中程序设计决策的文章,我们在这个系列的每一篇文章中都会提出一个具体的问题并从不同的角度讨论这种设计的优缺点、对具体实现造成的影响。如果你有想要了解的问题,可以在文章下面留言。


作者在去年使用过 Google Cloud 平台提供的 Kubernetes 来管理生产环境的集群,然而在托管的过程中却经历了一些比较严重的线上事故,几个集群的中的节点因为停机维护而同时重启导致线上的服务几个小时都处于不不可用的状态。


当然事故时间如此之长的原因有很多,在这里不会展开讨论,然而事故刚刚出现时作者曾经也想去责怪和质疑谷歌云服务的稳定性,但是在随后的分析中得出了另一个结论『你的基础服务其实不应该高可用』,我们在这篇文章就会为各位读者分享作者产生这一观点的原因。

概述

为了帮助大家理解今天的内容,我们需要帮助各位读者理解问题中的两个个关键点,也就是高可用意味着什么、基础服务在这里的定义以及基础服务和 SLA 之前的关系。


高可用

想要让服务达到高可用并不是一个容易的事情,不仅服务运行过程中出现的事故会影响可用时间,用于维护的计划停机和更新其实也会影响服务整体的可用时间,如果一个服务要求可用性为 99.95%,那么全年不工作的时间可能只有 4.38 小时,每个月只能宕机 21.9 分钟。


可用性不可用时间(每年)不可用时间(每月)
99%87.6h7.3h
99.9%8.76h0.73h
99.99%52.56min4.38min
99.999%5.26min26.3s
99.9999%31.56s2.63s


假设我们需要达到 4 个 9 的可用性(99.99%),全年的不可用时间只有不足 1 小时,每个月的不可用时间只有 4.38 分钟,99.99% 就是 Google 云计算引擎对外提供的服务质量,每个月不可用时间小于 5 分钟,这也是作者见到过云服务商对外提供的最高服务等级协议(Service-Level Agreement, SLA)了。


很多人可能认为每个月不可用 5 分钟也没什么难的,但是如果你的业务服务建立在稳定性只有 99.95% 甚至 99.9% 的服务上时,你还能保证服务的高可用么?

基础服务

在这篇文章中我们谈到的基础服务指的其实都是基础设施和基础架构,例如用于支撑整个业务系统的 MySQL、Redis 以及 Kubernetes 等系统,这些系统的稳定性和可用性会影响整个业务系统的可用,由于这些基础服务往往提供了相对较为简单和稳定的功能,所以我们对基础服务的可用性有着更高的要求。



业务服务由于经常发版和迭代,有时很难保证服务的稳定和可用,而基础服务和基础架构因为处于更加底层的位置,所以它们稳定性的提升对于依赖它们的上游来讲会有比较大的收益,这也是所有业务同学对基础服务以及架构的期望 —— 保证尽可能高的可用性并保证服务不会宕机。


本文转载自 Draveness 技术博客。


原文链接:https://draveness.me/whys-the-design-unstable-infrastructure


2019-12-27 11:33994

评论 1 条评论

发布
用户头像
强强强
2020-08-27 23:53
回复
没有更多了
发现更多内容

架构师训练营 Week 01

Wancho

命题作业—第一周

于江水

极客大学架构师训练营

架构师训练营 Week01 学习心得

极客大学架构师训练营

Week 01-作业一:食堂就餐卡系统设计

dean

为啥成为架构师总是少数人?

朱月俊

第一周学习总结

战峰

架构师训练营第一周

Melo

食堂就餐卡系统设计

GalaxyCreater

Week 01-作业二:学习总结

dean

食堂就餐卡系统设计

_MISSYOURLOVE

极客大学架构师训练营 第一周命题作业

小师妹学JavaIO之:Buffer和Buff

程序那些事

io nio 小师妹 buffer buff

架构师训练营学习总结(week-01)

Justin

Week1-架构是什么&如何做架构

wyzwlj

极客大学架构师训练营

第1周小结

龙7

极客大学架构师训练营

食堂就餐卡系统设计

dapaul

架构设计 极客大学架构师训练营

食堂就餐卡系统架构设计⽂档

Geek_2dfa9a

架构师训练营第0期-第一周学习总结

sljoai

作业

架构师训练营第一周总结

Geek_2dfa9a

极客大学架构师训练营--食堂就餐系统架构设计⽂档 -- 第一次作业

John(易筋)

极客时间 极客大学 极客大学架构师训练营

深入理解JVM垃圾回收机制 - 对象的内存布局

Skye

深入理解JVM 内存布局 垃圾回收

第1周 - 食堂就餐卡系统

大海

极客大学架构师训练营

架构师训练营第0期-第一周-命题作业1

sljoai

作业

使用IBM Blockchain Platform extension开发你的第一个fabric智能合约

程序那些事

区块链 blockchain hyperledger fabric ibm

学习总结—第一周

于江水

极客大学架构师训练营

架构师训练营作业(week-01)

Justin

Week1-Homework

第一周学习总结

Geek_5d0795

极客大学架构师训练营 第一周总结

食堂就餐卡系统设计

mh

系统设计

架构师训练营第一周总结

小树林

食堂就餐卡系统架构设计文档

朱月俊

在IBM Cloud中运行Fabric

程序那些事

vscode blockchain hyperledger fabric ibm

为什么基础服务不应该高可用(一)_语言 & 开发_Draveness_InfoQ精选文章