OpenFeign 教程: 使用 Spring Cloud Alibaba 和 Nacos
创始人
2025-01-09 15:09:46
0

OpenFeign 教程: 使用 Spring Cloud Alibaba 和 Nacos

在本教程中,我们将学习如何使用 OpenFeign 与 Spring Cloud Alibaba 和 Nacos 实现微服务之间的远程调用。OpenFeign 是一个声明式的 HTTP 客户端,让我们能够简化微服务间的调用。Spring Cloud Alibaba 为我们提供了与阿里巴巴生态系统的整合,其中 Nacos 是一个动态服务发现、配置管理和服务管理平台。

环境要求

  • JDK 8 或更高版本
  • Apache Maven 3.5 或更高版本
  • IDE(IntelliJ IDEA 或 Eclipse)

步骤 1: 创建项目

首先,我们将使用 Spring Initializr 创建一个基本的 Spring Boot 项目。访问 https://start.spring.io/ 并选择以下选项:

  • Project: Maven Project
  • Language: Java
  • Packaging: Jar
  • Java Version: 8
  • Group: com.example
  • Artifact: openfeign-demo
  • Name: openfeign-demo

在 “Dependencies” 中选择以下依赖:

  • Spring Web
  • Spring Cloud Alibaba Nacos Discovery
  • Spring Cloud OpenFeign

点击 “Generate” 生成项目并解压下载的文件。使用你的 IDE 打开项目。

步骤 2: 配置 Nacos

在开始之前,确保已安装并启动了 Nacos 服务器。如果还没有,请访问 https://nacos.io/en-us/docs/quick-start.html 进行安装和配置。

在项目中,打开 src/main/resources/application.properties 文件并添加以下内容:

spring.application.name=openfeign-demo spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 

这里,我们配置了应用的名称以及 Nacos 服务器的地址。

步骤 3: 创建一个简单的微服务

com.example.openfeigndemo 包下创建一个名为 HelloController 的类:

package com.example.openfeigndemo;  import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController;  @RestController public class HelloController {      @GetMapping("/hello")     public String hello() {         return "Hello from OpenFeign Demo!";     } } 

步骤 4: 创建一个 Feign 客户端

com.example.openfeigndemo 包下创建一个名为 HelloFeignClient 的接口:

package com.example.openfeigndemo;  import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.GetMapping;  @FeignClient("openfeign-demo") public interface HelloFeignClient {      @GetMapping("/hello")     String hello(); } 

这里,我们使用 @FeignClient 注解声明一个 Feign 客户端,并指定要调用的服务名称。

步骤 5: 调用微服务

com.example.openfeigndemo 包下创建一个名为 OpenFeignDemoApplication 的类,并添加以下代码:

package com.example.openfeigndemo;  import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; 
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.cloud.openfeign.EnableFeignClients; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController;  @EnableDiscoveryClient @EnableFeignClients @SpringBootApplication @RestController public class OpenFeignDemoApplication {      @Autowired     private HelloFeignClient helloFeignClient;      public static void main(String[] args) {         SpringApplication.run(OpenFeignDemoApplication.class, args);     }      @GetMapping("/feign-hello")     public String feignHello() {         return helloFeignClient.hello();     } } 

在这个类中,我们通过 @EnableDiscoveryClient@EnableFeignClients 注解启用服务发现和 Feign 客户端。我们还创建了一个 feignHello 方法,该方法通过注入的 HelloFeignClient 实例调用远程 hello 方法。

步骤 6: 运行项目

在 IDE 中运行 OpenFeignDemoApplication 类或者在项目根目录下使用 Maven 命令运行:

mvn spring-boot:run 

当应用启动后,访问 http://localhost:8080/feign-hello ,你将看到来自远程服务的 “Hello from OpenFeign Demo!” 响应。

总结

本教程演示了如何使用 OpenFeign 与 Spring Cloud Alibaba 和 Nacos 实现微服务之间的远程调用。我们创建了一个简单的 Spring Boot 项目,配置了 Nacos 服务发现,创建了一个简单的微服务,然后使用 Feign 客户端进行调用。你可以在这个基础上扩展,为你的项目创建更多的微服务和 Feign 客户端。

  • OpenFeign方法接口参数都有哪些?

  • OpenFeign 支持多种方法参数和注解,可以帮助你轻松地定义和调用远程服务。以下是一些常用的参数和注解:

  1. @PathVariable : 用于将方法参数绑定到 URI 模板变量。例如:
