本文为大家介绍了5个迁移到微服务架构所需做的准备步骤,包括如何划分微服务,微服务和组织结构间的误解,如何划分组织架构,以及在实现微服务架构中需要尽早考虑的一些问题,值得大家参考。

时至今日,微服务相关的话题不胜枚举,上百次的会议,在线讨论以及相关文章。你可以假设大家已经认识到其优点以及与之俱来的风险。然而,有很多组织没有事先准备就迈入这个潮流了。自然,这也就导致了在架构实现过程中的失败。

有一位 智者曾经说过,“对于商业中所应用的任何技术而言,有2条规则,其一,将自动化应用于高效的运维上才能增加效率;其二,将自动化应用于低效的运维反而会降低效率。”我认为这种哲学对微服务而言亦行之有效。如果你的组织没有为此准备就贸然迁移,很可能会招致失败。以上就是本文的出发点,我将为大家带来在实现微服务架构前需要准备的5个关键步骤。

1. 从绘图入手

在开发特定的微服务时,许多开发者都会犯同一个错误:直接写代码。或许,这可能就是你能够犯的最严重的错误了。诚然,对于一个服务而言,你可能会获得成功,但是随着服务数量的上升,所有事情都会变得一团乱。

和其它产品一样,它也需要被创造,需要以设计作为初始步骤。将团队汇聚到桌子周围,自由地在纸上(或者白板)绘制服务。首先,找出你所构建的应用的main函数。然后,自顶向下地将它分解成最小单元。最后,找出不同单元的互联通性。这些功能将会成为你的微服务。

比如,在一款图书预览应用中,其主要的功能就是比较不同的图书。然而,也有许多其他功能需要开发,例如创建用户履历,评分,评论,图书数据库等。识别每个功能,是将它们转为微服务的关键。

整个过程将会持续超过一天时间,并且需要多次迭代直至完美。当然,你将需要从许多不同部门的人员手中获得输入,以确保能够知晓其视角和观点,并确保你不会遗漏任何系统功能。

2. 微服务并不是组织结构

根据你所在公司的组织结构定义微服务,这似乎是很自然的。如果你正在构建单体(monolithic)应用,这或许真是一个恰当的解决方案。但是,在实现微服务架构时,它可能就是一个错误的决定了。

也许,这对于销售部门或客户服务是可行的,但是许多组织只有一个部门处理所有的数据库。因此,为所有数据库创建一个微服务将会导致单点故障。而 没有 单点故障,则是微服务的关键特性之一。

你希望通过服务实现的一些功能可能会涉及几个组织部门,或者,你可能将会需要为一个部门构建许多微服务。总结一下,你需要将架构聚焦于你想要提供的服务,而非你们公司的组织结构。

3. 创建合适的组织结构

转变到一个全然不同的组织架构,能够满足公司在管控活动上变化的需要。之前2个步骤关注于应用的设计,以便能够为最终用户提供正确的功能。现在,是时候确保对于新的架构而言,你拥有恰当的运维支持了。

你将不得不放弃原有的部门结构,并使团队关注于某个微服务。这意味着这些团队将由拥有不同技能的成员组成,如系统分析师、UX/UI设计师、后端工程师、前端工程师等。如此一来,团队就能够彻底负责它们的项目(微服务)——从开发部署到运维、监控和管理。反过来,由于团队觉得自己拥有这个产品,因此将提升其创建产品的积极性。

团队的规模视公司/项目的总体人数而定;当然,根据专家的建议,比较理想的规模是每个团队8-10人。和单体架构不同,微服务架构使得你能够根据业务的增长来扩展团队规模。

当然,所有团队将会( 需要 )积极配合,以最终促成整个项目。这便是这种结构的主要好处,使我们能够尽可能快地向市场交付产品。

4. 性能和可靠性同样重要

切换到微服务架构的整体想法,便是使得创建的最终产品相比于单体应用而言拥有更好的性能,更佳的稳定性(例如,更低的下线风险),同时可以更快地交付市场。

将改进性能作为设计的一部分是很重要的,这将确保潜在问题能够尽早被考虑。通常,(性能)问题都源自微服务设计主要考虑功能。然而,如果在更大的服务下,服务崩溃或者变得很慢,那么它就没什么用了。每个服务应该拥有2-3个替代机制,当下层资源失败时,它便可以继续运作。当其中一个机制无法在可接受时间窗口内响应时,服务也需要做到快速切换。

在前期考虑让服务支持更大的负载变动,你的应用将能够应对实际挑战,你将领先市场,当然这也是你在第一时间考虑切换到微服务的主要原因!

5. 变更先行

忽略应用的变化是不切实际的。开发者一直在增加和移除功能,变更代码,替换应用的核心元素等,这在微服务应用中更甚。更确切地说,微服务就是持续演进的。

当你每天需要处理多次代码升级时,最好接受一个观点:变更是持续的,而非对于稳定状态的一次偶然性中断。一旦你认知到这一点,你将意识到一开始便整合变更的灵活性需求的重要性。确保应用一直正常工作的一种方式便是准备服务API,这样微服务间便可继续通信,即使它们已被改变。另外,你还需要引入版本控制,以允许服务同时开放新旧接口。

另一方面,数据存储的演进是一个更大的挑战。改进数据库模式(schema),使其支持新的功能,传统观点中,这是应用升级时最难处理的部分,微服务并不会使其变得更加简单。然而,单就增加新的域且不破坏现有结构这一点而言, NoSQL数据库会更加灵活。如果你希望你的数据存储需求持续演进(谁不希望呢?),那么你应该将可演化的数据存储作为微服务设计的努力方向之一。

