nacos和sentinel的一些注意点

1. 概述

本篇文章主要记录自己在学习nacos和sentinel中需要注意的一些点,在学习过程中会不断更新,暂时先写几个注意点。基于的版本:

  1. JDK:17
  2. spring-boot:3.0.9
  3. mybatis-plus:3.5.3.2
  4. jackson-core:2.14.3
  5. spring-cloud-alibaba-dependencies:2022.0.0.0
  6. spring-cloud-starter-bootstrap:3.1.5:用来解决springboot不识别bootstrap.yaml的问题。
    主要学习参考的学习网址:

2. nacos

2.1 nacos鉴权的注意点

2.1.1 开启鉴权的配置

  1. 进入到nacos的安装目录的配置文件文件夹nacos\conf
  2. 编辑application.properties
  3. 修改以下配置,注意:原本配置文件中是存在这些属性设置的,只是设置的值全部是空,直接补上就行,这是个坑,我一直开始找了半天发现不了问题,原来是已经存在了。
nacos.core.auth.enabled=true
### 2.1.0 版本后
nacos.core.auth.plugin.nacos.token.secret.key=VGhpc0lzTXlDdXN0b21TZWNyZXRLZXkwMTIzNDU2Nzg=
### 配置自定义身份识别的key(不可为空)和value(不可为空)
nacos.core.auth.server.identity.key=nacos
nacos.core.auth.server.identity.value=nacos

这里贴一下鉴权的其他属性:
在这里插入图片描述

2.1.2 持久化nacos配置到mysql数据库

  1. 进入到nacos的安装目录的配置文件文件夹nacos\conf
  2. 找到mysql-schema.sql
  3. 在自己的数据库中新建这些表,并修改application.properties中的配置,如下所示:
# spring.datasource.platform=mysql ---已废弃
spring.sql.init.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
db.url.0=jdbc:mysql://127.0.0.1:3306/xxxxx?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=root
db.password.0=123456

### hikariCP配置
db.pool.config.connectionTimeout=30000
db.pool.config.validationTimeout=10000
db.pool.config.maximumPoolSize=20
db.pool.config.minimumIdle=2

nacos.config.push.maxRetryTime=50

注意:更改数据源后,鉴权中设置的用户名密码将失效,将会采用users表中的用户名和密码

3. sentinel

3.1 sentinel持久化设置到nacos的注意点

依赖

<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-datasource-nacos</artifactId>
    <version>x.y.z</version>
</dependency>
  1. yaml的配置新增nacos数据源配置
spring:
  cloud:
    sentinel:
      transport:
        port: 8719
        dashboard: localhost:8088
      datasource:
        ds:
          nacos:
            server-addr: localhost:8848
            username: nacos
            password: nacos
            namespace: mybatis-plus-study
            group-id: dev
            data-id: springcloudalibaba-sentinel-nacos
            rule-type: flow --本示例采取流控规则,还有其它的规则类型,可参考官网
  1. 新增SentinelWriteRead类,帮助sentinel在初始化时,从nacos中拉取配置。
@Component
public class SentinelWriteRead {
    @PostConstruct
    public void init() throws NacosException {
        System.out.println("-------------init-----------");
        String dataId = "springcloudalibaba-sentinel-nacos";
        String group = "dev";
        //TODO 从Nacos配置中心读取限流规则
        // 创建 NacosDataSource 并将其注册至对应的 RuleManager 上
        Properties properties = new Properties();
        properties.put(PropertyKeyConst.SERVER_ADDR, "localhost");
        properties.put(PropertyKeyConst.NAMESPACE, "mybatis-plus-study"); // 指定namespace配置
        properties.put(PropertyKeyConst.USERNAME, "nacos"); // 指定用户名
        properties.put(PropertyKeyConst.PASSWORD, "nacos"); // 指定密码
        ReadableDataSource<String, List<FlowRule>> flowRuleDataSource = new NacosDataSource<>(properties, group, dataId,
                source -> JSON.parseObject(source, new TypeReference<List<FlowRule>>() {
                }));
        FlowRuleManager.register2Property(flowRuleDataSource.getProperty());
        System.out.println(flowRuleDataSource.getProperty());
        //TODO 发布限流规则方式一:手动通过API修改
        // final String rule = "[\n"
        // + " {\n"
        // + " \"resource\": \"login\",\n"
        // + " \"controlBehavior\": 0,\n"
        // + " \"count\": 5.0,\n"
        // + " \"grade\": 1,\n"
        // + " \"limitApp\": \"default\",\n"
        // + " \"strategy\": 0\n"
        // + " }\n"
        // + "]";
        // ConfigService configService = NacosFactory.createConfigService(serverAddr);
        // boolean isPublishOk = configService.publishConfig(dataId, group, rule);
        // System.out.println(isPublishOk);
        //TODO 发布限流规则方式二:自动写入
        //TODO Sentinel Dashboard中修改规则同步到Nacos
        WritableDataSource writableDataSource = new WriteableNacos<>();
        WritableDataSourceRegistry.registerFlowDataSource(writableDataSource);
    }
}
  1. 新增WriteableNacos类,在更新sentinel时将配置持久化到nacos
