Sentinel控制台的功能主要包括:流量控制、降级控制、热点配置、系统规则和授权规则等

# 安装sentinel的控制台

## 下载地址
Sentinel控制台下载地址:

  https://github.com/alibaba/Sentinel/releases
  版本自己选择

# 启动控制台
到sentinel所在的目录运行下面的命令:
  java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-版本号.jar
启动之后访问localhost:8080;登录即可用户名和密码默认是sentinel

登录之后看到左侧的菜单只有默认的一个;因为现在sentinel还没有发现其他机器

# 客户端搭建--sc

基于spring-cloud的项目来搭建一个sentinel客户端

1、加入spring-cloud的sentinel依赖

```
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
```

2、建立一个controller

    package com.shadow.web;

    import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController; @RestController
public class UserController { @GetMapping("login")
public String login() throws InterruptedException {
System.out.println("login----");
return "success";
} @GetMapping("log")
public String log(){
System.out.println("log----");
return "success";
} }

3、yml配置

```
server:
port: 9000
spring:
application:
name: register-server
sentinel:
transport:
port: 8719 #如果加了客户端他就会开启一个 http server 为了dashboard 能够发过来
dashboard: localhost:8080
```

spring.cloud.sentinel.transport.dashboard——sentinel控制台的ip和端口地址

spring.cloud.sentinel.transport.port——sentinel客户端和控制台通信的端口

然后启动项目;继而访问localhost:8080/login;跟着刷新sentinel的控制台可以看到sentinel已经发现了我们的项目server-register

并且可以在簇点链路中看到刚刚那个请求

接下来就对这个请求进行流控、降级、授权、热点等配置等等配置了;先来介绍如何添加流控吧;点击+流控的按钮

怎么配置呢?首先了解这概念吧

# sentinel 术语
1、资源:标识资源的唯一名称,springboot项目默认为controller当中的请求路径,也可以在客户端中使用SentinelResource配置;比如你有个service当中的xx方法;你想对这个xx方法进行流控那么这个xx方法必须是一个资源;

2、针对来源:Sentinel可以针对服务调用者进行限流,填写微服务名称即spring.application.name,默认为default,不区分来源

3、阈值类型、单机阈值

QPS——每秒钟的请求数量,当调用该资源的QPS达到阈值的时候,进行限流;
线程数——当调用该资源的线程数达到阈值的时候,进行限流

4、是否集群:默认不集群;

5、流控模式:

直接:当资源调用达到限流条件的时,直接限流;
关联:当关联的资源请求达到阈值的时候,限流自己;
链路:下节课说

6、流控效果:

快速失败:直接失败;
Warm Up:根据冷加载因子默认值为3的值,从阈值/3,经过预热时长,才达到设置的QPS阈值;
排队等待:匀速排队,让请求匀速通过,阈值类型必须设置为QPS,否则无效

# QPS直接失败

上面设置的效果是,1秒钟内请求/login资源的次数达到1次以上的时候,进行限流

## 效果演示
首先一秒请求一次login没有问题;然后发挥你手速;一秒超过一次之后页面返回Blocked by Sentinel (flow limiting);如果手速不够多练练吧——总归有办法的

....

# 线程数直接失败

把login方法让其睡眠一秒;因为无论你单身多少年;你的手速不可能超过计算机;所以在刷新的情况下永远只有一个线程;如果让他睡眠1秒;这样就能模拟出来服务器这边开多个线程来处理的场景了;

```
@GetMapping("login")
public String login() throws InterruptedException {
System.out.println("login----");
Thread.sleep(1000);
return "success";
}
```

改完之后重启你的项目,然后先访问一次login;因为你重启之后sentinel控制台这边就检测不到了;需要重新访问一次;跟着添加流控规则

## 效果演示
首先慢慢刷新login请求;——等睡眠时间过;服务器永远只有一个线程,发觉没问题;但是你疯狂在地址栏里面点击回车(注意不要去刷新,因为刷新是会等到服务器返回之后才能点击;所以效果演示不出来,最好是点击回车在地址栏)就会失败

...

# 流控模式关联

首先把login方法当中的睡眠删除;然后重启项目,访问一下login;继而去配置流控规则

上述配置当1秒内访问/log的次数大于2的时候,限流/login

效果演示使用postman来密集访问/log(QPS=3),然后我们手动浏览器请求/login,看看效果...。postman的如下图

## 效果演示

在外面没有启动postman的时候 访问login没有问题;当我们启动postman之后 log的qps达到了阈值;这个时候再去访问login 被限流了、、、

# 预热Warm Up

Warm Up——预热/冷启动方式。当系统长期处于低访问量的情况下,流量突然增加时,可能瞬间把系统压垮。通过warm up方式,让通过的流量缓慢增加,在一定时间内逐渐增加到阈值上限,给冷系统一个预热的时间,避免问题

即请求QPS从 阈值 10/ 3 开始,经预热时长(10s)逐渐升至设定的QPS阈值(10)

## 效果演示
假设一开始我们疯狂刷新(让QPS大于3) 讲道理一般人的手速可以达到;你会看到被限流了;但是经过10s之后再也不会出错了;因为人的极限不可能1秒点到10次;如果哪位兄弟10s之后还能点击出现限流;请你私聊我。。。

