java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringCloud Alibaba 服务调用和负载均衡

SpringCloud Alibaba 核心组件解析:服务调用和负载均衡

作者:我登哥MVP

这段文章主要介绍了SpringCloud Alibaba体系中Sentinel与OpenFeign的整合使用方法及其核心优势,详细解释了配置步骤、降级链路机制,并并列举了常见问题及解决方案,帮助助开发者更好地应用此技术栈进行服务调用优化

技术栈:Spring Boot 3.2.0 + Spring Cloud Alibaba 2023.0.0.0-RC1 + Nacos Discovery + OpenFeign + Sentinel

2.1 是什么 — Alibaba 体系的服务调用

Alibaba 体系的服务调用与 Spring Cloud 官方基本一致(RestTemplate + OpenFeign),核心差异在于:

  1. 注册中心用 Nacos 替代 Consul/Eureka
  2. 熔断降级用 Sentinel 替代 Resilience4J
  3. Sentinel 与 OpenFeign 的整合更加原生

2.2 为什么 — Sentinel + OpenFeign 整合的优势

// 官方:OpenFeign + Resilience4J
@FeignClient(value = "service-name")
public interface Api { ... }
// + yaml 配置 + @CircuitBreaker 注解
// Alibaba:OpenFeign + Sentinel
@FeignClient(value = "nacos-payment-provider", fallback = Fallback.class)
public interface PayFeignSentinelApi { ... }
// + feign.sentinel.enabled: true
// → 更简洁,Sentinel 控制台可实时查看 Feign 调用数据

核心优势

2.3 怎么做 — 完整步骤

2.3.1 公共 Feign 接口(cloud-api-commons)

// @FeignClient 的 fallback 参数 = Sentinel 降级的兜底类
@FeignClient(value = "nacos-payment-provider",
             fallback = PayFeignSentinelApiFallBack.class)
public interface PayFeignSentinelApi {
    @GetMapping("/pay/nacos/get/{orderNo}")
    ResultData getPayByOrderNo(@PathVariable("orderNo") String orderNo);
}

2.3.2 Fallback 实现类

@Component  // ← 必须加,否则 Spring 找不到
public class PayFeignSentinelApiFallBack implements PayFeignSentinelApi {
    @Override
    public ResultData getPayByOrderNo(String orderNo) {
        return ResultData.fail(
            ReturnCodeEnum.RC500.getCode(),
            "对方服务宕机或不可用,FallBack服务降级o(╥﹏╥)o"
        );
    }
}

2.3.3 Consumer 配置

# 激活 Sentinel 对 Feign 的支持(核心开关!)
feign:
  sentinel:
    enabled: true    # 不加这行,fallback 不生效!
service-url:
  nacos-user-service: http://nacos-payment-provider

2.3.4 Consumer 调用

@RestController
public class OrderNacosController {
    @Resource
    private PayFeignSentinelApi payFeignSentinelApi;
    @GetMapping(value = "/consumer/pay/nacos/get/{orderNo}")
    public ResultData getPayByOrderNo(@PathVariable("orderNo") String orderNo) {
        return payFeignSentinelApi.getPayByOrderNo(orderNo);
    }
}

2.3.5 RestTemplate 方式(同样支持)

@Configuration
public class RestTemplateConfig {
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}
// 使用
@GetMapping("/consumer/pay/nacos/{id}")
public String paymentInfo(@PathVariable("id") Integer id) {
    return restTemplate.getForObject(
        "http://nacos-payment-provider/pay/nacos/" + id, String.class);
}

2.4 降级链路全景

Consumer 调用 payFeignSentinelApi.getPayByOrderNo()
    │
    ├→ Feign 调用成功 → 返回正常结果 ✅
    │
    └→ Feign 调用失败(超时/异常/Provider 宕机)
         │
         └→ Sentinel 拦截 → 走 PayFeignSentinelApiFallBack.getPayByOrderNo()
              │
              └→ 返回 "对方服务宕机或不可用..."

2.5 面试题

Q:@FeignClientfallbackfallbackFactory 有什么区别?

fallback 只返回降级结果;fallbackFactory 可以获取到异常信息(Throwable),根据不同的异常类型返回不同的降级数据,更加灵活。

2.6 踩坑指南

说明
🔴 Fallback 类忘记加 @ComponentSpring 找不到实现类,Feign 启动报错
🔴 忘记配置 feign.sentinel.enabled=truefallback 不生效,远程调用失败直接抛异常
🔴 Fallback 方法的返回值要一致Fallback 实现的方法返回值必须与接口完全一致

2.7 章节总结

到此这篇关于SpringCloud Alibaba 核心组件解析:服务调用和负载均衡的文章就介绍到这了,更多相关SpringCloud Alibaba 服务调用和负载均衡内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文