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


    前言

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

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

    官方文档地址

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

    改造第一步

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

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

    下面我们只需要去 NacosConfig中去小小改动下 配置nacos的地址

    1. @Configuration
    2. public class NacosConfig {
    3. @Value("${nacos.addr}")
    4. private String adders;//配置nacos的地址
    5. @Bean
    6. public Converter<List<FlowRuleEntity>, String> flowRuleEntityEncoder() {
    7. return JSON::toJSONString;
    8. }
    9. @Bean
    10. public Converter<String, List<FlowRuleEntity>> flowRuleEntityDecoder() {
    11. return s -> JSON.parseArray(s, FlowRuleEntity.class);
    12. }
    13. @Bean
    14. public ConfigService nacosConfigService() throws Exception {
    15. return ConfigFactory.createConfigService(adders); //创建链接
    16. }
    17. }
    18. 复制代码

    配置推送在 FlowControllerV1类中

    为什么改它而不是v2 呢因为我们在添加流控规则时打开f12 看到走的方法是v1的

    添加流控规则时同步推送到nacos

    1. private CompletableFuture<Void> publishRules(String app, String ip, Integer port) {
    2. List rules = repository.findAllByMachine(MachineInfo.of(app, ip, port));
    3. try {
    4. rulePublisher.publish(app,rules);
    5. }catch (Exception e){
    6. logger.info("同步失败");
    7. }
    8. return sentinelApiClient.setFlowRuleOfMachineAsync(app, ip, port, rules);
    9. }
    10. 复制代码

    注意如果需要修改持久化文件的组或者名称需要在 NacosConfigUtil中指定如果不指定就是默认的

    1. public static final String GROUP_ID = "SENTINEL_GROUP";
    2. public static final String FLOW_DATA_ID_POSTFIX = "-flow-rules";
    3. 复制代码

    ok 下面我们进行测试 在 控制面板添加流控规则

    可以看到添加成功

    下面我们去nacos中去看看

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

    将jar 上传到 liunx服务器

    下面我们编写一下 docker file

    1. FROM java:8
    2. ARG JAR_FILE
    3. VOLUME /tmp
    4. EXPOSE 8858 ## 注意这里 端口要和项目的启动端口一致
    5. ENTRYPOINT ["java","-jar","/sentinel-dashboard.jar"]
    6. 复制代码

    docker build -t sentinel-dashboard . 最后这个点指的是当前目录下

    然后我们使用docker images查看下镜像

    最后我们启动一下 容器

    1. docker run --name mysentinel -p 8868:8858 -d sentinel-dashboard
    2. docker start mysentinel
    3. 复制代码

    注意这里有个小坑

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

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

  • 相关阅读:
    项目的坎坷一生
    『德不孤』Pytest框架 — 12、Pytest中Fixture装饰器(二)
    2022深圳xxx校招Java笔试题目(选择题+简答题)
    Python ElementTree 导出 xml 缺少 开头声明&【Pymssql】使用cursor.fetchall()获取执行结果时中文乱码
    SQLMAP --TAMPER的编写
    【python】subprocess用法示例
    Scrum框架中的Sprint
    Python之Python的版本选择和IDE工具选择问题
    进大厂必备的Java八股文大全(2022最强精简易懂版,八股文中的八股文)备战秋招,赶快转发收藏起来吧~
    第七章第一节:顺序查找和折半查找
  • 原文地址:https://blog.csdn.net/YYniannian/article/details/126262747