springcloud学习手册-什么是微服务?

导读 | 微服务

在介绍springcloud之前,先整体认识一下,什么是微服务?

、系统演进的历程

系统演进的历程主要分为四个部分,MVC架构》RPC构架》SOA架构》微服务架构,大家可以在网上查一下前三种构架,这里咱们只是重点介绍微服务,此处省略简单介绍一下,如下是传统应用架构的主要结构图:

二、微服务与传统巨石应用的区分是什么?

传统巨石应用(monolith)

web应用程序发展的早期,大部分web工程是将所有的功能模块(service side)打包到一起并放在一个web容器中运行,很多企业的Java应用程序打包为war包部署到容器运行。其他语言(Ruby,Python或者C++)写的程序也有类似的问题。这种将所有功能都部署在一个web容器中运行的系统就叫做巨石型应用。那传统应用水平扩展后有什么效果呢,如下是传统应用架构水平扩展的主要结构图:

传统巨石应用(monolith)好处与不足之处

好处:单个应用设计编程、容易测试、因为是单体程序可直接打成一个完整的包,部署web容器中,即可运行。

不足之处:单体应用随着业务和功能不不断增加,代码量会增多,代码量增多后维护不容易,同时如果部署的话部署打包时间会增长,最麻烦的是如果业务功能有变更,修改代码成本会增大,同时单体应用对资源有一定的要求。

微服务的动机,就是为了解决单体应用的不足,从而把单体应用拆分成多个微服务的情况下产生的。

三、微服务的定义

微服务的概念源于2014年3月Martin Fowler所写的文章。

微服务架构是一种架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相沟通(通常是基于HTTP协议的RESTful API)。每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外,应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据业务上下文,选择合适的语言,工具对其进行构建。

如下是微服务架构的主要结构图:

微服务架构的优点与缺点

优点

  • 小且专注于做好一件事情,每个服务内聚并且小。
  • 独立部署,可以根据自己的需要部署到合适的硬件服务器上;
  • 轻量级的通信机制;
  • 松耦合,程序员可对单个服务进行开发、维护,同时每个服务可以采用不同语言开发;

缺点

  • 依赖服务接口变更导致,服务接口管理麻烦,接口变更跟踪难度增大,依赖服务调试难度增大。
  • 部分模块重复构建,安全认证,配置日志方面问题。
  • 分布式带来的问题,事务问题,依赖服务间不稳定,需要引入异步模式。
  • 运维复杂度加大,部署数量倍增,监控进程倍增,故障定位难,问题追溯难。

声明:文章属于个人原创,转载请注明文章出处

原文发布于微信公众号 - 全华班(quanhuaban)

原文发表时间:2017-12-05

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java帮帮-微信公众号-技术文章全总结

11个最值得Java开发者收藏的网站

? Java是一种面向对象的编程语言,由Sun Microsystems公司在1995年的时候正式发布。直到今天,Java都一直是最受欢迎的编程语言之一。如今...

2404
来自专栏java一日一条

11个最值得Java开发者收藏的网站

Java是一种面向对象的编程语言,由Sun Microsystems公司在1995年的时候正式发布。直到今天,Java都一直是最受欢迎的编程语言之一。如今,Ja...

621
来自专栏SDNLAB

Dragonflow的架构、功能及未来发展路线图详解

Dragonflow架构由Neutron插件构成,该插件可以将Neutron模型映射到一个新的逻辑拓扑模型中,并与本地Dragonflow控制器进行同步。而这...

34610
来自专栏纯洁的微笑

一文读懂 Spring Boot、微服务架构和大数据治理三者之间的故事

814
来自专栏Golang语言社区

容器环境下 go 服务性能诊断方案设计与实现

业务上量以后,对程序进行 profiling 性能诊断对很多后端程序员来说就是家常便饭。一个趁手的工具往往能让这个事情做起来事半功倍。

795

API代理,连接器和附加组件

我正在通过API服务提供商的一些100K的视图的研究,试图完善我对API下一步是什么?的看法。

1955
来自专栏FreeBuf

运维配置缺陷导致大量MongoDB数据信息遭泄露

近日,黑客组织GhostShell泄露了大量的MongoDB数据库用户资料。 数据遭到大量泄露 据统计该组织目前泄露的数据已达3600万条之多。MongoDB作...

18410
来自专栏企鹅号快讯

深度解析小程序4大核武器级接口能力

今天给大家介绍4组极其重要,但并不广为人知的微信小程序接口,了解这4类接口,相信您也可以设计出来一款牛逼的微信应用。下面且听微播君为您娓娓道来: 其实在公众号接...

1965
来自专栏java闲聊

浅谈架构(单体架构、 SOA架构、微服务架构)

* 一个典型的单体应用就是将所有的业务场景的表示层、业务逻辑层和数据访问层放在一个工程中,最终经过编译、打包,部署在一台服务器上。

1514
来自专栏北京马哥教育

一个开发眼中的运维

马哥linux运维 | 最专业的linux培训机构 ---- 在云计算时代,开发和运维的结合变得越来越重要。在DIFF论坛第一期,前新浪SAE运维主管,郑志勇...

2907

扫描关注云+社区