首页 > 其他分享 >微服务开发框架(spring cloud /dubbo)

微服务开发框架(spring cloud /dubbo)

时间:2022-11-22 16:03:44浏览次数:48  
标签:dubbo 调用 服务 spring 配置 编排 Spring cloud 客户端

 

 

Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,基于RPC调用,对于目前使用率较高的Spring Cloud Netflix来说,它是基于HTTP的,所以效率上没有Dubbo高,但问题在于Dubbo体系的组件不全,不能够提供一站式解决方案,比如服务注册与发现需要借助于Zookeeper等实现,而Spring Cloud Netflix则是真正的提供了一站式服务化解决方案,且有Spring大家族背景。

前些年,Dubbo使用率高于SpringCloud,但目前Spring Cloud在服务化/微服务解决方案中已经有了非常好的发展趋势。

Spring Cloud 只是利用了Spring Boot 的特点,让我们能够快速的实现微服务组件开发,否则不使用Spring Boot的话,我们在使用Spring Cloud时,每一个组件的相关Jar包都需要我们自己导入配置以及需要开发人员考虑兼容性等各种情况。所以Spring Boot是我们快速把Spring Cloud微服务技术应用起来的一种方式。

 

 

 

 

 

 

 

1.服务容器负责启动,加载,运行服务提供者;

2.服务提供者在启动时,向注册中心注册自己提供的服务;

3.服务消费者在启动时,向注册中心订阅自己所需的服务;

4.在注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者;

5.服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用;

6.服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心;

微服务框架核心功能

服务注册发现

微服务的注册发现是指应用的客户端与服务端的服务注册表进行交互,整个交互过程分为服务端的自注册和客户端的发现两个步骤。服务端的自注册是指服务实例向服务注册表注册,而客户端的发现是指客户端从服务注册表检索可用服务实例,并在它们之间进行负载均衡。同时服务注册表会定期调用服务API所提供的“运行状态检测”端点,来验证服务实例是否正常且处于可用状态。有时服务注册表还可能要求服务实例定期调用“心跳”API,以防止其注册过期。

Eureka是Netflix开源的一个高可用服务注册表,Eureka Java的客户端Ribbon是一个支持Eureka客户端的复杂HTTP客户端。

服务负载路由

在实施微服务的过程中,不免要面对服务的聚合与拆分。当后端服务的拆分相对比较频繁时,前端服务往往需要一个统一的入口,将不同的请求负载均衡路由到不同的后端服务,无论后端服务如何聚合与拆分,对于前端来讲都是透明的。有了API网关以后,简单的数据聚合可以在网关层完成,同时还可以进行统一的认证和鉴权。尽管服务之间的相互调用比较复杂,接口也比较多,但API网关往往只暴露必需的对外接口,并且对接口进行统一的认证和鉴权,使得内部的服务相互访问时不用再进行认证和鉴权,效率会比较高。有了统一的API网关,还可以在这一层设置一定的策略进行A/B测试、蓝绿发布、预发布环境导流等。API网关往往是无状态的,可以横向扩展,从而不会成为性能瓶颈。

Netflix Zuul就是一个典型的API网关

统一配置

一个配置中心来管理所有的配置,进行统一的配置下发。如果配置项发生变更,配置中心会通过通知服务告诉各个微服务实例关于配置项的变更情况,各个微服务实例收到配置项变更的通知后,使新的配置项生效,这样就实现了应用的动态更新。
微服务中的配置往往分为三类:

第一类是几乎不变的配置,这种配置可以被直接打包在容器镜像文件中;

第二类是启动时确定的配置,这种配置往往通过环境变量在容器启动时传进容器中;

第三类就是统一的配置,需要通过配置中心进行下发。如果将配置写到配置文件中,那么当遇到修改配置的情况时成本会很高,并且没有配置修改的记录,出问题很难追溯。

使用配置中心可以直接解决以上问题,可配置内容包括数据库连接、业务参数等。配置中心就是一个Web服务,配置人员通过后台页面修改配置,各个服务就会得到新的配置参数。

其实现方式主要有两种:Push和Pull。这两种方式各有优缺点:Push实时性较好,但是遇到网络抖动时会丢失消息;Pull不会丢失消息,但是其实时性差一些。

服务编排与弹性伸缩

将应用拆分后,微服务就会非常多,因此需要服务编排来管理微服务之间的依赖关系,以及将微服务的部署代码化,也就是Infrastructure as Code(基础设施即代码)。这样一来,服务的发布、更新、回滚、扩容、缩容等都可以通过修改编排文件来实现,从而增加了可追溯性、易管理性和自动化的能力。既然编排文件也可以用代码仓库进行管理,那么就可以实现部分升级。

编排一般分为资源编排和服务编排两类。资源编排定义所需的物理资源(如主机、CPU、内存、VPC、路由表、磁盘等),其对应Infrastructure as Code。服务编排以服务为中心,定义服务的弹性伸缩、灰度发布、滚动升级、资源配置等功能组合,其对应Application as Code。具体来说,编排包括批量部署、优雅启停、弹性伸缩。