限流效果图:

Sentinel使用的更多相关文章

  1. Redis集群~windows下搭建Sentinel环境及它对主从模式的实际意义

    回到目录 关于redis-sentinel出现的原因 Redis集群的主从模式有个最大的弊端,就是当主master挂了之前,它的slave从服务器无法提升为主,而在redis-sentinel出现之后 ...

  2. Redis Sentinel集群配置中的一些细节

    今天在配置Redis集群,用作Tomcat集群的缓存共享.关于Redis集群的配置网上有很多文章,这里只是记录一下我在配置过程中遇到的一些小的细节问题. 1. 关于Protected Mode的问题 ...

  3. redis 集群热备自动切换sentinel配置实战

    ---恢复内容开始--- Redis SentinelSentinel(哨兵)是用于监控redis集群中Master状态的工具,其已经被集成在redis2.4+的版本中一.Sentinel作用:1): ...

  4. Redis Sentinel 高可用实现说明

    背景:      前面介绍了Redis 复制.Sentinel的搭建和原理说明,通过这篇文章大致能了解Sentinel的原理和实现方法以及相关的搭建.这篇文章就针对Redis Sentinel的搭建做 ...

  5. Redis 复制、Sentinel的搭建和原理说明

    背景: Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,假如master宕机了,Redis本身(包括它的很多客户端) ...

  6. Redis Sentinel机制与用法说明【转】

    本文来自:https://segmentfault.com/a/1190000002680804 概述 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Ma ...

  7. 24.Redis2.8主从集群sentinel

    0.集群架构(此处只说两种;本文2种,避免sentinel成为单节点) 第一种: 第二种: 1.下载redis2.8.x版本,2.8.x都是稳定版 redis-2.8.24.tar.gz 2.解压,安 ...

  8. 基于sentinel 的redis集群环境搭建

    环境信息,三台机器,一台master,两台slave,每台机器上启动一个sentinel master 192.168.1.106 slave1 192.168.1.102 slave2 192.16 ...

  9. redis sentinel基本命令与参数

    1.redis基本命令1)获取sentinel的状态(1)info查看sentinel的状态(2)sentinel masters 获取sentinel中监控的所有master的节点(3)sentin ...

  10. Redis多机常用架构-sentinel

    哨兵经典架构 sentinel结构 哨兵工作原理 Sentinel 通过配置文件发现Master,如下: Sentinel 通过向Master发送 INFO 命令来自动获得所有Slave的地址 跟Ma ...

随机推荐

  1. Vue + ccropper.js裁切图片(vue-cropper)

    按原比例裁剪图片并且不失真. 安装: cnpm install vue-cropper --save-dev 使用: <template> <div style="disp ...

  2. 2020-06-27:ACID是什么?描述一下?

    福哥答案2020-06-27: 福哥口诀法:事原一隔持(事务属性ACID:原子性.一致性.隔离性.持久性) 用银行数据库来举例子解释一下这四个特性 原子性: 一个事务可能会包含多种操作,比如转账操作包 ...

  3. C#LeetCode刷题之#206-反转链表(Reverse Linked List)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3828 访问. 反转一个单链表. 输入: 1->2-> ...

  4. asp.net core跨平台--CentOS7.2部署asp.net core网站

    随着vs2015 2017的发布,.NETCore越来越流行了,我就尝试着做了个demo,在centos上试着运行了一下,中间遇到很多问题,不过最后还是成功运行,记录一下过程.废话不多说,直接开始: ...

  5. 高吞吐量消息系统—kafka

    现在基本上大数据的场景中都会有kafka的身影,那么为什么这些场景下要用kafka而不用其他传统的消息队列呢?例如rabbitmq.主要的原因是因为kafka天然的百万级TPS,以及它对接其他大数据组 ...

  6. JetCache埋点的骚操作,不服不行啊

    阐述背景 缓存是应对高并发绝对的利器,在很多业务场景允许的情况下,都可以使用缓存来提供性能. 既然用了缓存,那对缓存进行监控必不可少.比如缓存加载耗时,新增耗时等. 在 JetCache 中进行埋点操 ...

  7. linux root用户下没有.ssh目录

    .ssh 是记录密码信息的文件夹,如果没有登录过root的话,就没有 .ssh 文件夹,因此登录 localhost ,并输入密码就会生成了 ssh localhost

  8. Oracle和Mysql分页的区别

    一.Mysql使用limit分页 select * from stu limit m, n; //m = (startPage-1)*pageSize,n = pageSize PS: (1)第一个参 ...

  9. linux驱动之模块化编程

    今天刚开始学习linux驱动的编写.在网上开了许多网友的博客,感觉比较好的摘抄下来,以便以后忘记可以随时查看.下面是摘抄文章的地址,非常感谢他们. http://blog.chinaunix.net/ ...

  10. Airtest操作多台云手机,进行分发,多个脚本后端调度

    一.核心重点 使用python后端框架:tornado 调度:redis队列 存手机的class_name采取头取尾曾 多台手机连接方式 connect_device(f"Android:/ ...