专栏首页EAWorldDevOps组件高可用的思路

DevOps组件高可用的思路

转载本文需注明出处:微信公众号EAWorld,违者必究。

引言:

以往部署的应用或服务基本都是自成体系不会被其他影响。而在DevOps下这种部署方式也正在发生改变。因为应用或服务本身所涉及的组件越来越多。DevOps串联着应用或服务以及应用和服务所涉及的组件,以保证所有应用和服务的正常运行。

目录:

一、传统高可用

二、DevOps 简述

三、传统高可用架构模式

四、DevOps 带来的改变

一、传统高可用

传统生产模式下,如应用、中间件以及数据库等服务都需要有高可用。以避免业务服务出现宕机的问题。

常见的部署方法,有服务主备、服务集群,还有两地三中心的高可用方案。

高可用常见的指标,以及服务宕机时间。

https://en.wikipedia.org/wiki/Mean_time_between_failures

MTBF = MTTF + MTTR

365*24*(1-0.99)=87.6,在实际情况下当然故障时间越短越好

系统可用性比率 = MTTF/MTBF

二、DevOps简述

1、DevOps带来的变化就是整个部署过程是自动化的、部署的周期变短了。开发和运维所关注的焦点也发生了变化。开发人员从提交代码,到看到本次修改的内容可以在很短的时间内完成。

2、在实际的接触的过程中,由于DevOps串连了多重的应用服务,因此许多人会提出对于DevOps所串联的组件都必须是高可用。因此问题就出现了,使得原本简单清晰的架构发生了很大的变化。

3、DevOps带来的变化与传统的高可用是有区别的。

三、传统高可用架构模式

说明: 简单的将Gitlab服务做成主备,或者主主的方法。这样的Gitlab服务已经从单点变成的了稍微复杂的架构。

这样我们的harbor也已经变成高可用了,当通过程devops串联后,运维变得复杂起来。当然DevOps还可以串联更多的组件,这里只是举了两个例子。

四、DevOps带来的改变

进入DevOps时代,DevOps在串联组件高可用时,对于组件的要求也发生了变化。由于DevOps起到了串联的功能,因些希望所有的组件即可以高可用也可以是分布式的,希望所有服务都是可解耦的。

从图上可以看到,APP这一层就是一个简单的分布式。这也许是我们经常部署的一种典型的架构。简单的将APP这层进行了分布式的设计。而其他的组件还是沿用传统集群的部署模式,但在这种架构的部署模式下,增加了运维的难度。

复杂的分布式在图中看起来比简单分布式要简单。但在实践中会发现这个会很难。因为APP、Cache、DB、Storage等等都是分布式的,这样复杂对于架构上提出了很高的要求,同时对于运维也增加了难度。图上画的比较少,但实际上复杂的分布式比这要多的多。

也许集群就是分布式。也许集群只是解决高可用的,而分布式是解决高并发、高性能的问题,也许集群是分布式的一部分。每个人都有自己的理解,理解你的自己的业务、需求等等。

其实还有一种技术可以来帮助我们实现分布式部署,就是容器技术。通过kubernetes来实现自己所需求应用的高可用以及应用的分部式。

当随着微服务和devops的到来,容器化的微服务和devops更好的落地实现。高可用的kubernetes为我们提供了基础的容器平台和容器的调度能力。Kubernetes本身就具备容错能力。

也许你会说横向扩展并不是高可用的架构。但如果你考虑到业务对资源需求变化时,你会发现kubernetes的部署对你非常用利。当访问量突增时,就可以利用kubernetes的横向扩展能力。而不是像以往在从零开始。

同时Kubernetes本身时可靠的监控对高可用系统非常重要,利用很多商用的软件或者很多开源的工具进行整合甚至自行开发可以对整体的业务状况以及系统状况进行把握。也可以使用额外的开源软件promethus等来对业务状况的监控。

作者观点:适合自己的才是最合适自己的。


  • 并不是所有服务都适合容器部署
  • 高可用的选择需要适合自己的体系
  • 由于DevOps串联了整个周期,同时需要我们做出改变。

精选提问:

问1:devops为啥不和paas平台放一起,而分成两个项目,不麻烦么?

答:因为DevOps在我理解是串联的作用,二者应该定位不同。

问2:DevOps到底是解决什么问题?面向云计算架构,哪个最合适?

答:DevOps在串联整个开发-测试-预发-生产的作用。云计算架构很大的概念,具体要结合自身的需求。

问3:K8s对于网络的要求高吗?瓶颈在哪里?

答:k8s对于网络是有要求的。当运行到一定数量pod时,k8s网络的压力比较大,因此在新版中k8s已经开始支持ipvs或者像flannel支持direct-route等等来降低网络的开销。k8s目前还不具备纵向扩展。

问4:jenkins的用k8s 做架构好嘛? 有没有办法实现多master?

答:实现不了。k8s只能保证jenkins服务出错后自动重建。

问5:请问有哪些类型的服务不适合容器部署?

答:如数据库oracle、db2等。

本文分享自微信公众号 - EAWorld(eaworld),作者:严伟

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-10-10

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • DevOps是MindSet:工具也好,文化也罢,人员才是关键

    任何变革都需要时间,DevOps亦然。在经过数年的蛰伏期之后,DevOps终于成为了业界聚焦点;不过,从知其然到知其所以然,再到最终完美实现DevOps,依然前...

    yuanyi928
  • 加速企业敏捷的DevOps平台

    大家好,本次内容我在我司上个月的PWorld大会上分享过,线下会议参与人数有限,这次应邀在微信上向更广泛的人群分享。希望对大家能有帮助,谢谢! ? 今天分享的主...

    yuanyi928
  • 警惕文化空谈的陷阱,落地DevOps工具才是关键

    恍惚间,DevOps已经被讨论十年了 “如果系统是集中式的、环境是同质化的,从开发环境向生产环境推送程序变化的过程非常简单,不需要太多的自动化;但是今天的应用需...

    yuanyi928
  • P2375 动物园

    题目描述 近日,园长发现动物园中好吃懒做的动物越来越多了。例如企鹅,只会卖萌向游客要吃的。为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决...

    attack
  • 刷脸AI供应商下调业绩预期,苹果股价应声跌掉一个小米

    截至美东时间周一收盘,苹果股价下跌5.04%,市值蒸发489亿美元,194.17美元每股的股价,已是三个月来最低点。

    量子位
  • 刷脸AI供应商下调业绩预期,苹果股价应声跌掉一个小米

    截至美东时间周一收盘,苹果股价下跌5.04%,市值蒸发489亿美元,194.17美元每股的股价,已是三个月来最低点。

    量子位
  • INT类型知多少

    整型是MySQL中最常用的字段类型之一,通常用于存储整数,其中int是整型中最常用的,对于int类型你是否真正了解呢?本文会带你熟悉int类型相关知识,也会介绍...

    MySQL技术
  • C++11网络编程

    Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台。十行代码即可完成一个完整的网络服务器。

    bear_fish
  • 『互联网架构』软件架构-从0到1认知分布式架构(上)(38)

    PS:另外分享一个心得:很多公司需要一套框架,业内有比较成熟的开源系统,但是技术经理还是要选择自主去开发一套,这是为什么呢?为了kpi,大公司kpi要求比较高,...

    IT故事会
  • Java 八大排序实现

    将一个记录插入到已排序好的有序表中,从而得到一个新,记录数增1的有序表。即:先将序列的第1个记录看成是一个有序的子序列,然后从第2个记录逐个进行插入,直至整个序...

    Yano_nankai

扫码关注云+社区

领取腾讯云代金券