1:启动sentinel控制台
1.1: 下载sentinel的jar包 ,我的是 1.8.3。:https://github.com/alibaba/Sentinel/releases
1.2:启动jar包:https://github.com/alibaba/Sentinel/wiki/%E6%8E%A7%E5%88%B6%E5%8F%B0#2-%E5%90%AF%E5%8A%A8%E6%8E%A7%E5%88%B6%E5%8F%B0
1.3: 我这里的启动命令为: nohup java -Dserver.port=8888 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.3.jar &
1.4:后台访问: http://127.0.0.1:8888/ 默认账户 sentinel/sentinel
这个时候 是空白的页面,需要进行第二步的操作。
2:项目引入jar包
正常的springboot项目,自己引入alibaba相关的依赖后(具体看 nacos的文章,里面有相关的 Pom的引入,这里不重复),
在引入下面的pom。
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
spring:
cloud:
sentinel:
transport:
dashboard: 127.0.0.1:8888 #第一步的 地址。
配置好以后,启动自己的springboot的项目。然后调用一次接口,sentinel控制台 就会出现数据。
3:基础功能的使用
这里就可以在 这里 设置自己的规则,
例如:
当2个线程去请求后,后面一个线程就会报出异常:
这个异常信息 是自带的返回的信息。
那如果是要自定义 自己的异常信息返回:
自定义BlockExceptionHandler 的实现类统一处理BlockException:
下面是我自己的实现类:
package com.zr.spring.cloud.nacos.sentinel;
import com.alibaba.csp.sentinel.adapter.spring.webmvc.callback.BlockExceptionHandler;
import com.alibaba.csp.sentinel.slots.block.BlockException;
import com.alibaba.csp.sentinel.slots.block.authority.AuthorityException;
import com.alibaba.csp.sentinel.slots.block.degrade.DegradeException;
import com.alibaba.csp.sentinel.slots.block.flow.FlowException;
import com.alibaba.csp.sentinel.slots.block.flow.param.ParamFlowException;
import com.alibaba.csp.sentinel.slots.system.SystemBlockException;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Component;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@Slf4j
@Component
public class MySentinelException implements BlockExceptionHandler {
@Override
public void handle(HttpServletRequest httpServletRequest, HttpServletResponse response, BlockException e) throws Exception {
log.info("BlockExceptionHandler BlockException====, rult: {}", e.getRule());
String result = "";
if (e instanceof FlowException) {
result= "接口限流了";
} else if (e instanceof DegradeException) {
result="服务降级了";
} else if (e instanceof ParamFlowException) {
result="热点参数限流了";
} else if (e instanceof SystemBlockException) {
result= "触发系统保护规则了";
} else if (e instanceof AuthorityException) {
result= "授权规则不通过";
}
//返回json数据
response.setStatus(500);
response.setCharacterEncoding("utf-8");
response.setContentType(MediaType.APPLICATION_JSON_VALUE);
new ObjectMapper().writeValue(response.getWriter(), result);
}
}
基础使用就讲到这里,下一章节开始讲解源码。