流量管控

当微服务数量越来越多时,需要一种服务治理机制对所有微服务进行统一管控,保障微服务的正常运行。微服务治理覆盖整个生命周期,从微服务建模、开发、测试、审批、发布到运行时的管理及下线。而微服务中的服务治理主要是指运行时的治理,除了前面所讲的配置、健康检查等,还包括熔断、限流、降级等流量管控。
熔断:是指一个远程微服务调用在连续失败次数超过指定的阈值后的一段时间内会拒绝其他调用。例如,Spring Cloud的Hystrix就为保护服务依赖提供了熔断机制的开源库。
限流:通过全链路的压力测试,应该能够知道整个应用的支撑能力,因此制定了限流策略,保证应用处理请求处于其支撑能力范围内,超出其支撑能力范围的请求处理可被拒绝。例如,使用下单服务时弹出对话框,显示“系统忙,请重试”,这并不代表下单应用停止服务了,而是限流策略起到了作用。
降级:是指当发现整个应用服务负载过高时,可以选择降级某些功能来保证最重要的交易流程正常工作,以及最重要的资源全部用于保证最核心的流程。假设服务A依赖服务B和服务C,而服务B和服务C可能又依赖其他服务,继续下去会使得调用链路过长。如果在服务A后续的链路上某个或某几个被调用的微服务不可用或者延迟较高,则会导致调用服务A的请求被堵住。被堵住的请求会占用系统的线程、I/O等资源,当该类请求越来越多时,占用的资源就会越来越多,从而导致系统出现瓶颈,造成其他请求同样不可用,最终导致业务应用崩溃,所以应当及时将服务A降级。


在分布式微服务应用中,当一个微服务企图调用另一个微服务发送同步请求时,会面临着局部故障的风险。局部故障会导致客户端一直处于等待响应状态,从而造成访问阻塞,进而影响整个应用的可用性。当一个微服务调用另一个微服务超时时,应该及时返回而非阻塞在那里,避免影响其他微服务。当一个微服务发现被调用的微服务因过于繁忙、线程池满、连接池满或总是出错时,应该及时熔断,防止下一个微服务错误或繁忙导致本服务不正常,进而逐渐往前传导导致整个应用崩溃。

可观察运维 

 

标签:dubbo,调用,服务,spring,配置,编排,Spring,cloud,客户端
From: https://www.cnblogs.com/muzinan110/p/16915365.html

相关文章

  • 如何用App实现巡检业务数字化?以YonBuilder移动开发平台APICloud为例
    巡检是企事业单位的常见场景之一,以消防检查为例,秋冬季节气温下降、生产繁忙,用火、用电、用气情况大量增加,消防安全事件多发,一款消防检查app可以有效减少繁复工作、提升巡......
  • 关于Springboot大文件上传
    ​ 第一点:Java代码实现文件上传FormFilefile=manform.getFile();StringnewfileName= null;Stringnewpathname= null;StringfileAddre= "/numUp";try{......
  • spring文件上传大小限制,Springboot大于一1G文件上传
    ​前言一、SpringMVC简介1.1、SpringMVC引言为了使Spring有可插入的MVC架构,SpringFrameWork在Spring基础上开发SpringMVC框架,从而在使用Spring进行WEB开发时可以......
  • 2流高手速成记(之九):基于SpringCloudGateway实现服务网关功能
    咱们接上回 上一节我们基于Sentinel实现了微服务体系下的限流和熔断,使得整个微服务架构的安全性和稳定性上升了一个台阶篇尾我们引出了一个问题,众多的微服务节点,我们如......
  • 【Mybatis学习总结九】Spring中集成Mybatis
    学习了Mybatis的基本内容后,现在最重要的内容莫过于是在Spring中集成Mybatis了。好处之一就是不用再单独配置Mybatis-config.xml文件了(含有数据库连接池和配置类名以及注册......
  • 用Spring工厂实例化对象
    如何导入spring相关包,以及基本的配置及应用spring工厂spring的作用有多大,它代表的不仅仅是spring框架本身,在前辈的更新下,已经能无脑支持structs,mybatis,hibernate等各种......
  • Spring Boot Admin 入门及配置
    什么是SpringBootAdmin?SpringBootAdmin是一个管理和监控SpringBoot应用的社区项目。创建SpringBootAdminServer要做到这一点,只需创建一个简单的SpringBo......
  • springboot的@EnableAutoConfigurationProperties注解
    一、创建一个springboot工程添加依赖,编写启动类,二、使用@Component注解让@ConfigurationProperties注解生效,从而完成配置文件与javaBean的数据绑定1、配置文件zs.nam......
  • Java:Spring Boot整合mybatis-plus示例
    文档https://start.spring.io/mybatis-plus文档|githubmaven文档p6spy文档|github使用示例(目录)项目结构$tree-Itarget.├──pom.xml└──src......
  • SpringMVC
    SpringMVCDispatcherServlet<servlet>    <servlet-name>springMVC</servlet-name>    <servlet-class>org.springframework.web.servlet.DispatcherSe......