SpringClouldAlibaba 之 Sentinel
前言
上一篇我们将流控规则配置到了nacos 让服务启动时拉取流控规则从而实现持久化但是是有一个缺陷的,毕竟在nacos中维护这个流控规则不太友好,毕竟sentinel为我们提供了可视化界面,我们只需要修改修改 sentinel-dashboard这个工程然后重新制作一个镜像(docker)就可以了
首先我们需要去下载 dashboard 的源码
因为是在github上网不好下载有点慢这里我放一个 gitee上的地址 gitee.com/mirrors/Sen… (这个和github那个是一样一天一次同步它)
改造第一步
注意: 官方其实已经为我们封装好了代码就在测试包下
我们把这几个配置类复制到上面同目录下去(这个nacos 是我创建的包)
下面我们只需要去 NacosConfig中去小小改动下 配置nacos的地址
@Configuration public class NacosConfig { @Value("${nacos.addr}") private String adders;//配置nacos的地址 @Bean public Converter<List<FlowRuleEntity>, String> flowRuleEntityEncoder() { return JSON::toJSONString; } @Bean public Converter<String, List<FlowRuleEntity>> flowRuleEntityDecoder() { return s -> JSON.parseArray(s, FlowRuleEntity.class); } @Bean public ConfigService nacosConfigService() throws Exception { return ConfigFactory.createConfigService(adders); //创建链接 } }
配置推送在 FlowControllerV1类中
为什么改它而不是v2 呢因为我们在添加流控规则时打开f12 看到走的方法是v1的添加流控规则时同步推送到nacos
private CompletableFuture<Void> publishRules(String app, String ip, Integer port) { List<FlowRuleEntity> rules = repository.findAllByMachine(MachineInfo.of(app, ip, port)); try { rulePublisher.publish(app,rules); }catch (Exception e){ logger.info("同步失败"); } return sentinelApiClient.setFlowRuleOfMachineAsync(app, ip, port, rules); }
注意如果需要修改持久化文件的组或者名称需要在 NacosConfigUtil中指定如果不指定就是默认的
public static final String GROUP_ID = "SENTINEL_GROUP"; public static final String FLOW_DATA_ID_POSTFIX = "-flow-rules";
ok 下面我们进行测试 在 控制面板添加流控规则
可以看到添加成功
下面我们去nacos中去看看
可以看到数据同步没有问题😁😁😁😁
下面我们制作一下 docker 镜像 直接在ide里面先打一个jar包
将jar 上传到 liunx服务器
下面我们编写一下 docker file
FROM java:8 ARG JAR_FILE VOLUME /tmp EXPOSE 8858 ## 注意这里 端口要和项目的启动端口一致 ENTRYPOINT ["java","-jar","/sentinel-dashboard.jar"]
docker build -t sentinel-dashboard . 最后这个点指的是当前目录下
然后我们使用docker images查看下镜像
最后我们启动一下 容器
docker run --name mysentinel -p 8868:8858 -d sentinel-dashboard docker start mysentinel
注意这里有个小坑
这里提示我们IPV4 被禁用了(外部访问不到)
我们需要去 /etc/sysctl.conf
文件中添加 net.ipv4.ip_forward=1
最后重启一下网络服务 systemctl restart network
外部也可以访问到了 启动成功..
实践是检验真理的唯一准则,感兴趣的可以去试试呀!
#Java##程序员#