• 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, String> flowRuleEntityEncoder() {
            return JSON::toJSONString;
        }
    
        @Bean
        public Converter> 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 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中去看看

    我们把这个数据贴出去格式化一下

    可以看到数据同步没有问题:grin::grin::grin::grin:

    下面我们制作一下 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

    外部也可以访问到了 启动成功..

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

  • 相关阅读:
    Linux系统编程·进程地址空间
    【1】前端学习笔记
    jvm总结
    C++---链表
    Linux 命令 poll 和 ppoll 详解 + 实例
    【RabbitMQ】——消息应答
    Java-面向对象的特征之一:封装
    xml文件全面解析。
    ESP8266-Arduino编程实例-MCP3008-ADC转换器驱动
    JColorChooser 和JFileChooser
  • 原文地址:https://blog.csdn.net/JHIII/article/details/126233941