SpringCloud学习笔记(十一、SpringCloud总结)
SpringCloud Config:
1、动态刷新配置:通过job调用Set<String> keys = contextRefresher.refresh()这段代码即可。
2、如何实现自定义健康检查:重写AbstractHealthIndicator的doHealthCheck方法就可以了。
详见:https://www.cnblogs.com/bzfsdr/p/11589902.html
SpringCloud Netflix Eureka:
1、服务发现:服务发现分为两种模式,其主要区别在于主逻辑在谁那判断。
- 客户端模式:调用其它服务时首先去注册中心获取服务列表,并且在本地缓存一份,然后根据客户端自身的负载均衡策略进行服务调用。
- 服务端模式:调用其它服务时直接向注册中心发起请求,注册中心根据自身负载均衡策略进行服务调用,而客户端不需要维护服务发现逻辑。
2、服务发现两种模式的比较:
- 客户端模式:如Eureka。
- 由于服务列表会在本地缓存一份,所以在调用服务时会减少一次链路的调用;但每个客户端都需要维护自身的服务列表。
- 可用性高;因为有本地缓存,所以即使注册中心宕机了也不会影响服务间的正常使用。
- 服务端上下线时客户端会出现短暂的调用失败。
- 服务端模式:如Zookeeper。
- 使用简单,客户端无需维护服务列表。
- 可用性取决于注册中心,若注册中心发生故障则所有的服务都不可用;同时所有的存储和调用工作都由注册中心完成,这样的话注册中心的负载过高。
- 服务端上下线时客户端无感知。
3、Eureka高可用:
我们都知道Eureka分为服务端和客户端,所以搭建高可用的Eureka时二者都需要高可用。
a、服务端:
服务端的高可用其实就是让客户端获取服务列表时尽可能的少失败,所以我们只需要启动两个或多个Eureka Server,让他们相互复制服务列表即可。
1 server.port=9091
2 eureka.client.service-url.defaultZone=http://localhost:9092/eureka
1 server.port=9092
2 eureka.client.service-url.defaultZone=http://localhost:9091/eureka
b、客户端
客户端的高可用就是在获取服务列表时尽可能的少失败,所以我们只需要配置多个注册中心即可。
eureka.client.service-url.defaultZone=http://localhost:9091/eureka,http://localhost:9092/eureka
4、Eureka原理:
- 默认30秒,eureka client定期拉取eureka server服务列表配置。
- 服务的上下线eureka server会通知订阅了的eureka client更新服务列表,并且还会通知其它的eureka server。
- eureka client默认30秒向eureka server发送心跳,而eureka server会在90秒将未发送心跳的eureka client下线,并通知eureka client、eureka server。
eureka server保护机制:因eureka server可能会因为网络问题收不到其它服务心跳,所以eureka server并不会盲目的将服务下线。
eureka server保护规则:计算一定时间内是否有85%的服务都没有发送心跳,如果是则进入保护机制,此段时间内eureka server会正常的接受注册、查询服务,但不会将数据通知到eureka client和其它的eureka server,这样就不会误杀了。
SpringCloud Ribbon:
重构造一个新的基于rest风格的RestTemplate,这样调用服务是便能实现负载均衡了。
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
配置properties:
## 局部配置-- 单独制定客户端(eureka-provider客户端)
eureka-provider.ribbon.listOfServers=localhost:8072,localhost:8073
配置格式:<clientName>.<nameSpace>.<propertyName>=<value>
propertyName见com.netflix.client.config.CommonClientConfigKey
SpringCloud Hystrix:
Hystrix是一款开源的分布式容错和延迟库,目的是隔离分布式服务的故障。它还提供了优雅的降级和熔断的实现方式,使服务能够快速的失败,并且能从失败中快速的恢复。
1、Hystrix解决的问题:
- 通过线程隔离和信号量实现了限制分布式服务资源的使用,当一个服务有问题时不会影响其它服务。
- 优雅的降级机制(超时、资源不足是降级),降级后可返回托底数据。
- 优化的熔断机制,失败率达到阀值自动降级,并且可以快速恢复。
- 提供了请求合并和请求缓存。
2、线程隔离:将Tomcat请求的任务转交给自己内部的线程来执行,这样Tomcat便可以响应更多的请求,内部线程执行完后再将结果转交给Tomcat。
3、信号量隔离:与线程隔离类似,但不同的是信号量隔离是内部程序限流。
4、线程隔离与信号量隔离区别:
线程池 |
信号量 |
|
线程 |
与调度线程非同一线程 |
与调度线程是同一线程 |
开销 |
排队、调度、上下文切换等开销 |
无线程切换,开销低 |
异步 |
支持 |
不支持 |
并发支持 |
支持(由线程池大小决定) |
支持(由信号量大小决定) |
注意:服务熔断必须满足时间、请求数、失败比例三个条件才会触发断路器。
SpringCloud Feign:
Feign是一款开源的声明式、模板化的HTTP客户端,它可以更加便捷、优雅的调用HTTP API;而SpringCloud Feign是对Netflix Feign的增强,使其支持Ribbon、Eureka。
使用时只需要定义接口、加上扫描接口注解@EnableFeignClients(basePackages = {"com.xxx.xxx"}),并像调用方法一样调用接口就可以了。
SpringCloud Zuul:
Zuul是Netflix开源的网关,主要用于路由和过滤。
它还是基于JVM的路由器和负载均衡器,所以它的规则引擎允许使用任何JVM语言编写,如java、groovy。
1、Zuul作用:
- 日志
- 压力测试
- 动态路由
- 安全认证
- 等等
2、Zuul请求生命周期:
- pre:在请求转发前处理请求,如日志、请求校验等。
- route:将请求转发到具体的服务提供方。
- post:在接收到服务提供方的返回结果后做的一些处理,如数据加工、内容转换等等(数据脱敏)。
- error:当请求发生异常时启用error过滤器。
3、自定义Zuul过滤器
package com.jdr.maven.sc.integration.zuul.filter; import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.exception.ZuulException;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.stereotype.Component; import static org.springframework.cloud.netflix.zuul.filters.support.FilterConstants.PRE_TYPE; /**
* @author zhoude
* @date 2019/10/20 9:44
*/
@Component
@RefreshScope
public class LogFilter extends ZuulFilter { @Value("${zuul.log-name}")
private String logName; /**
* 过滤器类型
*
* @return pre、route、post、err
*/
@Override
public String filterType() {
return PRE_TYPE;
} /**
* 过滤器执行顺序,越小越先执行
*
* @return 执行序列
*/
@Override
public int filterOrder() {
return 0;
} /**
* 是否应该过滤(此函数可以增加一些开关的逻辑,来达到动态控制)
*
* @return true-应该执行过滤,false-不应该执行过滤
*/
@Override
public boolean shouldFilter() {
return true;
} /**
* 过滤器具体执行逻辑
*
* @return target
* @throws ZuulException 执行发生异常时抛出ZuulException
*/
@Override
public Object run() throws ZuulException {
System.err.println("这是日志" + logName);
return null;
}
}
SpringCloud Bus:
SpringCloud Bus是一个分布式执行器,它可以作为应用程序间的通信通道,如系统状态变更时的广播(配置变更)。
SpringCloud学习笔记(十一、SpringCloud总结)的更多相关文章
- SpringCloud学习笔记:SpringCloud简介(1)
1. 微服务 微服务具有的特点: ◊ 按照业务划分服务 ◊ 每个微服务都有独立的基础组件,如:数据库.缓存等,且运行在独立的进程中: ◊ 微服务之间的通讯通过HTTP协议或者消息组件,具有容错能力: ...
- SpringCloud学习笔记(2):使用Ribbon负载均衡
简介 Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡工具,在注册中心对Ribbon客户端进行注册后,Ribbon可以基于某种负载均衡算法,如轮询(默认 ...
- SpringCloud学习笔记(3):使用Feign实现声明式服务调用
简介 Feign是一个声明式的Web Service客户端,它简化了Web服务客户端的编写操作,相对于Ribbon+RestTemplate的方式,开发者只需通过简单的接口和注解来调用HTTP API ...
- SpringCloud学习笔记(4):Hystrix容错机制
简介 在微服务架构中,微服务之间的依赖关系错综复杂,难免的某些服务会出现故障,导致服务调用方出现远程调度的线程阻塞.在高负载的场景下,如果不做任何处理,可能会引起级联故障,导致服务调用方的资源耗尽甚至 ...
- SpringCloud学习笔记(5):Hystrix Dashboard可视化监控数据
简介 上篇文章中讲了使用Hystrix实现容错,除此之外,Hystrix还提供了近乎实时的监控.本文将介绍如何进行服务监控以及使用Hystrix Dashboard来让监控数据图形化. 项目介绍 sc ...
- SpringCloud学习笔记(6):使用Zuul构建服务网关
简介 Zuul是Netflix提供的一个开源的API网关服务器,SpringCloud对Zuul进行了整合和增强.服务网关Zuul聚合了所有微服务接口,并统一对外暴露,外部客户端只需与服务网关交互即可 ...
- SpringCloud学习笔记(7):使用Spring Cloud Config配置中心
简介 Spring Cloud Config为分布式系统中的外部化配置提供了服务器端和客户端支持,服务器端统一管理所有配置文件,客户端在启动时从服务端获取配置信息.服务器端有多种配置方式,如将配置文件 ...
- SpringCloud学习笔记:服务支撑组件
SpringCloud学习笔记:服务支撑组件 服务支撑组件 在微服务的演进过程中,为了最大化利用微服务的优势,保障系统的高可用性,需要通过一些服务支撑组件来协助服务间有效的协作.各个服务支撑组件的原理 ...
- python3.4学习笔记(十一) 列表、数组实例
python3.4学习笔记(十一) 列表.数组实例 #python列表,数组类型要相同,python不需要指定数据类型,可以把各种类型打包进去#python列表可以包含整数,浮点数,字符串,对象#创建 ...
- Go语言学习笔记十一: 切片(slice)
Go语言学习笔记十一: 切片(slice) 切片这个概念我是从python语言中学到的,当时感觉这个东西真的比较好用.不像java语言写起来就比较繁琐.不过我觉得未来java语法也会支持的. 定义切片 ...
随机推荐
- 学好linux必须精通用户管理的章节知识
第12章 Linux中用户知识管理 12.1 系统开机启动流程 12.1.1 centos6系统开机启动流程 12.1.1.1 开机系统流程语言描述 服务器电源开关打开 bios自检 目的:检查硬件是 ...
- 深入学习 OLED Adafruit_SSD1306库(8266+arduino)
QQ技术互动交流群:ESP8266&32 物联网开发 群号622368884,不喜勿喷 单片机菜鸟博哥CSDN 1.前言 SSD1306屏幕驱动库,最出名应该就是u8g2,读者可以参考 玩转u ...
- LNMP-Nginx配置不记录静态文件、过期时间
用户访问web网站,通常日志文件会记录很多web站点上的一些静态文件信息,如果长期不处理,日志文件会越来越大,占用的系统资源也越大,此时就需要我们配置不记录静态文件和过期时间,减少日志文件记录过多不必 ...
- ES6中export default与export的区别
1.export default 和export都可以用于导出常量,函数,文件,模块等: 2.可以在模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使 ...
- 【Java必修课】图说Stream中的skip()和limit()方法及组合使用
1 简介 本文将讲解Java 8 Stream中的两个方法:skip()和limit().这两个方法是Stream很常用的,不仅各自会被高频使用,还可以组合出现,并能实现一些小功能,如subList和 ...
- (2019版本可用)Pycharm的安装,破解
前言 python的操作工具pycharm,是专门用来写python语言的. 因为之前在网上找到了,但是太麻烦了,所以整理整理. pycharm安装 官网可以选择下载(pycharm最新版有可能破解不 ...
- PDF提取表格的网页工具——Excalibur
在之前的文章另类爬虫:从PDF文件中爬取表格数据中,我们知道如何利用Python的camelot模块,通过写Python程序来提取PDF中的表格数据.本文我们将学习如何用更便捷的工具从PDF中提取 ...
- [ASP.NET Core 3框架揭秘] 依赖注入[7]:服务消费
包含服务注册信息的IServiceCollection集合最终被用来创建作为依赖注入容器的IServiceProvider对象.当需要消费某个服务实例的时候,我们只需要指定服务类型调用IService ...
- 从AlexNet(2012)开始
目录 写在前面 网络结构 创新点 其他有意思的点 参考 博客:blog.shinelee.me | 博客园 | CSDN 写在前面 本文重点在于回顾深度神经网络在CV领域的First Blood--A ...
- Linux服务器部署.Net Core笔记:一、开启ssh服务
开启ssh服务需要root权限,先用root账户登陆系统 在安装ssh前我们先更新一下yum:yum update 先检查有没有安装ssh服务:rpm -qa | grep ssh 如果没有安装ssh ...