微服务架构的好处
微服务架构模式有很多好处. 首先, 通过分解巨大单体式应用为多个服务方法解决了复杂性问题. 在功能不变的情况下, 应用被分解为多个可管理的分支 或服务. 每个服务都有一个用 RPC - 或者消息驱动 API 定义清楚的边界. 微服务架构模式给采用单体式编码方式很难实现的功能提供了模块化的解决方案, 由 此, 单个服务很容易开发, 理解和维护.
第二, 这种架构使得每个服务都可以有专门开发团队来开发. 开发者可以自由选择开发技术, 提供 API 服务. 当然, 许多公司试图避免混乱, 只提供某 些技术选择. 然后, 这种自由意味着开发者不需要被迫使用某项目开始时采用的过时技术, 他们可以选择现在的技术. 甚至于, 因为服务都是相对简单, 即使用现在 技术重写以前代码也不是很困难的事情.
第三, 微服务架构模式是每个微服务独立的部署. 开发者不再需要协调其它服务部署对本服务的影响. 这种改变可以加快部署速度. UI 团队可以采用 AB 测试, 快速的部署变化. 微服务架构模式使得持续化部署成为可能.
最后, 微服务架构模式使得每个服务独立扩展. 你可以根据每个服务的规模来部署满足需求的规模. 甚至于, 你可以使用更适合于服务资源需求的硬件. 比如, 你可以在 EC2 Compute Optimized instances 上部署 CPU 敏感的服务, 而在 EC2 memory-optimized instances 上部署内存数据库.
微服务架构的不足
Fred Brooks 在 30Year 前写道,"there are no silver bullets", 像任何其它科技一样, 微服务架构也有不足. 其中一个跟他的名字类似,微服务强调了服务大小, 实际上, 有一些开发者鼓吹建立稍微大一 些的, 10-100 LOC 服务组. 尽管小服务更乐于被采用, 但是不要忘了这只是终端的选择而不是最终的目的. 微服务的目的是有效的拆分应用, 实现敏捷开发和部署.
另外一个主要的不足是, 微服务应用是分布式系统, 由此会带来固有的复杂性. 开发者需要在 RPC 或者消息传递之间选择并完成进程间通讯机制. 更甚 于, 他们必须写代码来处理消息传递中速度过慢或者不可用等局部失效问题. 当然这并不是什么难事, 但相对于单体式应用中通过语言层级的方法或者进程调用, 微 服务下这种技术显得更复杂一些.
另外一个关于微服务的挑战来自于分区的数据库架构. 商业交易中同时给多个业务分主体更新消息很普遍. 这种交易对于单体式应用来说很容易, 因为只 有一个数据库. 在微服务架构应用中, 需要更新不同服务所使用的不同的数据库. 使用分布式交易并不一定是好的选择, 不仅仅是因为 CAP 理论, 还因为今天高扩 展性的 NoSQL 数据库和消息传递中间件并不支持这一需求. 最终你不得不使用一个最终一致性的方法, 从而对开发者提出了更高的要求和挑战.
测试一个基于微服务架构的应用也是很复杂的任务. 比如, 采用流行的 Spring Boot 架构, 对一个单体式 web 应用, 测试它的 REST API, 是很容易的事情. 反过来, 同样的服务测试需要启动和它有关的所有服务 (至少需要这些服务的 stubs). 再重申一次, 不能低估了采用微服务架构带 来的复杂性.
另外一个挑战在于, 微服务架构模式应用的改变将会波及多个服务. 比如, 假设你在完成一个案例, 需要修改服务 A,B,C, 而 A 依赖 B,B 依赖 C. 在单体式应用中, 你只需要改变相关模块, 整合变化, 部署就好了. 对比之下, 微服务架构模式就需要考虑相关改变对不同服务的影响. 比如, 你需要更新服务 C, 然后是 B, 最后才是 A, 幸运的是, 许多改变一般只影响一个服务, 而需要协调多服务的改变很少.
部署一个微服务应用也很复杂, 一个分布式应用只需要简单在复杂均衡器后面部署各自的服务器就好了. 每个应用实例是需要配置诸如数据库和消息中间件等基础服务. 相对比, 一个微服务应用一般由大批服务构成. 例如, 根据 Adrian Cockcroft,NetFlix 有大约 600 个服务. 每个服务都有多个实例. 这就造成许多需要配置, 部署, 扩展和监控的部分, 除此之外, 你还需要完成一个服务发现机制 (后续文章中发 表), 以用来发现与它通讯服务的地址 (包括服务器地址和端口). 传统的解决问题办法不能用于解决这么复杂的问题. 接续而来, 成功部署一个微服务应用需要开 发者有足够的控制部署方法, 并高度自动化.
一种自动化方法是使用 PaaS 服务, 例如 Cloud Foundry. PaaS 给开发者提供一个部署和管理微服务的简单方法, 它把所有这些问题都打包内置解决了. 同时, 配置 PaaS 的系统和网络专家可以采用最佳实践和策略来 简化这些问题. 另外一个自动部署微服务应用的方法是开发对于你来说最基础的 PaaS 系统. 一个典型的开始点是使用一个集群化方案, 比如配合 Docker 使 用 Mesos 或者 Kubernetes. 后面的系列我们会看看如何基于软件部署方法例如 NGINX, 可以方便的在微服务层面提供缓存, 权限控制, API 统 计和监控.
总结
构建复杂的应用真的是非常困难. 单体式的架构更适合轻量级的简单应用. 如果你用它来开发复杂应用, 那真的会很糟糕. 微服务架构模式可以用来构建复杂应用, 当然, 这种架构模型也有自己的缺点和挑战.
在后续的博客中, 我会深入探索微服务架构模式, 并讨论诸如服务发现, 服务部署选择和如何分解一个分布式应用为多个服务的策略.
欢迎大家一起学习研究相关技术
来源: http://www.bubuko.com/infodetail-2700430.html