@GetMapping("/users/{id}") User getUserById(@PathVariable("id") Long id); 

在这个例子中,{id} 是 URI 模板变量,@PathVariable("id") 将方法参数 id 绑定到 URI 模板变量。

  1. @RequestParam : 用于将方法参数绑定到 HTTP 请求参数。例如:
@GetMapping("/users") List getUsers(@RequestParam("page") int page, @RequestParam("size") int size); 

在这个例子中,pagesize 是请求参数,@RequestParam("page")@RequestParam("size") 将方法参数与请求参数进行绑定。

  1. @RequestHeader : 用于将方法参数绑定到 HTTP 请求头。例如:
@GetMapping("/users/{id}") User getUserById(@PathVariable("id") Long id, @RequestHeader("Authorization") String authToken); 

在这个例子中,Authorization 是请求头,@RequestHeader("Authorization") 将方法参数 authToken 绑定到请求头。

  1. @RequestBody : 用于将方法参数绑定到 HTTP 请求体。通常用于 POST 和 PUT 请求。例如:
@PostMapping("/users") User createUser(@RequestBody User user); 

在这个例子中,@RequestBody 将方法参数 user 绑定到请求体。

以下是一个完整的示例,演示了如何在 Feign 客户端中使用这些注解:

package com.example.demo;  import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.*;  import java.util.List;  @FeignClient("user-service") public interface UserFeignClient {      @GetMapping("/users/{id}")     User getUserById(@PathVariable("id") Long id);      @GetMapping("/users")     List getUsers(@RequestParam("page") int page, @RequestParam("size") int size);      @PostMapping("/users")     User createUser(@RequestBody User user);      @PutMapping("/users/{id}")     User updateUser(@PathVariable("id") Long id, @RequestBody User user);      @DeleteMapping("/users/{id}")     void deleteUser(@PathVariable("id") Long id); } 

这个例子中,我们定义了一个名为 UserFeignClient 的 Feign 客户端,用于调用远程的用户服务。我们使用了 @PathVariable@RequestParam@RequestHeader@RequestBody 注解来绑定方法参数到对应的 URI 模板变量、请求参数、请求头和请求体。

  • 以下是关于使用 OpenFeign 的更多信息和技巧:
  1. 自定义请求超时 : 默认情况下,OpenFeign 使用 Ribbon(客户端负载均衡器)的默认超时设置。要自定义这些设置,请在 application.propertiesapplication.yml 文件中进行配置。例如:
feign.client.config.default.connectTimeout=5000 feign.client.config.default.readTimeout=10000 

上述设置将连接超时设置为 5000 毫秒,读取超时设置为 10000 毫秒。

  1. 自定义 Feign 配置 : 如果需要为特定的 Feign 客户端提供自定义配置,可以创建一个 Feign 配置类,并在 @FeignClient 注解中引用它。例如:
@Configuration public class CustomFeignConfig {      @Bean     public Logger.Level feignLoggerLevel() {         return Logger.Level.FULL;     }      @Bean     public Request.Options requestOptions() {         return new Request.Options(5000, 10000);     } } 

然后,在 @FeignClient 注解中引用这个配置类:

@FeignClient(value = "user-service", configuration = CustomFeignConfig.class) public interface UserFeignClient {     // ... } 

在这个示例中,我们创建了一个自定义的 Feign 配置类 CustomFeignConfig,其中包含了自定义的日志级别和请求选项。然后,我们在 UserFeignClient@FeignClient 注解中引用了这个配置类。

  1. Feign 日志 : 默认情况下,Feign 的日志级别设置为 NONE,这意味着不会记录任何日志。要启用日志记录,请在自定义的 Feign 配置类中设置日志级别。例如:
@Bean public Logger.Level feignLoggerLevel() {     return Logger.Level.FULL; } 

可用的日志级别包括:

  • NONE:不记录任何日志(默认值)。
  • BASIC:仅记录请求方法和 URL,以及响应状态代码和执行时间。
  • HEADERS:在基本信息之外,还记录请求和响应头。
  • FULL:记录请求和响应头、正文以及元数据。

要查看日志输出,还需要在 application.propertiesapplication.yml 文件中配置包含 Feign 客户端的包的日志级别。例如:

logging.level.com.example.demo=DEBUG 

在这个示例中,我们将 com.example.demo 包的日志级别设置为 DEBUG,这将输出 Feign 客户端的日志信息。

通过以上示例和技巧,你应该能够更有效地使用 OpenFeign 构建和调用远程服务。结合实际场景,可以根据需要调整和优化 Feign 客户端的配置。

