【Sentinel、Nacos】Sentinel中读取Nacos中配置(服务和网关)

一、环境准备

1、Spring Cloud中单个服务并能正常使用。参考链接
2、Sentinel已经搭建。
3、服务已经整合Sentinel参考链接
4、Nacos已经搭建。参考链接

二、Sentinel中读取Nacos中配置

1、引入依赖

		<dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-datasource-nacos</artifactId>
        </dependency>

2、application.yml配置

server:
  port: 7101

spring:
  application:
    name: a-server
  cloud:
    sentinel:
      transport:
        # sentinel地址
        dashboard: pfhe.com:7003
        # 此端口用于跟sentinel绑定,集群时能知道具体那台
        port: 7200
      # 程序启动就建立心跳
      eager: true
      datasource:
        ds:
          nacos:
            # nacos地址
            server-addr: pfhe.com:7001
            # 命名空间
            namespace: ${spring.profiles.active}
            # Data Id
            dataId: ${spring.application.name}-sentinel-flow-rules
            # 分组,默认DEFAULT_GROUP
            groupId: SENTINEL_GROUP
            # 格式
            data-type: json
            # 类型
            rule-type: flow
            # nacos账号
            username: nacos
            # nacos账号的密码
            password: nacos

3、Nacos中对应配置文件的内容
3.1、添加服务的Sentinel配置文件
在这里插入图片描述

[
    {
        "app": "a-server",
        "clusterConfig": {
            "fallbackToLocalWhenFail": true,
            "sampleCount": 110,
            "strategy": 0,
            "thresholdType": 0,
            "windowIntervalMs": 1000
        },
        "clusterMode": false,
        "controlBehavior": 0,
        "count": 6,
        "gmtCreate": 1646375875441,
        "gmtModified": 1646560397517,
        "grade": 1,
        "id": 24,
        "ip": "172.22.144.1",
        "limitApp": "default",
        "port": 8720,
        "resource": "/index",
        "strategy": 0
    }
]

参数解答:参考链接

resource	资源名,资源名是限流规则的作用对象	 
count	限流阈值	 
grade	限流阈值类型,QPS 或线程数模式	QPS 模式
limitApp	流控针对的调用来源,default,代表不区分调用来源
strategy	判断的根据是资源自身,还是根据其它关联资源 (refResource),还是根据链路入口	根据资源本身
controlBehavior	流控效果(直接拒绝 / 排队等待 / 慢启动模式),直接拒绝

3.2、添加网关服务的Sentinel配置
在这里插入图片描述

[
    {
        "apiName": "a-server",
        "app": "gateway-server",
        "gmtCreate": 1646473266000,
        "gmtModified": 1646473266000,
        "id": 1,
        "ip": "172.22.144.1",
        "port": 7201,
        "predicateItems": [
            {
                "matchStrategy": 1,
                "pattern": "/a-server"
            }
        ]
    }
]

三、效果:服务启动后会自动拉取Nacos中的配置,并且Nacos中配置更新之后,会同步到Sentinel控制台。

四、问题总结

1、Sentinel中修改了服务配置如何同步到Nacos?

答案

2、Sentinel中修改了网关服务配置如何同步到Nacos?

答案

3、上文说到的Nacos配置文件的内容可以不配置,如果配置了Sentinel同步Nacos之后,会自动同步。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值