SpringCloud-记

目录

什么是SpringCloud

什么是微服务

SpringCloud的优缺点

SpringBoot和SpringCloud的区别

RPC 的实现原理

RPC是什么

eureka的自我保护机制

Ribbon

feigin优点

Ribbon和Feign的区别


什么是SpringCloud

  • Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、智能路由、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。
  • Spring Cloud并没有重复制造轮子,它只是将各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

什么是微服务

微服务架构就是将单体的应用程序分成多个应用程序,这多个应用程序就成为微服务,每个微服务运行在自己的进程中,并使用轻量级的机制通信。这些服务围绕业务能力来划分,并通过自动化部署机制来独立部署。这些服务可以使用不同的编程语言,不同数据库,以保证最低限度的集中式管理。

SpringCloud的优缺点

优点

  • 耦合度比较低。不会影响其他模块的开发
  • 减轻团队的成本,可以并行开发,不用关注其他人怎么开发,先关注自己的开发
  • 配置比较简单,基本用注解就能实现,不用使用过多的配置文件
  • 微服务跨平台的,可以用任何一种语言开发
  • 每个微服务可以有自己的独立的数据库也有用公共的数据库
  • 直接写后端的代码,不用关注前端怎么开发,直接写自己的后端代码即可,然后暴露接口,通过组件进行服务通信。

缺点

  • 部署比较麻烦,给运维工程师带来一定的麻烦。
  • 针对数据的管理比麻烦,因为微服务可以每个微服务使用一个数据库。
  • 系统集成测试比较麻烦
  • 性能的监控比较麻烦

SpringBoot和SpringCloud的区别

SpringBoot专注于快速方便的开发单个个体微服务。

SpringCloud是关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务整合并管理起来。

为各个微服务之间提供,配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、决策竞选、分布式会话等等集成服务

SpringBoot可以离开SpringCloud独立使用开发项目, 但是SpringCloud离不开SpringBoot ,属于依赖的关系.

SpringBoot专注于快速、方便的开发单个微服务个体,SpringCloud关注全局的服务治理框架

RPC 的实现原理

首先需要有处理网络连接通讯的模块,负责连接建立、管理和消息的传输。其次需要有编/解码的模块,因为网络通讯都是传输的字节码,需要将我们使用的对象序列化和反序列化。剩下的就是客户端和服务器端的部分,服务器端暴露要开放的服务接口,客户调用服务接口的一个代理实现,这个代理实现负责收集数据、编码并传输给服务器然后等待结果返回。

RPC是什么

RPC 称远程过程调用(Remote Procedure Call),用于解决分布式系统中服务之间的调用问题。 通俗地讲,就是开发者能够像调用本地方法一样调用远程的服务。 所以,RPC的作用主要体现在这两个方面:

  • 屏蔽远程调用跟本地调用的区别,让我们感觉就是调用项目内的方法;
  • 隐藏底层网络通信的复杂性,让我们更专注于业务逻辑

eureka的自我保护机制

当Eureka Server 节点在短时间内丢失了过多实例的连接时(比如网络故障或频繁启动关闭客户端)节点会进入自我保护模式,保护注册信息,不再删除注册数据,故障恢复时,自动退出自我保护模式。

Ribbon

ribbon是一个负载均衡客户端,可以很好的控制htt和tcp的一些行为。feign默认集成了ribbon。

feigin优点

1.feign采用的是基于接口的注解

2.feign整合了ribbon,具有负载均衡的能力

3.整合了Hystrix,具有熔断的能力

使用:

1.添加pom依赖。

2.启动类添加@EnableFeignClients

3.定义一个接口 @FeignClient(name=“xxx”) 指定调用哪个服务

Ribbon和Feign的区别

1.Ribbon都是调用其他服务的,但方式不同。

2.启动类注解不同,Ribbon是@RibbonClient,feign 的是@EnableFeignClients

3.服务指定的位置不同,Ribbon是在@RibbonClient注解上声明,Feign 则是在定义抽象方法的接口中使用@FeignClient声明。

4.调用方式不同,Ribbon需要自己构建http 请求,模拟http请求


近日总结:大学女生宿舍小团体挺严重的,不止我的宿舍,光是听说到的就不计少数,我的舍友天天躺在宿舍,而我自己天天早出晚归学习,运动,锻炼身体......回到宿舍还要被阴阳怪气,还蛮影响心情的,还有些素质不太高的会趁你不在宿舍的时候动你的东西,给我心情都影响了...... 大学舍友真的做不了朋友......

相关推荐

  1. SpringCloud

    2024-03-23 20:22:02       49 阅读
  2. SpringCloud

    2024-03-23 20:22:02       56 阅读
  3. SpringCloud

    2024-03-23 20:22:02       55 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-23 20:22:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-23 20:22:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-23 20:22:02       82 阅读
  4. Python语言-面向对象

    2024-03-23 20:22:02       91 阅读

热门阅读

  1. server2016datacenter改正式版

    2024-03-23 20:22:02       37 阅读
  2. 苍穹外卖Day3碰到的元注解

    2024-03-23 20:22:02       43 阅读
  3. Eureka注册中心

    2024-03-23 20:22:02       40 阅读
  4. C语言经典面试题目(二十)

    2024-03-23 20:22:02       43 阅读
  5. python之exec与eval

    2024-03-23 20:22:02       46 阅读
  6. Acwing 104. 货仓选址

    2024-03-23 20:22:02       39 阅读
  7. MySQL 中的事务和存储引擎

    2024-03-23 20:22:02       36 阅读
  8. 基于单片机的机电控制实训平台设计

    2024-03-23 20:22:02       41 阅读
  9. git -- 提交规范

    2024-03-23 20:22:02       40 阅读
  10. ECS Fargate 上部署 SkyWalking UI 并通过 ALB 提供服务

    2024-03-23 20:22:02       35 阅读
  11. 如何从小白,到掌握Python

    2024-03-23 20:22:02       38 阅读