SpringClouldAlibaba 之 Sentinel流控规则同步到nacos(并重新生成镜像)

1,147 阅读2分钟

这是我参与「掘金日新计划 · 8 月更文挑战」的第10天,点击查看活动详情

Sentinel.png

前言

上一篇我们将流控规则配置到了nacos 让服务启动时拉取流控规则从而实现持久化但是是有一个缺陷的,毕竟在nacos中维护这个流控规则不太友好,毕竟sentinel为我们提供了可视化界面,我们只需要修改修改 sentinel-dashboard这个工程然后重新制作一个镜像(docker)就可以了

首先我们需要去下载 dashboard 的源码

官方文档地址

image.png 因为是在github上网不好下载有点慢这里我放一个 gitee上的地址 gitee.com/mirrors/Sen… (这个和github那个是一样一天一次同步它)

image.png

改造第一步

注意: 官方其实已经为我们封装好了代码就在测试包下

image.png

我们把这几个配置类复制到上面同目录下去(这个nacos 是我创建的包)

image.png 下面我们只需要去 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); //创建链接
    }
}

image.png

配置推送在 FlowControllerV1类中

为什么改它而不是v2 呢因为我们在添加流控规则时打开f12 看到走的方法是v1的 image.png 添加流控规则时同步推送到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 下面我们进行测试 在 控制面板添加流控规则

image.png 可以看到添加成功

image.png 下面我们去nacos中去看看

image.png 我们把这个数据贴出去格式化一下 image.png 可以看到数据同步没有问题😁😁😁😁
下面我们制作一下 docker 镜像 直接在ide里面先打一个jar包

image.png 将jar 上传到 liunx服务器

image.png 下面我们编写一下 docker file

FROM java:8
ARG JAR_FILE
VOLUME /tmp
EXPOSE 8858 ## 注意这里 端口要和项目的启动端口一致
ENTRYPOINT ["java","-jar","/sentinel-dashboard.jar"]

docker build -t sentinel-dashboard . 最后这个点指的是当前目录下 image.png 然后我们使用docker images查看下镜像

image.png 最后我们启动一下 容器

docker run --name mysentinel  -p 8868:8858 -d sentinel-dashboard
docker start mysentinel 

注意这里有个小坑

image.png 这里提示我们IPV4 被禁用了(外部访问不到)
我们需要去 /etc/sysctl.conf
文件中添加 net.ipv4.ip_forward=1
最后重启一下网络服务 systemctl restart network image.png 外部也可以访问到了 启动成功..

实践是检验真理的唯一准则,感兴趣的可以去试试呀!明天见咯 😃😃😃😃