sentinel学习(1)——基础使用

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);
    }
}

基础使用就讲到这里,下一章节开始讲解源码。

### C++ 中 `explicit` 关键字的作用和用法 #### 单参数构造函数中的使用 在C++中,`explicit`关键字主要用于防止编译器执行不必要的隐式类型转换。当定义了一个只接受单一参数的构造函数时,如果不加`explicit`修饰,则该构造函数可以被用来实现从其参数类型的对象到类类型的隐式转换。这可能会导致一些难以察觉的错误。 通过声明为`explicit`,能够阻止这些潜在危险的行为发生,使得只有显式的强制转换才能触发此类构造过程[^1]: ```cpp class MyClass { public: // 不带 explicit 的构造函数允许隐式转换 MyClass(int value); }; void func(MyClass obj); int main() { int num = 5; // 下面这一行会因为存在无参构造而成功编译并运行, // 导致意料之外的对象创建行为。 func(num); } ``` 如果我们将上述例子中的构造函数改为带有`explicit`的关键字形式: ```cpp class MyClass { public: // 带有 explicit 的构造函数不允许隐式转换 explicit MyClass(int value); }; ``` 此时再尝试传递整数给期望接收`MyClass`实例的地方将会引发编译期报错,除非程序员明确指定了类型转换操作。 #### 转换运算符上的应用 除了应用于单个参数的构造函数外,`explicit`也可以标注于用户自定义类型之间的转换运算符上。同样地,这样做是为了避免不希望发生的自动转型情况的发生: ```cpp class IntWrapper { private: int m_value; public: // 显式指定此转换仅能由显示转换完成 explicit operator bool() const noexcept { return static_cast<bool>(m_value); } }; ``` 在这个案例里,即使有一个布尔上下文环境(比如条件判断),也不会让`IntWrapper`对象直接参与逻辑表达式的求值;相反,必须采用静态或动态方式来实施必要的转变动作。 关于多参数构造的情况,并不在`explicit`的应用范围内,因此对于这种情况下的处理方法并不涉及`explicit`关键字本身[^2]。然而值得注意的是,在某些版本之后的标准库支持下,可以通过大括号语法来进行初始化列表风格的新建工作,但这属于另一个话题了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值