Sentinel控制台配置 持久化到nacos

2023-09-13 16:12:13

 sentinel控制台,使用方便,功能强大。使用官方的jar包,配置不会持久化,sentinel重启后会导致,之前的规则全部丢失,下面一起改造源码实现规则数据的持久化

sentinel源码地址

(github访问太慢,直接上镜像版)

Sentinel: Sentinel 是什么 随着微服务的流行,服务和服务之间的稳定性变得越来越重要icon-default.png?t=N7T8https://gitee.com/mirrors/Sentinel.git

因为项目使用的是Spring-cloud-alibaba,Sentinel支持和nacos整合,就持久化到nacos数据库中,同时sentinel还能读取nacos中做的流控规则。

1 源码目录

1.1、后台源码修改

小惊喜:sentinel中有和nacos中对接的源码,只不过没有使用。

1、改成 默认后台使用sentinel对接nacos,而不是存到内存,

2、前台页面接口调用nacos对应的接口

1.1.1 sentinel-dashboard中需要改动的位置

pom.xml中将sentinel-datasource-nacos包的scope注释掉

1.1.2 源码持久化到nacos的实现位置

不多说,先复制到main目录rule包下

nacos包中的4个类:

  • FlowRuleNacosProvider: 动态获取Nacos配置中心流控规则,读取流控规则
  • FlowRuleNacosPublisher: publish上传流控规则到Nacos配置中心,写入流控规则
  • NacosConfig: Nacos配置
  • NacosConfigUtils: 流控规则在nacos中配置文件的一些细节:后缀、组别等
1.1.3 NacosConfig配置

只实现了本地nacos并且需要默认配置,需要支持自定义配置

改造后

NacosConfig源码

/*
 * Copyright 1999-2018 Alibaba Group Holding Ltd.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.alibaba.csp.sentinel.dashboard.rule.nacos;

import com.alibaba.csp.sentinel.dashboard.datasource.entity.rule.FlowRuleEntity;
import com.alibaba.csp.sentinel.datasource.Converter;
import com.alibaba.fastjson.JSON;
import com.alibaba.nacos.api.PropertyKeyConst;
import com.alibaba.nacos.api.config.ConfigFactory;
import com.alibaba.nacos.api.config.ConfigService;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.List;
import java.util.Properties;

/**
 * @author Eric Zhao
 * @since 1.4.0
 */
@Configuration
public class NacosConfig {

    @Value("${sentinel.nacos.address}")
    private String nacosAddr;

    @Value("${sentinel.nacos.username}")
    private String nacosUsername;

    @Value("${sentinel.nacos.password}")
    private String nacosPassword;

    @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 {
        Properties properties = new Properties();
        properties.put(PropertyKeyConst.SERVER_ADDR, nacosAddr);
        properties.put(PropertyKeyConst.USERNAME, nacosUsername);
        properties.put(PropertyKeyConst.PASSWORD, nacosPassword);
        return ConfigFactory.createConfigService(properties);
    }
}
1.1.4 修改配置文件 application.properties

增加nacos配置信息

#Sentinel  连接nacos配置
sentinel.nacos.address= 192.168.1.109:8848
sentinel.nacos.username= nacos
sentinel.nacos.password= nacos
 1.1.5 配置v2版本controller,调用nacos提供的服务层

1.2 前端页面源码修改

1.2.1 配置中添加nacos接口并修改地址

文件 src/main/webapp/resources/app/scripts/controllers/identity.js

搜FlowServiceV1 改为 FlowServiceV2

/dashboard/flow/ 改为 /dashboard/v2/flow/

 1.2.2 修改页面中的路由地址

文件 src/main/webapp/resources/app/scripts/directives/sidebar/sidebar.html

dashboard.flowV1定位57行去掉V1

文件 src/main/webapp/resources/app/views/flow_v2.html

注释掉回到单机页面按钮

2.项目引用

2.1 微服务引入jar包 pom.xml
        <!-- SpringCloud Alibaba Nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <!-- Sentinel -->
        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-datasource-nacos</artifactId>
        </dependency>
2.2 微服务sentinel相关配置
# Spring
spring:
  cloud:
    sentinel:
      eager: true
      # sentinel 地址
      transport:
        dashboard: ${sentinel.host}:${sentinel.port}
        filter:
          enabled: false
      datasource:
        ds1:
          nacos:
            server-addr: ${nacos.host}:${nacos.port}
            username: ${nacos.name}
            password: ${nacos.pwd}
            namespace: ${nacos.namespace}
            group-id: ${nacos.group}
            data-id: ${spring.application.name}-flow-rules
            data-type: json
            rule-type: flow

