首先pom.xml里加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
<version>2.1.0.RELEASE</version>
</dependency>
application.yml,根据自己的改一改
server:
port: 84
spring:
application:
name: nacos-order-consumer
cloud:
nacos:
discovery:
server-addr: localhost:8848
sentinel:
enabled: true # 是否开启。默认为 true 开启
eager: true # 是否饥饿加载。默认为 false 关闭
transport:
dashboard: localhost:8080
port: 8179 #默认8179端口,假如被占用会自动从8179开始依次+1扫描,直至找到未被占用的端口
clientIp: 127.0.0.1
#消费者将要去访问的微服务名称
service-url:
nacos-server-service: http://nacos-payment-provider
nacos和sentinel都跑起来这里不多说了,能看到这儿肯定都知道怎么用了。
然后是关于@SentinelResource的用法,它容易报错的几个点这里说一下
1.两个方法都要用public不要用private,第一个方法不加会导致sentinel找不到getResult这个资源名,同样的第二个不加会导致sentinel找不到这个方法然后报错。
2.两个方法返回类型必须一样。
3.两个方法的参数类型必须一样,数量和参数类型要保持一致,注意第一个方法加了@PathVariable这个注解,这个只是url传参用的不需要加。
4.blockHandler的值必须与你的兜底方法,也就是第二个方法保持一致。
5.第二个方法必须要加BlockException这个异常类参数。
以上说的5点一定要注意,不然会导致@SentinelResource失效报错。
多点几次