教程:在 Spring Boot 应用中使用功能标志

Spring Boot Core 功能管理库支持在 Spring Boot 应用程序中实施功能标志。 使用这些库能够以声明方式将功能标志添加到代码。

功能管理库还会在幕后管理功能标志生命周期。 例如,这些库可刷新和缓存标志状态,或者保证标志状态在请求调用期间保持不变。 此外,Spring Boot 库还提供集成,包括 MVC 控制器操作、路由和中间件。

将功能标志添加到 Spring Boot 应用快速入门介绍了在 Spring Boot 应用程序中添加功能标志的多种方法。 本教程将更详细地介绍这些方法。

本教程介绍如何执行下列操作:

  • 在应用程序的关键组件中添加功能标志,以控制功能可用性。
  • 使用应用程序配置来管理功能标志时,与应用程序配置相集成。

设置功能管理

Spring Boot 功能管理器 FeatureManager 从框架的本机配置系统获取功能标志。 因此,可以使用 Spring Boot 支持的任何配置源(包括本地 bootstrap.yml 文件或环境变量)来定义应用程序的功能标志。 FeatureManager 依赖于依赖项注入。 可以使用标准约定来注册功能管理服务。

private FeatureManager featureManager;

public HelloController(FeatureManager featureManager) {
    this.featureManager = featureManager;
}

我们建议将功能标志保留在应用程序的外部,并单独对其进行管理。 这样便可以随时修改标志状态,并使这些更改在应用程序中立即生效。 应用程序配置提供一个中心位置用于通过专用门户 UI 来组织和控制所有功能标志。 应用程序配置还直接通过其 Spring Boot 客户端库将标志传送到应用程序。

将 Spring Boot 应用程序连接到应用程序配置的最简单方法是使用配置提供程序:

<dependency>
    <groupId>com.azure.spring</groupId>
    <artifactId>spring-cloud-azure-feature-management-web</artifactId>
</dependency>

<dependencyManagement>
    <dependencies>
        <dependency>
        <groupId>com.azure.spring</groupId>
        <artifactId>spring-cloud-azure-dependencies</artifactId>
        <version>5.18.0</version>
        <type>pom</type>
        <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

功能标志声明

每个功能标志有两个组成部分:一个名称,以及用于评估功能状态是否为“打开”(即,其值为 True)的一个或多个筛选器的列表。 筛选器定义有关何时应启用某个功能的用例。

如果某个功能标志包含多个筛选器,则会按顺序遍历筛选器列表,直到其中一个筛选器确定应启用该功能。 此时,该功能标志为“打开”,并会跳过所有剩余的筛选器结果。 如果没有任何筛选器指示应启用该功能,则表示该功能标志为“关闭”。

功能管理器支持将 application.yml 用作功能标志的配置源。 以下示例演示如何在 YAML 文件中设置功能标志:

feature-management:
  feature-a: true
  feature-b: false
  feature-c:
    enabled-for:
      -
        name: PercentageFilter
        parameters:
          Value: 50

按照约定,此 YML 文档的 feature-management 节用于功能标志设置。 以上示例演示了三个功能标志,其筛选器已在 EnabledFor 属性中定义:

  • feature-a 状态为“打开”。
  • feature-b 状态为“关闭”。
  • feature-c 指定包含 parameters 属性的名为 PercentageFilter 的筛选器。 PercentageFilter 是可配置的筛选器。 在此示例中,PercentageFilter 指定打开 feature-c 标志的概率为 50%。

功能标志检查

功能管理的基本模式是首先检查功能标志是否设置为“打开”。 如果是,则功能管理器将运行该功能包含的操作。 例如:

private FeatureManager featureManager;
...
if (featureManager.isEnabledAsync("feature-a").block()) {
    // Run the following code
}

依赖项注入

在 Spring Boot 中,可以通过依赖项注入访问功能管理器 FeatureManager

@Controller
@ConfigurationProperties("controller")
public class HomeController {
    private FeatureManager featureManager;

    public HomeController(FeatureManager featureManager) {
        this.featureManager = featureManager;
    }
}

控制器操作

在 MVC 控制器中,使用 @FeatureGate 属性控制是否启用特定的操作。 以下 Index 操作要求 feature-a 状态为“打开”才能运行该操作:

@GetMapping("/")
@FeatureGate(feature = "feature-a")
public String index(Model model) {
    ...
}

当由于控制功能标志状态为“关闭”而阻止了 MVC 控制器或操作时,将调用已注册的 DisabledFeaturesHandler接口。 默认的 DisabledFeaturesHandler 接口向客户端返回 404 状态代码,但不返回响应正文。

MVC 筛选器

可以设置 MVC 筛选器,以根据功能标志的状态激活这些筛选器。 以下代码添加名为 FeatureFlagFilter 的 MVC 筛选器。 仅当已启用 feature-a 时,才会在 MVC 管道内部触发此筛选器。

@Component
public class FeatureFlagFilter implements Filter {

    @Autowired
    private FeatureManager featureManager;

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        if(!featureManager.isEnabled("feature-a")) {
            chain.doFilter(request, response);
            return;
        }
        ...
        chain.doFilter(request, response);
    }
}

路由

可以使用功能标志来重定向路由。 以下代码从启用的 feature-a 重定向用户:

@GetMapping("/redirect")
@FeatureGate(feature = "feature-a", fallback = "/getOldFeature")
public String getNewFeature() {
    // Some New Code
}

@GetMapping("/getOldFeature")
public String getOldFeature() {
    // Some New Code
}

后续步骤

本教程已介绍如何使用 spring-cloud-azure-feature-management-web 库在 Spring Boot 应用程序中实施功能标志。 如有进一步问题,请参阅参考文档。 参考文档包含有关 Spring Cloud Azure 应用程序配置库如何工作的全部详细信息。有关 Spring Boot 和应用程序配置中功能管理支持的详细信息,请参阅以下资源: