基于@SentinelResource的规则错误优化

本文详细介绍了如何在Spring Boot项目中集成Sentinel流量控制和降级处理,包括配置dashboard地址、使用@SentinelResource注解,以及自定义URL阻塞处理。通过实例展示如何创建MyUrlBlockHandler处理不同类型的Sentinel异常,并在dashboard中测试规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 加配置

spring:
    sentinel:
      transport:
        dashboard: localhost:8080
      filter:
        enabled: true #使@SentinelResource 生效

2. 加@SentinelResource注解

    @GetMapping("/{id}")
    @SentinelResource("SentinelResource-ShareConroller-findById")
    public ShareDTO findById(@PathVariable("id") Integer id) {
        return this.shareService.findById(id);
    }

3.创建 MyUrlBlockHandler类


import com.alibaba.csp.sentinel.adapter.servlet.callback.UrlBlockHandler;
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.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Component
public class MyUrlBlockHandler implements UrlBlockHandler {
    @Override
    public void blocked(HttpServletRequest request, HttpServletResponse response, BlockException ex) throws IOException {
        ErrorMsg msg = null;
        if (ex instanceof FlowException) {
            msg = ErrorMsg.builder()
                    .status(100)
                    .msg("限流了")
                    .build();
        } else if (ex instanceof DegradeException) {
            msg = ErrorMsg.builder()
                    .status(101)
                    .msg("降级了")
                    .build();
        } else if (ex instanceof ParamFlowException) {
            msg = ErrorMsg.builder()
                    .status(102)
                    .msg("热点参数限流")
                    .build();
        } else if (ex instanceof SystemBlockException) {
            msg = ErrorMsg.builder()
                    .status(103)
                    .msg("系统规则(负载/...不满足要求)")
                    .build();
        } else if (ex instanceof AuthorityException) {
            msg = ErrorMsg.builder()
                    .status(104)
                    .msg("授权规则不通过")
                    .build();
        }
        // http状态码
        response.setStatus(500);
        response.setCharacterEncoding("utf-8");
        response.setHeader("Content-Type", "application/json;charset=utf-8");
        response.setContentType("application/json;charset=utf-8");
        // spring mvc自带的json操作工具,叫jackson
        new ObjectMapper()
                .writeValue(
                        response.getWriter(),
                        msg
                );
    }
}

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
class ErrorMsg {
    private Integer status;
    private String msg;
}

4.sentinelDashboard创建规则测试

### 关于 DubboZookeeper 的面试常见问题与解答 #### 1. Dubbo 是什么? Dubbo是一个高性能的 Java RPC 框架,广泛应用于分布式系统中的服务治理。它提供了透明化的远程过程调用方案,使得开发者可以像调用本地方法一样调用其他服务器上的资源[^2]。 #### 2. ZookeeperDubbo 中的作用是什么? Zookeeper作为注册中心,在Dubbo架构里扮演着至关重要的角色。所有的提供者启动时都会向Zookeeper注册自己的地址信息;而消费者则订阅这些数据变化以便动态获取最新的可用的服务列表。这样即使有新的节点加入集群或是旧有的实例失效,整个系统的正常运行也不会受到影响[^1]。 #### 3. 解释一下 Dubbo 的服务发现机制? 当一个应用想要消费另一个应用程序所提供的某项功能时,它并不需要知道具体哪个机器上部署了该服务以及它的网络位置等细节。相反地,只需要告诉中间件自己要访问哪一个逻辑名称所代表的服务即可。随后由Dubbo框架负责查询位于Zookeeper内的实际物理地址,并据此建立连接完成交互操作[^4]。 ```java // 注册服务示例代码 public class ServiceRegistry { public void register(String serviceName, String serviceAddress){ zkClient.create().creatingParentsIfNeeded() .withMode(CreateMode.EPHEMERAL) .forPath("/services/" + serviceName, serviceAddress.getBytes()); } } ``` #### 4. 如何理解 Dubbo 的负载均衡策略? 为了提高性能并增强可靠性,Dubbo内置了几种不同的算法来决定每次请求应该发送给哪一台工作机。比如随机选择(Random)、轮询(RoundRobin)或者是基于权重的比例分配(WeightedRandom)。 #### 5. Dubbo 支持哪些协议? 除了默认使用的 dubbo:// 协议外,还支持 http:// , hessian:// 等多种传输方式。每一种都有各自的特点适用于不同场景下的需求。 #### 6. Dubbo 的异步转同步是如何工作的? 在发起RPC调用的时候可以选择设置为async=true属性开启异步模式。这时客户端不会立刻阻塞等待结果返回而是继续执行后续逻辑直到接收到回调通知为止。而对于那些期望获得即时反馈的情况,则可以通过CompletableFuture对象手动触发同步行为从而达到目的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值