写点什么

DevOps 能力是落地微服务的前提

  • 2017-02-05
  • 本文字数:1131 字

    阅读完需:约 4 分钟

在软件开发领域不存在银弹,当用一项新的技术或新的架构时一定要明白其背后的原理,确保把合适的技术应用在合适的项目上,而不是盲目跟风。

单体应用伸缩性差,而且随着应用规模的扩大,业务逻辑和开发部署过程都变得极其复杂。牵一发而动全身,任何一个微小的改动都有可能影响整个应用,新技术的更新换代对于单体应用来说几乎是个不可能的任务。

相比单体应用,微服务灵活自由,伸缩性强,近年来深受软件开发者的热捧。不过,微服务虽然没有了单体应用的某些局限,但却对开发运维和整个组织提出了更高的要求。在采用微服务架构之前开发者要先想清楚自己的项目是否适合采用微服务架构,以及是否有足够的能力运维一个微服务生态系统。

微服务概念的提出者 Martin Fowler 其实在很早之前就说明了使用微服务需要具备的三个核心能力,分别是服务器的快速扩容、监控和应用的快速部署。下面是具体介绍。

硬件资源是否能够快速到位

为了避免资源竞争和服务间的相互影响,微服务一般是部署在单独的硬件资源上。当有新的微服务加入系统,或者需要对微服务进行伸缩时,必需能足够快地为其准备相应的硬件资源。如果使用了云服务,在获取新资源时会相对容易一些。但在没有云服务的情况下,那么至少需要有一个自动化或者半自动化的系统能够满足快速分配资源的需求。

是否具备了微服务监控能力

微服务生态系统可能会很庞大,服务间相互依赖,个体微服务的可用性会影响整个系统的可用性。对微服务进行监控可以及时地发现微服务的运行状况,如果有些服务出现故障(可能有些在测试阶段没有被测出来的缺陷进入了生产环境),需要及时回滚到之前的稳定版本,避免对系统的整体可用性造成影响。

是否具有快速的开发部署流程

微服务变化很快,一个微服务在一天之内可能需要部署多次,因此需要一个快速的开发、部署以及测试流程。可以在整个流程中引入部署管道,部署管道规定了一系列严格的自动化部署过程,可以加快部署的速度。

微服务系统通常涉及多个团队之间的合作,除了开发团队之间的合作之外,还有开发团队和运维团队之间的合作。运维团队需要保证开发团队能够活得足够的资源,当发生问题时,运维团队能够快速向开发团队暴露问题,开发团队能够及时地解决问题。 DevOps 是开发和运维之间的粘合剂,可以促进团队之间的合作。

微服务系统比我们想象的要复杂得多。微服务给我们带来了诸多好处,同时也对我们提出了更高的要求。必要的时候,我们需要通过调整组织结构来更好地支持微服务系统的发展。所以在转向微服务架构时,需要先考虑好这些问题,并想清楚微服务是否真的适合自己。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2017-02-05 18:005864
用户头像

发布了 322 篇内容, 共 139.4 次阅读, 收获喜欢 145 次。

关注

评论

发布
暂无评论
发现更多内容

Redis管道技术/分区

恒山其若陋兮

7月月更

微信朋友圈的高性能架构设计

张立奎

接口测试

Xd

接口测试工具

视频号加强打击低俗内容:对违背公序良俗的内容必须赶尽杀绝

石头IT视角

在openEuler社区开源的Embedded SIG,来聊聊它的多 OS 混合部署框架

openEuler

Linux 开源 操作系统 嵌入式 openEuler

python干货——函数

Java学术趴

7月日更

Qt | 设置部件大小 sizeHint、minimumSizeHint、sizePolicy、stretch factor

YOLO.

qt 7月月更

什么是 Rest 动词

宇宙之一粟

REST API 7月月更

strncat() strncmp()

謓泽

7月月更

阿里onedate分层思想

奔向架构师

数据中台 7月月更

JAVA编程规范之建表规约

源字节1号

后端开发

使用 Vue + Three.js 构建交互式 WEB 作品展示集(一)

devpoint

Vue three.js 7月月更

最新的swoole-cli已可以支持Windows,手把手带你在windows体验swoole

迷彩

swoole 服务器开发 7月月更 swoole-cli

LibcarePlus 用户态热补丁技术那些事

openEuler

安全 openEuler 漏洞 #开源

openEuler 资源利用率提升之道 01:概论

openEuler

开源 openEuler 内核 资源管理

CentOS 7 常用的 11 个小技巧

耳东@Erdong

Linux 7月月更

1000个Okaleido Tiger首发上线Binance NFT,引发抢购热潮

股市老人

架构实战营模块二作业

zhihai.tu

查策,查策,python字体反爬再一次实践

梦想橡皮擦

Python 爬虫 7月月更

1000个Okaleido Tiger首发上线Binance NFT,引发抢购热潮

BlockChain先知

1000个Okaleido Tiger首发上线Binance NFT,引发抢购热潮

鳄鱼视界

Qt|字符串生成二维码功能

中国好公民st

qt 7月月更

计算机网络之初识网络

未见花闻

7月月更

汇编语言伪指令详解(附实例)

timerring

汇编语言 7月月更 伪指令

【函数式编程实战】(四)流-Stream API原理解析

小明Java问道之路

Java 后端 stream 函数式编程 7月月更

通过http请求启动jenkins任务

程序员欣宸

Java jenkins 7月月更

STM32+ESP8266+MQTT协议连接阿里云物联网平台

DS小龙哥

7月月更

D1-H 开发板——哪吒 开发入门

贾献华

7月月更

ES6箭头函数的使用

bo

JavaScript 前端 ES6 7月月更

Harbor2.2 精细化的权限控制

琦彦

Harbor

DevOps能力是落地微服务的前提_语言 & 开发_薛命灯_InfoQ精选文章