集群配置(nacos伪集群)
1.复制nacos重命名
data:image/s3,"s3://crabby-images/0ed3d/0ed3d0381c260f36aa856f79f630266b48eb0213" alt=""
2.修改配置文件
修改端口号
data:image/s3,"s3://crabby-images/974d2/974d21f5dc90639d24420bbc6599d2611ef33cdd" alt=""
3.配置cluster.conf
data:image/s3,"s3://crabby-images/3612c/3612c4170ed90e10d7151ac2f2d19d207b80e16a" alt=""
data:image/s3,"s3://crabby-images/e2d40/e2d400ea9f17238630a039cb136240bb14dd643a" alt=""
4.导入数据源
data:image/s3,"s3://crabby-images/4003e/4003e3b1b5894ebd1ae4f52b7d23224e4d92330b" alt=""
5.连接数据库
data:image/s3,"s3://crabby-images/ad934/ad9349ff037f110d7131044d15bddfea4a52e0cf" alt=""
6.启动
data:image/s3,"s3://crabby-images/3ac66/3ac6643b1b10455407c4f0d38ef0ffcae931b2f5" alt=""
访问
data:image/s3,"s3://crabby-images/5d22c/5d22cef9e9951eeecfe90810dc4f2f6d4da5616d" alt=""
7.反向代理
启动nginx
data:image/s3,"s3://crabby-images/6b73b/6b73b9c49a683d62a401646b1fe16c8aa1990ad5" alt=""
修改配置文件
data:image/s3,"s3://crabby-images/99ed0/99ed0acebb8a735a5a575be11ef69a9faff6bf07" alt=""
8.注册到集群
修改配置文件
data:image/s3,"s3://crabby-images/16b4e/16b4eccf5508d017a163339c8c960f72a3063d8e" alt=""
启动项目 访问nacos
data:image/s3,"s3://crabby-images/a4f1e/a4f1e176109709f09e6787cf961e9aa6cbcf23d4" alt=""
服务雪崩
假设存在如下调用链
1000
1000
500
data:image/s3,"s3://crabby-images/8cfbc/8cfbca5e3c48aa324e86d3eff075ea9c8362e34d" alt=""
而此时,Service A的流量波动很大,流量经常会突然性增加!那么在这种情况下,就算Service A能扛得住请求,Service B和Service C未必能扛得住这突发的请求。
此时,如果Service C因为抗不住请求,变得不可用。那么Service B的请求也会阻塞,慢慢耗尽Service B的线程资源,Service B就会变得不可用。紧接着,Service A也会不可用,这一过程如下图所示
data:image/s3,"s3://crabby-images/b677a/b677af214c54b0ddab3bbc85d9660fdcf8f3cba1" alt=""
如上图所示,由于服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是 服务故障的 "雪崩效应" 。
那么,服务熔断和服务降级就可以视为解决服务雪崩的手段之一。
熔断
在互联网系统中,当下游服务因访问压力过大而响应变慢或失败,上游服务为了保护系统整 体的可用性,可以暂时切断对下游服务的调用。这种牺牲局部,保全整体的措施就叫做熔断。
data:image/s3,"s3://crabby-images/edf33/edf33fa98e454638dd4e320f3086cc067d3e7b31" alt=""
服务熔断一般有三种状态:
熔断关闭状态(Closed)
a->b ->c
服务没有故障时,熔断器所处的状态,对调用方的调用不做任何限制
熔断开启状态(Open)
a->b->c(x)
a->b
后续对该服务接口的调用不再经过网络,直接执行本地的fallback方法
半熔断状态(Half-Open)
c
尝试恢复服务调用,允许有限的流量调用该服务,并监控调用成功率。如果成功率达到预 期,则说明服务已恢复,进入熔断关闭状态;如果成功率仍旧很低,则重新进入熔断关闭状态
降级
降级其实就是为服务提供一个备用方案,一旦服务无法正常调用,就使用备用方案
data:image/s3,"s3://crabby-images/f3067/f306735559467aaf4241d3e5727b63dc58513773" alt=""
常见的容错组件
Hystrix
Hystrix是由Netflix开源的一个延迟和容错库,用于隔离访问远程系统、服务或者第三方库,防止 级联失败,从而提升系统的可用性与容错性。
Resilience4J
Resilicence4J一款非常轻量、简单,并且文档非常清晰、丰富的熔断工具,这也是Hystrix官方推 荐的替代产品。不仅如此,Resilicence4j还原生支持Spring Boot 1.x/2.x,而且监控也支持和 prometheus等多款主流产品进行整合。
Sentinel
Sentinel 是阿里巴巴开源的一款断路器实现,本身在阿里内部已经被大规模采用,非常稳定
data:image/s3,"s3://crabby-images/7210f/7210f2dfbe7c186eae28fc5a6457113d83686bea" alt=""
Sentinel
1.Sentinel入门
https://github.com/alibaba/Sentinel/wiki/%E4%BB%8B%E7%BB%8D
Sentinel (分布式系统的流量防卫兵) 是阿里开源的一套用于服务容错 的综合性解决方案。它以流量为切入点, 从流量控制、熔断降级、系统负载保护等多个维度来保护服务的稳定性。
Sentinel 具有以下特征:
丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景, 例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。
完备的实时监控:Sentinel 提供了实时的监控功能。通过控制台可以看到接入应用的单台机器秒级数据, 甚至 500 台以下规模的集群的汇总运行情况。
广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架/库的整合模块, 例如与 Spring Cloud、Dubbo、gRPC 的整合。只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。
完善的 SPI 扩展点:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口快
速地定制逻辑。例如定制规则管理、适配动态数据源等
Sentinel 分为两个部分:
核心库(Java 客户端)不依赖任何框架/库,能够运行于所有 Java 运行时环境,同时对 Dubbo /Spring Cloud 等框架也有较好的支持。
控制台(Dashboard)基于 Spring Boot 开发,打包后可以直接运行,不需要额外的 Tomcat 等应用容器。
2.微服务集成Sentinel
1)添加jar
为微服务集成Sentinel非常简单, 只需要加入Sentinel的依赖即可
在pom.xml中加入下面依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
2) 编写消费者的controller并调用
@RestController
@RequestMapping("test")
public class TestController {
@GetMapping
public String aaaa(){
return "hahaha";
}
}
data:image/s3,"s3://crabby-images/c15f3/c15f3e75169770cba639d6d025df7dab61ea2ca6" alt=""
2.安装Sentinel控制台
1) 下载jar包,解压到文件夹
https://github.com/alibaba/Sentinel/releases/tag/1.8.1
2)启动
java -Dserver.port=8888 -Dcsp.sentinel.dashboard.server=localhost:8888 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.1.jar
data:image/s3,"s3://crabby-images/d9656/d965622d098f727d7938a754d7df3c0a28dd1603" alt=""
访问页面
输入localhost:8888 进入控制台
data:image/s3,"s3://crabby-images/4cc6f/4cc6f72774746d34c0d55dfd253e0616292fdec3" alt=""
3) 修改 product ,在里面加入有关控制台的配置
spring.cloud.sentinel.transport.port=9999
# 该端口号为sentinal于服务之间的交互 随便写只要不被占用
spring.cloud.sentinel.transport.dashboard=localhost:8888
#sentinal服务所在的地址和端口号
8081与8080交互
3.实现接口的限流
设置流控规则
data:image/s3,"s3://crabby-images/0ed25/0ed25c74ea9b786b67f9dd6024d7f3ae220a0e5f" alt=""
一秒内访问次数大于1
data:image/s3,"s3://crabby-images/7fe47/7fe47a7692da767afb7be4ff4d5f85f282304cc6" alt=""
4.自定义先流的异常处理
新建配置文件
data:image/s3,"s3://crabby-images/985da/985da77984ad958214df91aa129414959cf22c58" alt=""
访问 重启项目后要重新配置流控规则
data:image/s3,"s3://crabby-images/acf97/acf97cd5ebcf347ec72333e234d2fab48ee875b9" alt=""
5.关联流控模式
控流模式
sentinel共有三种流控模式,分别是:
l 直接(默认):接口达到限流条件时,开启限流
l 关联:当关联的资源达到限流条件时,开启限流 [适合做应用让步]
l 链路:当从某个接口过来的资源达到限流条件时,开启限流
data:image/s3,"s3://crabby-images/1299e/1299ec0fe9bec65b662d0b469b97a21a30d425c8" alt=""
data:image/s3,"s3://crabby-images/6d49d/6d49dafe6d743ff3a72545a50d731ecab3ddfc0a" alt=""
6.链路流控模式
链路流控模式
链路流控模式指的是,当从某个接口过来的资源达到限流条件时,开启限流**。**
注解:@SentinelResource
我们可以对某一个方法进行限流控制,无论是谁在何处调用了它,这里需要使用到@SentinelResource
,一旦方法被标注,那么就会进行监控@SentinelResource
,一旦方法被标注,那么就会进行监控。
创建测试资源
data:image/s3,"s3://crabby-images/29229/2922934d3459c3236f4438fec33ced8162a279f1" alt=""
data:image/s3,"s3://crabby-images/c91e3/c91e3644e6dbf4f81a6a06fef9a4cff5a2ca6000" alt=""
配置 禁止收敛URL的入口 context
在application.properties中添加:
spring.cloud.sentinel.web-context-unify=false
data:image/s3,"s3://crabby-images/4ec63/4ec6352735737af28c97dc57054e859cfcdd00c9" alt=""
data:image/s3,"s3://crabby-images/78c88/78c88e20de2238630974c2abdccaab6afa829fe7" alt=""
自定义限流
创建工具类
data:image/s3,"s3://crabby-images/d29c0/d29c0225bf7d40218386915427e89231bc5744b4" alt=""
public static Result handler(BlockException e){
return new Result(500,"限流了","heiheihei");
}
data:image/s3,"s3://crabby-images/3dfa4/3dfa4b3c91f66fec82d2ff48a827dd20affe7cf6" alt=""
data:image/s3,"s3://crabby-images/819ef/819ef42e94d894d8e75d71128a6e1f2e5ed81147" alt=""
设置流控规则
data:image/s3,"s3://crabby-images/462e9/462e93db3df174643520760a7da7ec944e5d566d" alt=""
data:image/s3,"s3://crabby-images/4789e/4789e775c5a8080c9d99ce848c176febb4187447" alt=""