接入Dubbo应用

将Dubbo应用接入AHAS应用防护后,可以对其配置流控、降级和系统规则来保证系统稳定性。本文介绍如何使用SDK方式将Dubbo应用接入应用防护。

操作步骤

  1. 登录AHAS控制台
  2. 在AHAS控制台左上角,选择应用接入的地域。
  3. 在控制台左侧导航栏中选择流量防护 > 应用防护
  4. 应用防护页面右上角单击新应用接入

  5. JAVA语言页签,单击SDK接入,然后单击Dubbo/HFS应用接入

  6. 选择以下任意一种方式,在Dubbo应用中添加应用防护依赖。

    • 在Dubbo应用的pom.xml中添加以下依赖(自SDK/Starter 1.8.6版本起,支持Dubbo 2.6.x/2.7.x主流版本):

      <dependency>
        <groupId>com.alibaba.csp</groupId>
        <artifactId>ahas-sentinel-client</artifactId>
        <!-- 可指定版本号,最新版本见AHAS控制台应用防护新应用接入页引导。 -->
        <version>x.y.z</version>
      </dependency>

      Dubbo应用接入页面查看pom依赖最新版本,将x.y.z替换为新版本的版本号。

      Dubbo版本号2.png

      说明

      若Dubbo服务是Spring Boot应用,可通过Spring Boot方式快速接入。具体详情,请参见接入Spring Boot/Spring Cloud应用

    • 添加JAR包依赖。

      Dubbo应用接入页面单击请点此链接下载下载压缩包,并将压缩包中的所有JAR包放置在classpath目录下。

  7. 配置应用的启动参数。

    类别

    配置参数示例

    非公网

    -Dproject.name=AppName -Dahas.namespace=default -Dahas.regionId=<RegionId>
    说明
    • 将AppName替换为自定义的应用名称。

    • 将<RegionId>替换应用所在地域,地域与RegionId对应表请参见下文地域与RegionId对应表

    公网

    -Dproject.name=AppName -Dahas.license=<license> -Dahas.namespace=default -Dahas.regionId=cn-public
    说明

    将AppName替换为自定义的应用名称,将<license>替换为真实值。

    若在公网地域,需要查看License信息。请在第二步:添加埋点区域查看(非公网地域不需要),具体请参见查看License

    dubbo license2.png

  8. 重启您的应用。

  9. 可选:您可以自定义Dubbo应用触发限流、降级或系统保护规则时的fallback处理逻辑,自定义DubboFallback接口并通过DubboFallbackRegistry注册即可。配置后,当Dubbo应用触发流控、降级或系统规则时,AHAS会将BlockException包装后抛出。更多信息,请参见Dubbo Adapter

    说明

    若未执行此步骤,当Dubbo应用触发应用防护规则时,默认抛出BlockException异常类的子类(触发流控规则,则抛出流控异常FlowException;触发降级规则,则抛出降级异常DegradeException)。

结果验证

登录AHAS控制台,在左侧导航栏选择流量防护 > 应用防护,若在应用防护页面出现该应用的资源卡片且有数据上报,则说明接入成功。

应用防护.png

地域与RegionId对应表

地域

RegionId

公网

cn-public

华东1(杭州)

cn-hangzhou

华东2(上海)

cn-shanghai

华北2(北京)

cn-beijing

华北3(张家口)

cn-zhangjiakou

华南1(深圳)

cn-shenzhen

新加坡

ap-southeast-1

德国(法兰克福)

eu-central-1