3 nacos增加sentinel持久化配置文件

以下文件后缀与组名需要对应

大功告成,去试试效果吧

更多推荐

Kafka开篇

前言从本篇开始对个人Kafka学习做一个总结,目标有这么几个。从概念架构角度,对消息中间件形成概要认知;从使用角度,掌握其常见用法;从性能角度,探究其高性能实现机制;消息中间件的用途从消息生产和消费的角度,平衡消费者和消费者的速率差。基于该点可以做到削峰填谷,比如流量突发,日志处理等。从系统解耦的角度,解耦生产者和消费

React 全栈体系(九)

第五章React路由一、相关理解1.SPA的理解单页Web应用(singlepagewebapplication,SPA)。整个应用只有一个完整的页面。点击页面中的链接不会刷新页面,只会做页面的局部更新。数据都需要通过ajax请求获取,并在前端异步展现。2.路由的理解2.1什么是路由?一个路由就是一个映射关系(key:

Mysql的常见错误总结

Mysql的常见错误总结Datatruncation:Outofrangevalueofforcolumn在执行一个update语句的时候,报错Datatruncation:Outofrangevalueofforcolumn‘CLAIM_QUANTITY’…update语句是把’CLAIM_QUANTITY’这个字段

使用Python编写一个多线程的12306抢票程序

国庆长假即将到来,大家纷纷计划着自己的旅行行程。然而,对于很多人来说,抢购火车票人们成了一个令人头疼的问题。12306网站的服务器经常因为流量高而崩溃,导致抢票变得越来越严重异常困难。首先,让我们来了解一下12306抢票的难点。由于很多人都在同一时间段内访问12306网站,服务器的负载率非常高,导致网站响应变慢甚至崩溃

【uniapp】小程序开发:3 分包配置

分包加载配置,此配置为小程序的分包加载机制。因小程序有体积和资源加载限制,各家小程序平台提供了分包方式,优化小程序的下载和启动速度。所谓的主包,即放置默认启动页面/TabBar页面,以及一些所有分包都需用到公共资源/JS脚本;而分包则是根据pages.json的配置进行划分。在小程序启动时,默认会下载主包并启动主包内页

ReactNative 网络库

WhatJS判断网络状态不准确react-native-netinfo在Android中的结构type-CellularGeneration:G网模式枚举type-ConnectionType:网络连接类型AmazonFireDeviceConnectivityPoller:Amazon设备网络适配,可忽略Broadc

字符串函数和内存函数详解(2)

🐵本文会将会对剩余的字符串库函数和内存函数进行讲解1.strstr📚1.1函数用法✏️strstr函数原型:strstr用于在字符串中找子串,strstr会返回str1中出现str2的起始地址,如果在str1中没有找到str2,则返回空指针1.2具体实现🖊️#include<stdio.h>#include<st

秋招如何做好IT面试准备

一年一季又是到了秋招的日子,回首去年这时候的自己也在准备面试中苦苦挣扎,在这里给各位学弟学妹分享一些面试准备的小技巧吧。方向一:分享你面试IT公司的小技巧IT公司区别与其他公司肯定对技术要求更高,所以首先你要准备的是你简历上写的东西你是否都能回答的上,因为大部分公司面试第一出发点都是你的简历,不要在简历上胡吹海侃给自己

视觉Transformer在低级视觉领域的研究综述

视觉Transfomer的基本原理在图像处理过程中,ViT首先将输入的图片分成块,对其进行线性的编码映射后排列成一堆的向量作为编码器的输入,在分类任务中会在这个一维向量加入了一个可学习的嵌入向量用作分类的类别预测结果表示,最后通过一个全连接层输出结果注意力机制注意力机制让网络更聚焦于输入中相关信息的方法,从而减少对无关

实时云渲染与直播应用场景结合技术探索

//随着互联网以及终端设备的全面发展,直播在日常的生活中已经越来越常见。越来越多的人开始在直播中与主播互动,作为一种娱乐消遣的方式。但是有些直播平台频发的卡顿以及打赏特效的单一会让用户的直播体验大打折扣。LiveVideoStack邀请到腾讯云的江敏为我们介绍腾讯云如何将云渲染应用在直播场景中,为直播带来更好的体验。文

前端中blob文件流和base64的区别

在前端中,base64和fileBlob是用于处理文件数据的两种不同方式。1.Base64编码Base64是一种将二进制数据转换为文本字符串的编码方式。它将文件数据转换为一串由ASCII字符组成的字符串。在前端中,可以使用JavaScript的btoa()和atob()函数来进行Base64编码和解码。优点:-Base

热文推荐