微服务

作者: zmwise | 来源:发表于2018-04-24 23:33 被阅读0次

起源

微服务的起源是由 Peter Rodgers 博士于 2005 年度云端运算博览会提出的微 Web 服务 (Micro-Web-Service)


image.png
image.png

概念

微服务是系统架构上的一种风格,它的主旨是将一个原本独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间通过基于HTTP的RESTful API进行通信协作

特点

  • 微小度颗粒
  • 责任单一性
  • 运行隔离性
  • 管理自动化

针对微服务解决方案或开源框架

  • 服务治理:Dubbo、当当网DubboX、Netflix的Eureka、Apache的Consul等
  • 分布式配置管理:百度的Disconf、Netflix的Archaius、360的Qconf、Spring Cloud的Config、淘宝的Diamond等
  • 批量任务:当当网的Elastic-Job、LinkedIn的Azkaban、Spring Cloud的Task等
  • 服务跟踪:京东的Hydra、Spring Cloud的Sleuth、Twitter的Zipkin等
  • ......

优缺点

微服务提供的好处 微服务带来的成本
模块化:微服务强调模块化的结构,这对大团队特别重要 分布式特性:分布式系统的编程难度更大,因为远程调用慢,而且总存在失败的风险
独立部署:简单的服务更容易部署,而且由于它们是自治的,一旦出了问题,不会导致整个系统的故障 最终一致性:对于分布式系统来说,保持强一致性很难,这意味着每个人都不得不去处理最终一致性
技术的多样性:有了微服务,你可以混合使用多种编程语言、开发框架以及数据存储技术 运维的复杂性:你需要一个成熟的运维团队,来管理很多需要定时重新部署的服务

单一应用架构

当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键。


image.png

垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。


image.png

分布式服务架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键。

流动计算架构

当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。

微服务架构

image.png

Dubbo与Spring Cloud对比

组件名称 Dubbo Spring Cloud
服务注册中心 Zookeeper Spring Cloud Netflix Eureka
服务调用方式 PRC REST API
服务网关 Spring Cloud Netflix Zuul
断路器 不完善 Spring Cloud Netflix Hystrix
分布式配置 Spring Cloud Config
服务跟踪 Spring Cloud Sleuth
消息总线 Spring Cloud Bus
数据流 Spring Cloud Stream
批量任务 Spring Cloud Task
...... ...... ......

Spring Cloud 生态圈

组件名称 说明
spring-boot spring应用程序脚手架
spring-cloud-config 分布式配置
spring-cloud-eureka 服务治理
spring-cloud-task 定时任务
spring-cloud-zookeeper 注册中心
spring-cloud-fegin 声明式服务调用客户端
spring-cloud-hystrix 服务降级、服务熔断、线程隔离
spring-cloud-bus 消息总线
spring-cloud-zuul 服务网关
spring-cloud-session 会话共享
...... ......

相关文章

  • 菜鸟带你看传说中的微信开发!

    1.微信开发原理微信客户端->微信服务器->开发绑定的服务器。微信开发步骤: 2.微信验证服务器原理(验证服务器的...

  • 胡健豪:如何运营微信矩阵

    微信矩阵是怎么回事,其实就是1个微信服务号+N个微信订阅号。微信服务号和订阅号的差别在于,服务号提供公司服务,订阅...

  • zabbix微信 | 微信对接自己服务器(2)

    上接使用微信告警 企业号微信对接自己服务器 1.本地服务器与微信服务器的信任 本地具有独立外网ip服务器获取微信服...

  • 微服务的微

    微服务的微,是指服务粒度的微么? 微服务可能是由此得名的。但在微服务架构思想中,服务粒度的微,不应该放在首要强调的...

  • 微信服务

    1.微信sdk 样例 http://demo.open.weixin.qq.com/jssdk/

  • 实战 Docker+Kubernetes 微服务容器化(一)-初

    1 微服务-导学 2 软件架构的进化 3 什么是微服务 多微才算微 微服务的特征 微服务诞生背景 4 画出微服务架...

  • SDtalk-10:阿里茶山服务设计实践-4

    2015年的茶山:服务设计微日记 《服务设计微日记》以微日记的故事写作形式,引用每天生活和工作的真实服务设计案例及...

  • 微服务应该具备的功能

    微服务应该具备的功能 >> 微服务应该具备的功能微服务,可以拆分为“微”和“服务”二字。“微”即小的意思,那到底多...

  • 微信开发——内网穿透

    微信开发需要与微信服务器交互,要保证微信服务器能向我们的服务器POST数据,我们的服务器需要能够在公网访问。这里简...

  • 【服务设计】服务设计微日记

    服务设计如同一部电影,有各个角色,出场顺序也不一样,服务流程贯穿应用场景,且有故事性,各个利益相关者都有主次之分。...

网友评论

      本文标题:微服务

      本文链接:https://www.haomeiwen.com/subject/vruslftx.html