    1. 重试机制 : OpenFeign 默认集成了 Ribbon,可以通过 Ribbon 提供的重试机制来应对服务调用失败的情况。为了启用重试,需要在 application.propertiesapplication.yml 文件中进行配置。例如:
feign.client.config.default.retry.enabled=true feign.client.config.default.retry.maxAttempts=3 feign.client.config.default.retry.backoff.period=1000 feign.client.config.default.retry.backoff.multiplier=2.0 

上述设置启用了重试机制,并配置了最大重试次数为 3 次,初始退避时间为 1000 毫秒,退避时间倍数为 2.0。根据这些设置,每次失败后的等待时间将分别为 1000 毫秒、2000 毫秒和 4000 毫秒。

  1. 请求拦截器 : 有时候你可能需要在发送请求前对请求进行一些处理,比如添加认证信息、修改请求头等。这时,你可以创建一个自定义的 Feign 请求拦截器。例如:
public class CustomRequestInterceptor implements RequestInterceptor {      @Override     public void apply(RequestTemplate requestTemplate) {         // 在此处添加自定义逻辑,如修改请求头、添加认证信息等         requestTemplate.header("Authorization", "Bearer " + getAccessToken());     }      private String getAccessToken() {         // 获取访问令牌的逻辑         return "your_access_token";     } } 

然后,在你的自定义 Feign 配置类中将此拦截器注册为一个 Bean:

@Configuration public class CustomFeignConfig {      @Bean     public RequestInterceptor customRequestInterceptor() {         return new CustomRequestInterceptor();     }      // ... } 

在这个示例中,我们创建了一个自定义的请求拦截器 CustomRequestInterceptor,用于在发送请求前为请求添加授权头。然后,我们在 CustomFeignConfig 配置类中将此拦截器注册为一个 Bean。

  1. 响应解码器 : 默认情况下,Feign 使用 Jackson 作为 JSON 解码器。如果你需要自定义响应解码逻辑,可以创建一个自定义的解码器并将其注册为一个 Bean。例如:
public class CustomDecoder extends JacksonDecoder {      @Override     public Object decode(Response response, Type type) throws IOException, FeignException {         // 在此处添加自定义解码逻辑         return super.decode(response, type);     } } 

然后,在你的自定义 Feign 配置类中将此解码器注册为一个 Bean:

@Configuration public class CustomFeignConfig {      @Bean     public Decoder customDecoder() {         return new CustomDecoder();     }      // ... } 

在这个示例中,我们创建了一个自定义解码器 CustomDecoder,继承了 JacksonDecoder 并覆盖了 decode 方法。然后,在 CustomFeignConfig 配置类中将此解码器注册为一个 Bean。

通过以上高级功能和技巧,你可以更好地

  • 掌握和应用 OpenFeign。以下是一些建议和最佳实践,帮助你在实际项目中更有效地使用 OpenFeign。
  1. Hystrix 整合 : 虽然 Hystrix 已经进入维护模式,但仍然可以与 OpenFeign 集成来实现熔断和降级策略。为了使用 Hystrix,需要在项目中引入 Hystrix 依赖,并在 application.propertiesapplication.yml 文件中启用 Hystrix:
feign:   hystrix:     enabled: true 

然后,在你的 Feign 客户端接口中定义一个 Fallback 类,并在 @FeignClient 注解中指定它。例如:

@FeignClient(value = "user-service", fallback = UserServiceFallback.class) public interface UserFeignClient {     // ... }  @Component class UserServiceFallback implements UserFeignClient {      @Override     public User getUserById(Long id) {         // 返回降级策略,例如返回一个默认的 User 对象         return new User("Fallback User");     }      // ... 实现其他方法的降级策略 } 
  1. 错误处理 : 当远程服务调用失败时,你可能需要根据不同的错误类型进行不同的处理。你可以创建一个自定义的 Feign 错误解码器来实现这一目标。例如:
public class CustomErrorDecoder implements ErrorDecoder {      @Override     public Exception decode(String methodKey, Response response) {         // 根据响应状态码判断错误类型,并返回相应的异常         switch (response.status()) {             case 404:                 return new NotFoundException("Resource not found");             case 500:                 return new InternalServerException("Internal server error");             default:                 return new UnknownException("Unknown error");         }     } } 

然后,在你的自定义 Feign 配置类中将此错误解码器注册为一个 Bean:

@Configuration public class CustomFeignConfig {      @Bean     public ErrorDecoder customErrorDecoder() {         return new CustomErrorDecoder();     }      // ... } 
  1. 遵循 RESTful 最佳实践 : 在设计和实现 Feign 客户端时,尽量遵循 RESTful API 的最佳实践,如使用正确的 HTTP 动词、状态码和资源路径等。
  2. 合理划分 Feign 客户端 : 将不同领域或业务功能的远程调用分组到不同的 Feign 客户端接口中,以提高代码的可读性和可维护性。

通过这些最佳实践和高级功能,你将能够更好地利用 OpenFeign 构建健壮、可扩展的微服务应用。在实际项目中,根据业务需求和场景,可以灵活调整和优化 Feign 客户端的配置和功能。

