在生产环境中使用 Sentinel
原创
©著作权归作者所有:来自51CTO博客作者gblfy的原创作品,请联系作者获取转载授权,否则将追究法律责任
data:image/s3,"s3://crabby-images/f969a/f969aa9376e335cd59424cc384a322e651180219" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper"
文章目录
分布式限流 Sentinel+Zookkeper
https://github.com/alibaba/Sentinel/wiki/在生产环境中使用-Sentinel
一、安装zookeeper
1. linux环境
data:image/s3,"s3://crabby-images/c5e61/c5e618985bfe5d58e6a4b768276eae9d9668606f" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper_02"
data:image/s3,"s3://crabby-images/e03b5/e03b564e8b669c98561baa0783ec1133a870792c" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_03"
注:这个zookeeper版本建议使用3.5.8,curator4.x对应zookeeper版本3.5.x
2. windows环境
将zoo_sample.cfg重命名zoo.cfg:
data:image/s3,"s3://crabby-images/ca2eb/ca2eb33775037a399f4563f3db4096933c65b64c" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper_04"
双击启动zk
data:image/s3,"s3://crabby-images/96c86/96c86bbb0b86213eb8f1a04685eb8d11fd0f0e02" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper_05"
2. 安装并启动zkui
linux环境:
nohup java -jar zkui-2.0-SNAPSHOT-jar-with-dependencies.jar &
windows环境
java -jar zkui-2.0-SNAPSHOT-jar-with-dependencies.jar >>
data:image/s3,"s3://crabby-images/3500e/3500e86ae90351564bdd5168b3f11475b121da84" alt="在这里插入图片描述 在生产环境中使用 Sentinel_jar_06"
data:image/s3,"s3://crabby-images/1f6e9/1f6e9a7b82b60463e4f52a02fe53a77d486a2703" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper_07"
二、编译打包
2.1. 拉取项目
git clone git@github.com:jiajiangnan/Sentinel.git
cd Sentinel
mvn clean install
data:image/s3,"s3://crabby-images/90056/90056ff47a6fcad5db7c58df0553577c51582313" alt="在这里插入图片描述 在生产环境中使用 Sentinel_jar_08"
data:image/s3,"s3://crabby-images/b00a5/b00a57ae770e36dcc477de980ef8de31d27b8527" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_09"
2.2. 启动
#进入编译后的目录
cd Sentinel-master\Sentinel-master\sentinel-dashboard\target
# 第一种(推荐使用):sentinel启动本地连接zk 没任何问题
java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -Ddatasource.provider=zookeeper -Ddatasource.provider.zookeeper.server-addr=localhost:2181 -jar sentinel-dashboard-1.8.0-zookeeper.jar
注:jar待补充
data:image/s3,"s3://crabby-images/dc13f/dc13f6b958ee92cb4d769ac5cf4986cf8c3155d6" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_10"
2.3. 登录 sentinel
账号/密码:sentinel/sentinel
data:image/s3,"s3://crabby-images/6a736/6a73670d16964b4266c1dbd2889995673b26ba22" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_11"
data:image/s3,"s3://crabby-images/6f20a/6f20a3ce9e667997fbcc11403453ed51bc74af5c" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_12"
data:image/s3,"s3://crabby-images/a5807/a5807ae8b003f9bcd4930fdf0c947c283345f519" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper_13"
2.4. 登录zkui
data:image/s3,"s3://crabby-images/4392d/4392d89b9869cb2fa83d38d78afd7917a4d95bdf" alt="在这里插入图片描述 在生产环境中使用 Sentinel_jar_14"
2.5. 重启Sentinel
查看流控规则是否仍然存在
data:image/s3,"s3://crabby-images/f5d3e/f5d3e84593a43fbf4596563a68465571c427461c" alt="在这里插入图片描述 在生产环境中使用 Sentinel_jar_15"
2.6. 删除Sentinel的流控规则
因为流控规则是Sentinel控制台同步zk的,预期效果,在Sentinel控制台删除流控规则后,zk的流控规则也会删除
data:image/s3,"s3://crabby-images/a5b6d/a5b6d75f811cf4aac1e6cad6ba7baea53e1cd6b1" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_16"
data:image/s3,"s3://crabby-images/cdb1a/cdb1a1551dbaa31a2421b2267761353ef5974648" alt="在这里插入图片描述 在生产环境中使用 Sentinel_Sentinel_17"
data:image/s3,"s3://crabby-images/2b186/2b1862cae0f2ed8d1b10de9208a4b34a062e99a5" alt="在这里插入图片描述 在生产环境中使用 Sentinel_Sentinel_18"
符合预期
三、将客户端和zk打通
https://github.com/alibaba/Sentinel/wiki/动态规则扩展
3.1. 引入依赖
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-datasource-zookeeper</artifactId>
</dependency>
3.2. 配置
package com.gblfy.distributedlimiter.config;
import com.alibaba.csp.sentinel.datasource.ReadableDataSource;
import com.alibaba.csp.sentinel.datasource.zookeeper.ZookeeperDataSource;
import com.alibaba.csp.sentinel.slots.block.flow.FlowRule;
import com.alibaba.csp.sentinel.slots.block.flow.FlowRuleManager;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.TypeReference;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import java.util.List;
@Component//添加到spring把容器让spring管理
public class ZookeeperDataSourceConfig {
@Bean//启动加载此方法
public void loadRules() {
//zk服务端地址
final String remoteAddress = "192.168.43.119:2181";
//应用+keyName
final String path = "/limiter/sentinel-flow-rules";
ReadableDataSource<String, List<FlowRule>> flowRuleDataSource = new ZookeeperDataSource<>(remoteAddress, path,
source -> JSON.parseObject(source, new TypeReference<List<FlowRule>>() {
}));
FlowRuleManager.register2Property(flowRuleDataSource.getProperty());
}
}
3.3. 启动springboot
data:image/s3,"s3://crabby-images/2f4ba/2f4babc12e704163054a560a050ec8e330793db5" alt="在这里插入图片描述 在生产环境中使用 Sentinel_Sentinel_19"
3.4. sentinel控制台+添加流控规则
data:image/s3,"s3://crabby-images/8c258/8c25839f5bfe67f681b5ecdb88a1a865d7ced137" alt="在这里插入图片描述 在生产环境中使用 Sentinel_Sentinel_20"
data:image/s3,"s3://crabby-images/ad6c0/ad6c00c0f116365ca0fc1489ed8f26d841fbc56a" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_21"
3.5. 登录zkui
查看流控规则是否同步
data:image/s3,"s3://crabby-images/9f358/9f35881f0b52abff180d1f5ba3a5cda79eb4ab89" alt="在这里插入图片描述 在生产环境中使用 Sentinel_zookeeper_22"
四、测试
4.1. 请求
请求数量>1,预期会被限流
http://192.xxx.x.xxx:8082/sentinel
data:image/s3,"s3://crabby-images/f11be/f11bed7f92860d0969e2853a6edd02b5e70908dc" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_23"
4.2. 重启springboot项目
lue
4.3. Sentinel控制台
查看流控规则是否仍然存在
data:image/s3,"s3://crabby-images/10981/1098171660629a575c89e9dca80f4e130b466067" alt="在这里插入图片描述 在生产环境中使用 Sentinel_spring_24"
4.4. zkui
data:image/s3,"s3://crabby-images/bacca/bacca8996133f07a4a279da9d176fa194b9c44a0" alt="在这里插入图片描述 在生产环境中使用 Sentinel_jar_25"
4.5. 分布式限流总结
对于是否是分布式限流,明确的就是限流规则是否储存在外部的一个公用的存储中心。之前讲的Guava RateLimiter组件限流为什么不能做不到分布式呢?因为限流规则存在java应用内存里面的。