
前言
上一篇我们将流控规则配置到了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
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 外部也可以访问到了 启动成功..
实践是检验真理的唯一准则,感兴趣的可以去试试呀!明天见咯 😃😃😃😃