  • OpenFeign接口参数还有哪些,请举例说明

  • OpenFeign 接口参数除了前面提到的 @PathVariable@RequestParam@RequestHeader@RequestBody 外,还有以下参数注解:

  1. @RequestPart : 用于将方法参数绑定到 multipart/form-data 类型的 HTTP 请求中的一部分。通常用于文件上传。例如:
@PostMapping(value = "/upload", consumes = MediaType.MULTIPART_FORM_DATA_VALUE) String uploadFile(@RequestPart("file") MultipartFile file); 

在这个例子中,filemultipart/form-data 请求的一个部分,@RequestPart("file") 将方法参数与请求部分进行绑定。

  1. @RequestLine : 用于自定义请求方法和 URI 模板,这样你可以脱离 Spring MVC 注解,并使用更底层的 Feign 注解。例如:
@RequestLine("GET /users/{id}") User getUserById(@Param("id") Long id); 

在这个例子中,@RequestLine("GET /users/{id}") 自定义了请求方法和 URI 模板,而 @Param("id") 将方法参数与 URI 模板变量进行绑定。

  1. @Headers : 用于自定义请求头。当与 @RequestLine 一起使用时,可以方便地设置静态请求头。例如:
@RequestLine("GET /users/{id}") @Headers("Authorization: Bearer your_access_token") User getUserById(@Param("id") Long id); 

在这个例子中,@Headers("Authorization: Bearer your_access_token") 为请求添加了一个静态的授权头。

注意:使用 @RequestLine@Headers 时,需要将 Feign 的 Contract 更改为 feign.Contract.Default。可以在自定义的 Feign 配置类中进行设置:

@Configuration public class CustomFeignConfig {      @Bean     public Contract feignContract() {         return new Contract.Default();     }      // ... } 

然后,在 @FeignClient 注解中引用这个配置类:

@FeignClient(value = "user-service", configuration = CustomFeignConfig.class) public interface UserFeignClient {     // ... } 

通过这些额外的参数注解,你可以根据需要灵活地处理不同类型的请求,如文件上传、自定义请求头等。在实际项目中,根据具体的接口需求,可以选择合适的参数注解来实现所需的功能。

  • OpenFeign接口参数前四种组合使用,都有哪些

  • 在 OpenFeign 接口中,@PathVariable@RequestParam@RequestHeader@RequestBody 四种参数注解可以按照需求灵活组合使用。以下是一些常见的组合示例:

  1. 使用 @PathVariable@RequestParam:
@GetMapping("/users/{id}/orders") List getUserOrders(@PathVariable("id") Long userId, @RequestParam("status") String status); 

在此示例中,我们使用 @PathVariable 从 URI 中获取用户 ID,并使用 @RequestParam 从查询参数中获取订单状态。

  1. 使用 @PathVariable@RequestHeader:
@GetMapping("/users/{id}") User getUserById(@PathVariable("id") Long id, @RequestHeader("Authorization") String authToken); 

在此示例中,我们使用 @PathVariable 从 URI 中获取用户 ID,并使用 @RequestHeader 从请求头中获取授权令牌。

  1. 使用 @RequestParam@RequestHeader:
@GetMapping("/search/users") List searchUsers(@RequestParam("query") String query, @RequestHeader("X-Api-Key") String apiKey); 

在此示例中,我们使用 @RequestParam 从查询参数中获取搜索查询,并使用 @RequestHeader 从请求头中获取 API 密钥。

  1. 使用 @RequestBody@RequestHeader:
@PostMapping("/users") User createUser(@RequestBody User newUser, @RequestHeader("Authorization") String authToken); 

在此示例中,我们使用 @RequestBody 从请求正文中获取新用户的信息,并使用 @RequestHeader 从请求头中获取授权令牌。