public class WriteableNacos<T> implements WritableDataSource<T> {
    //当sentinel update 时候
    @Override
    public void write(T value) throws Exception {
        String s = JSON.toJSONString(value);
        System.out.println("-------------write-----------" + s);
        String dataId = "springcloudalibaba-sentinel-nacos";
        String group = "dev";
        // 发布配置
        Properties properties = new Properties();
        properties.put(PropertyKeyConst.SERVER_ADDR, "localhost");
        properties.put(PropertyKeyConst.NAMESPACE, "mybatis-plus-study"); // 指定namespace配置
        properties.put(PropertyKeyConst.USERNAME, "nacos"); // 指定用户名
        properties.put(PropertyKeyConst.PASSWORD, "nacos"); // 指定密码
        ConfigService configService = NacosFactory.createConfigService(properties);
        boolean isPublishOk = configService.publishConfig(dataId, group, s);
        System.out.println("isPublishOk========" + isPublishOk);
    }

    @Override
    public void close() throws Exception {
    }
}
  1. 在nacos中新增命名空间mybatis-plus-study,在该命名空间下新增dev组的springcloudalibaba-sentinel-nacos配置文件,类型为json。
    最近有点忙,先暂停更新吧…
  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Nacos 可以与 Sentinel 集成,以实现动态的流量控制和熔断降级策略。这样,你可以使用 Nacos 配置中心来配置 Sentinel 规则,实现对应用程序的实时流量控制和熔断降级。 以下是集成 NacosSentinel 的基本步骤: 1. 首先,你需要在应用程序中引入 NacosSentinel 的客户端库。根据你使用的编程语言和框架,可能需要添加相应的依赖或库文件。 2. 在 Nacos 配置中心中创建配置项,用于存储 Sentinel 的规则配置。可以在 Nacos 控制台中手动创建或使用 API 自动创建。 3. 在应用程序中使用 Nacos 的配置读取 API,读取 Sentinel 规则配置。这些规则可以是流量控制规则、熔断降级规则等。 4. 将读取到的规则配置传递给 Sentinel 客户端,使其生效。这样,Sentinel 就会根据配置的规则对流量进行控制和熔断降级。 5. 在 Nacos 配置中心中更新规则配置时,应用程序会自动获取最新的配置,并且 Sentinel 会根据新的配置进行动态调整。 下面是一个示例伪代码,展示了如何集成 NacosSentinel: ```python import nacos import sentinel # 创建 Nacos 客户端实例 client = nacos.NacosClient(server_addresses='nacos-server:8848') # 从 Nacos 获取 Sentinel 规则配置 config = client.get_config(data_id='sentinel-rules', group='your-group') # 将规则配置传递给 Sentinel 客户端 sentinel.load_rules(config) # 应用程序主逻辑 def main(): # 执行应用程序逻辑 do_something() if __name__ == '__main__': main() ``` 在上面的示例中,`client.get_config()` 方法用于从 Nacos 中获取 Sentinel 规则配置。然后,通过 `sentinel.load_rules()` 方法将规则配置传递给 Sentinel 客户端。 通过上述步骤,你可以实现 NacosSentinel 的集成,实现动态的流量控制和熔断降级策略。在 Nacos 配置中心更新规则配置时,应用程序会自动获取最新的配置,并且 Sentinel 会根据新的配置进行动态调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值