在迁移到微服务架构时,做适当的准备是整个项目成功的关键因素,这一点我们可以认同。只有经过仔细的准备,创新设计思维,并且具备合适的运维和管理结构,你才能收获微服务带来的所有好处!

最后,我为大家奉上我的干货,私信【资料】来领取哟。

创建微服务架构的步骤_成功备战微服务的5个准备步骤相关推荐

  1. 微服务架构开发实战:如何实现微服务的自动扩展?

    微服务架构开发实战:如何实现微服务的自动扩展? 程序员高级码农II 2020-09-25 07:25:00 如何实现微服务的自动扩展 前面讲了一些关于自动扩展的理论知识,但如何实现自动扩展,并不是三言 ...

  2. 超全,看完这份微服务架构与实践文档,微服务不再难

    前言: 微服务近年来受到了极大的关注并成为趋势,不信的话可以查看 Google Trends. 可以看到从2014年开始人们对它产生了极大的兴趣,随着时间的推移,这一趋势仍在增长. 随着数字化转型的推 ...

  3. Java架构师-微服务:微服务架构【单体部署 --改造--> 微服务架构】【分布式:分散压力;微服务:分散能力】【RESTFul+Docker+K8S、SpringCloud】

    一.微服务概述 微服务架构是团队面对互联网产品爆发式增长的最优选择,要解决的是快速迭代.高可靠和高可用等问题,把复杂度很高的产品拆分成一些较小的模块,并遵循康威定律,每一个模块用5-9个小团队来维护, ...

  4. 微服务架构中熔断器_基于 Golang 语言的微服务熔断器

    背景 从单体服务拆分到微服务过程中,原来模块间交互逐渐抽离成远程调用,可能http,rpc,tcp,,,等等,那么这些模块在调用中一定存在某种依赖关系. 这时一旦下游某个服务超时或者down,请求量还 ...

  5. 微服务架构 性能提升_如何通过无服务器架构提高性能

    微服务架构 性能提升 by Domenico Angilletta 通过多梅尼科·安吉列塔(Domenico Angilletta) 如何通过无服务器架构提高性能 (How to boost your ...

  6. 微服务构架 esb总线_好的微服务架构=企业服务总线(ESB)的灭亡?

    微服务构架 esb总线 如今,似乎每个人都在谈论微服务. 您可以在数百篇文章和博客文章中读到很多有关该主题的文章,但是我建议的出发点是Martin Fowler的这篇文章 , 该文章引发了有关这种新建 ...

  7. 微服务架构的优缺点_微服务架构DNS服务注册与发现实现原理

    微服务架构已经成为中小型企业必备的项目支撑能力,尤其互联网BATJ企业在04年已经非常成熟,在大规模的核心业务实战中总结了很多大规模服务调度与大数据集的处理方案.微服务架构中涉及到很多模块,本文以微服 ...

  8. 真腻害,阿里P8架构师手撸微服务架构探险pdf,成功登顶榜首

    微服务来了,有了"服务"这两个字,这注定又是个一说就明白.一举例就糊涂.一讨论就吵架的概念.微服务的出现有其必然的商业背景和架构哲学,如何更好地认识微服务的内涵如即使指地应用微服务 ...

  9. python微服务框架_微服务架构框架有哪些?常用微服务架构介绍

    小伙伴们知道常用的微服务架构框架有哪些吗?上回我们介绍了一些常用的微服务架构设计模式,这次我们就来了解一下一些常用的微服务架构框架吧. 一.Dubbo Dubbo框架是由阿里巴巴开发的开源式的分布式服 ...

最新文章

  1. 阿里云MVP北京闭门会圆满落幕 多把“利剑”助力开发者破阵蜕变
  2. 数据库日常总结(笛卡儿积与笛卡儿集 )
  3. 为什么说“按月订购”和“无人货架”本质上是一样的?
  4. jvm 参数-server_JVM选项:-client vs -server
  5. python调用系统_python 执行系统命令
  6. Jquery精准计算
  7. 计算机英语口试,英语口试面对“电脑考官”有哪些临场应试技巧
  8. 源码编译altas mysql_Atlas的安装
  9. java开发之路——个人开发模板之技巧
  10. Linux串口编程-转
  11. retrofit2、RxJava简单使用总结
  12. android 屏幕方向监听,android 屏幕旋转问题 - jwzhangjie的个人空间 - 51Testing软件测试网 51Testing软件测试网-软件测试人的精神家园...
  13. Tomcat 7 证书配置中遇到的一个问题
  14. correlation 蒙特卡洛_蒙特卡洛模拟法
  15. 2500个常用中文字符 + 130常用中英文字符
  16. 安装VMware出现Error 1406:could not write value installpath to key的解决办法
  17. 车牌识别系统原理及代码【YOLO+MLP】
  18. 考研复试问题之数据库概论
  19. 帕斯卡计算机的控制原理,液体静力学基本方程式和帕斯卡原理
  20. 天云大数据_【案例分享】天云大数据最佳实践系列之——信用评分模型

热门文章

  1. Oracle 原理:用户和权限,Profile,系统权限,对象权限,角色
  2. C/Cpp / 如何定义一个只能在堆上(栈上)生成对象的类?
  3. Cpp 对象模型探索 / 外部调用私有的虚函数的方法
  4. Cpp 对象模型探索 / 静态联编和动态联编
  5. Qt5 常见的控件类关系
  6. 处理自己的数据集_手写代码实现KDD CUP99数据集的数据归一化处理
  7. mfc获取别的计算机是否在线,VC获取并修改计算机屏幕分辨率(MFC)
  8. Palo Doris不会用?(基础指南)
  9. 做百度AI工程师,还要会“相牛”?
  10. java 静态方法 实例方法的区别_java 静态方法和实例方法的区别