  1. 使用 @PathVariable@RequestParam@RequestHeader:
@GetMapping("/users/{id}/orders") List getUserOrders(@PathVariable("id") Long userId, @RequestParam("status") String status, @RequestHeader("Authorization") String authToken); 

在此示例中,我们结合了前面的示例,使用 @PathVariable 从 URI 中获取用户 ID,使用 @RequestParam 从查询参数中获取订单状态,并使用 @RequestHeader 从请求头中获取授权令牌。

  1. 使用 @PathVariable@RequestParam@RequestHeader@RequestBody:
@PostMapping("/users/{id}/orders") Order createOrderForUser(@PathVariable("id") Long userId, @RequestParam("type") String orderType, @RequestHeader("Authorization") String authToken, @RequestBody Order order); 

在此示例中,我们使用 @PathVariable 从 URI 中获取用户 ID,使用 @RequestParam 从查询参数中获取订单类型,使用 @RequestHeader 从请求头中获取授权令牌,并使用 @RequestBody 从请求正文中获取订单信息。

这些示例展示了如何灵活地组合 OpenFeign 接口参数注解以满足不同需求。在实际项目中,根据具体的接口和业务场景,可以选择合适的参数注解组合来实现所需的功能。

  • 当然,还有很多其他组合方式,主要取决于你的业务需求。以下是一些额外的示例:
  1. 使用 @PathVariable@RequestBody:
@PutMapping("/users/{id}") User updateUser(@PathVariable("id") Long userId, @RequestBody User updatedUser); 

在此示例中,我们使用 @PathVariable 从 URI 中获取用户 ID,并使用 @RequestBody 从请求正文中获取更新后的用户信息。

  1. 使用 @RequestParam@RequestBody:
@PostMapping("/orders/filter") List filterOrders(@RequestParam("status") String status, @RequestBody OrderFilter filter); 

在此示例中,我们使用 @RequestParam 从查询参数中获取订单状态,并使用 @RequestBody 从请求正文中获取过滤器信息。

  1. 使用多个 @RequestParam:
@GetMapping("/users") List getUsersByFilter(@RequestParam("minAge") Integer minAge, @RequestParam("maxAge") Integer maxAge, @RequestParam("country") String country); 

在此示例中,我们使用多个 @RequestParam 从查询参数中获取年龄范围和国家信息来过滤用户列表。

  1. 使用多个 @RequestHeader:
@GetMapping("/products") List getProducts(@RequestHeader("X-Api-Key") String apiKey, @RequestHeader("X-User-Token") String userToken); 

在此示例中,我们使用多个 @RequestHeader 从请求头中获取 API 密钥和用户令牌。

总之,OpenFeign 参数注解的组合方式非常灵活,可以根据实际业务场景选择适当的组合。这些示例仅仅是为了展示不同的组合方式,实际使用时请根据具体需求进行调整。

  • OpenFeign和sentinel整合有哪些知识点

  • OpenFeign 与 Sentinel 的整合可以让你在微服务之间的远程调用中实现流量控制、熔断降级和系统负载保护等功能。以下是一些与 OpenFeign 和 Sentinel 整合相关的知识点:

  1. 引入依赖 : 要整合 Sentinel 和 OpenFeign,需要在项目中引入 Sentinel 和 Spring Cloud Alibaba Sentinel 依赖。在 Maven pom.xml 文件中添加以下依赖:
     com.alibaba.cloud     spring-cloud-starter-alibaba-sentinel       com.alibaba.csp     sentinel-core  
  1. 配置 Sentinel : 在 application.propertiesapplication.yml 文件中配置 Sentinel 相关参数,例如:
spring:   cloud:     sentinel:       transport:         dashboard: localhost:8080         port: 8719 

在这里,我们配置了 Sentinel Dashboard 的地址和 Sentinel 客户端的端口。

  1. 定义 Fallback 方法 : 与 Hystrix 类似,Sentinel 也支持为 Feign 客户端定义 Fallback 方法,以便在发生熔断降级时提供备选方案。首先,为 Feign 客户端接口定义一个 Fallback 类:
@Component public class UserServiceFallback implements UserFeignClient {      @Override     public User getUserById(Long id) {         // 返回降级策略,例如返回一个默认的 User 对象         return new User("Fallback User");     }      // ... 实现其他方法的降级策略 } 

然后,在 @FeignClient 注解中指定 Fallback 类:

@FeignClient(value = "user-service", fallback = UserServiceFallback.class) public interface UserFeignClient {     // ... } 
  1. 定义 Sentinel 限流规则 : 为了实现限流功能,你需要为 Feign 客户端定义 Sentinel 限流规则。可以通过 Sentinel 控制台或者编程方式定义规则。以编程方式为例:
public class SentinelConfiguration {      @PostConstruct     public void initFlowRules() {         List rules = new ArrayList<>();         FlowRule rule = new FlowRule("user-service");         rule.setCount(20);         rule.setGrade(RuleConstant.FLOW_GRADE_QPS);         rule.setLimitApp("default");         rules.add(rule);         FlowRuleManager.loadRules(rules);     } } 

在这个示例中,我们为 user-service 定义了一个 QPS 限流规则,限制每秒请求数量为 20。

  1. 自定义异常处理 : 当 Sentinel 触发限流、熔断等操作时,你可能需要自定义异常处理。可以通过实现 BlockExceptionHandler 接口来自定义异常处理逻辑:
@Component public class CustomBlockExceptionHandler implements BlockExceptionHandler {      @Override     public void handle(HttpServletRequest request, HttpServletResponse response, BlockException e) throws Exception {         // 自定义异常处理逻辑     } } 

通过以上知识点,你应该能够在 OpenFeign 和 Sentinel 中实现流量控制、熔断降级等功能。但是,为了更好地应用这些知识点,你还需要了解以下相关概念:

  1. 熔断降级策略 : Sentinel 提供了多种熔断降级策略,例如基于响应时间的降级、异常比例降级和异常数降级等。你需要了解这些策略以便根据实际场景选择合适的策略。
  2. 热点参数限流 : Sentinel 支持基于方法参数的热点参数限流。通过这种限流方式,你可以根据调用参数值对接口进行细粒度的限流。了解如何在 Feign 客户端中使用热点参数限流将有助于更好地控制系统流量。
  3. 系统负载保护 : Sentinel 还提供了系统负载保护功能,可以根据系统的负载情况对调用进行限制,从而保护系统稳定。你需要了解如何在 Feign 客户端中配置和使用系统负载保护。
  4. Sentinel 控制台 : Sentinel 控制台是一个用于管理和监控 Sentinel 规则和指标的 Web 应用程序。了解如何使用 Sentinel 控制台可以帮助你更好地管理和监控整个系统的流量控制、熔断降级等策略。
  5. 集成其他组件 : Sentinel 可以与其他 Spring Cloud 组件(如 Spring Cloud Gateway、Spring Cloud Sleuth 等)进行整合,以实现更丰富的功能。了解如何与这些组件整合可以帮助你更好地构建和管理微服务架构。

学习和理解这些知识点将有助于你更好地在 OpenFeign 和 Sentinel 中实现流量控制、熔断降级和系统负载保护等功能。在实际项目中,你需要根据业务需求和场景选择合适的 Sentinel 策略和配置。

相关内容

热门资讯

总算了解Wepoke测试软件透... 总算了解Wepoke测试软件透明挂!太坑了原来真的是有挂的(有挂方法)(哔哩哔哩)总算了解Wepok...
第三方教程《微扑克辅助安卓版本... 第三方教程《微扑克辅助安卓版本》微扑克智能外挂辅助器安卓版本(哔哩哔哩)第三方教程《微扑克辅助安卓版...
新手必备!wpk辅助器(wpK... 新手必备!wpk辅助器(wpK)辅助透视!(透视辅助)详细教程(2023已更新)(哔哩哔哩);最新版...
传递经验微扑克智能原来是真的有... 传递经验微扑克智能原来是真的有挂,太离谱了原来确实是有挂,详细教程(有挂方法)传递经验微扑克智能原来...
玩家科普!微扑克代打辅助器脚本... 玩家科普!微扑克代打辅助器脚本(辅助挂)原来真的有挂(有挂神器)详细教程(哔哩哔哩)玩家科普!微扑克...
指导大家《Wepoke德州版本... 亲,这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,...
记者爆料!(WPK插件)透视辅... 记者爆料!(WPK插件)透视辅助!(透视)外挂辅助挂程序(2025已更新)(哔哩哔哩)记者爆料!(W...
重大通报《Wepoke网页版》... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
一分钟揭秘!(wpk规律)辅助... 一分钟揭秘!(wpk规律)辅助透视!(透视)外挂辅助插件(2023已更新)(哔哩哔哩);小薇(透视辅...
分享个大家《Wepokeapp... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【757446909】很多玩家在这款游戏中打牌都...