关于后端:一文入门-Spring-Cloud-Tencent

41次阅读

共计 4072 个字符,预计需要花费 11 分钟才能阅读完成。

Spring Cloud Tencent 是什么

Spring Cloud Tencent 是腾讯开源的一站式微服务解决方案。Spring Cloud Tencent 实现了 Spring Cloud 规范微服务 SPI,开发者能够基于 Spring Cloud Tencent 疾速开发 Spring Cloud 微服务架构利用。Spring Cloud Tencent 的外围依靠腾讯开源的一站式服务发现与治理平台 Polarismesh,实现各种散布式微服务场景。

Spring Cloud Tencent 提供的能力包含但不限于:

一、装置北极星

北极星是腾讯开源的服务发现和治理核心,致力于解决分布式或者微服务架构中的服务可见、故障容错、流量管制和平安问题。尽管,业界曾经有些组件能够解决其中一部分问题,然而短少一个规范的、多语言的、框架无关的实现。

腾讯具备海量的分布式服务,加上业务线和技术栈的多样性,积淀了大大小小数十个相干组件。从 2019 年开始,咱们通过北极星对这些组件进行形象和整合,打造公司对立的服务发现和治理计划,帮忙业务晋升研发效率和经营品质。

北极星装置十分的简略下载响应平台的 zip 间接运行即可

二、服务注册与发现

  • 服务减少 polaris-discovery 依赖
<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-discovery</artifactId>
</dependency>
  • application.yaml 接入 polaris server
spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091
  • 启动服务察看 polaris console

  • 服务调用示例
@Bean
@LoadBalanced
public RestTemplate restTemplate() {return new RestTemplate();
}

@Autowired
private RestTemplate restTemplate;

@GetMapping("/consumer")
public String consumer() {return restTemplate.getForObject("http://lengleng-tencent-discovery-provider/provider/lengleng", String.class);
}

三、配置管理

在利用启动 Bootstrap 阶段,Spring Cloud 会调用 PolarisConfigFileLocator 从 Polaris 服务端获取配置文件并加载到 Spring 上下文里。通过 Spring Boot 规范的 @Value,@ConfigurationProperties 注解即可获取配置内容。动静配置刷新能力,则通过 Spring Cloud 规范的 @RefreshScope 机制实现。

  • 服务减少 polaris-config 依赖
<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-config</artifactId>
</dependency>
  • bootstrap.yaml 接入 polaris-config
spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8081
      config:
        groups:
          - name: ${spring.application.name}
            files: "application"

特地留神: 这里须要配置在 bootstrap,spring-cloud-tencent 未适配 spring boot 最新的文件加载机制

  • 北极星控制台减少配置

  • 代码应用配置
@Value("${name:}")
private String name;

四、服务限流

服务限流是最常见的一种服务自我保护措施之一,避免流量洪峰打垮服务。Spring Cloud Tencent Rate Limit 模块内置了针对 Spring Web 和 Spring WebFlux 场景的限流 Filter,联合 Polaris 的限流性能帮忙业务疾速接入限流能力。

  • 服务减少 polaris-ratelimit 依赖

应用限流组件时增加 discovery , 不便在服务列表编辑

<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-discovery</artifactId>
</dependency>
<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-ratelimit</artifactId>
</dependency>
  • 服务接入 polaris-ratelimit
spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091
      namespace: default
      ratelimit:
        reject-http-code: 403
        reject-request-tips: "lengleng test rate limit"
  • 北极星控制台减少限流规定

五、服务路由

polaris 可能实现的路由模式较多元数据路由、就近路由、规定路由、自定义路由等模式,本文以元数据路由演示,如下图只会路由至雷同元数据信息的服务

  • 服务减少 polaris-router 依赖
<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-router</artifactId>
</dependency>
  • 服务标记元数据
spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091
    tencent:
      metadata:
        content:
          version: local

六、限流熔断

故障实例熔断是常见的一种容错爱护机制。故障实例熔断能实现主调方迅速主动屏蔽错误率高或故障的服务实例,并启动定时工作对熔断实例进行探活。在达到复原条件后对其进行半开复原。在半开复原后,开释大量申请去进行实在业务探测。并依据实在业务探测后果去判断是否齐全恢复正常。

  • 增加限流熔断相干的依赖 polaris-circuitbreaker
<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-circuitbreaker</artifactId>
</dependency>

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

<dependency>
    <groupId>com.tencent.cloud</groupId>
    <artifactId>spring-cloud-starter-tencent-polaris-discovery</artifactId>
</dependency>

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-circuitbreaker-spring-retry</artifactId>
</dependency>

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
  • 提供 Feign 服务调用实现

spring-cloud-tencent 以后版本仅反对 feign 熔断

@FeignClient(contextId = "demoFeign", value = "lengleng-circuitbreaker-tencent-circuitbreaker-provider",
        fallback = DemoFeignFallback.class)
public interface DemoFeign {@GetMapping("/provider")
    String get(@RequestParam String name);

}
  • 服务接入 polaris-circuitbreaker
spring:
  cloud:
    polaris:
      address: grpc://127.0.0.1:8091

#开启断路器
feign:
  circuitbreaker:
    enabled: true
  • 编写熔断规定 polaris.yml
consumer:
  circuitBreaker:
    checkPeriod: 100ms
    chain:
      - errorCount
      - errorRate
    plugin:
      errorCount:
        continuousErrorThreshold: 1
        metricNumBuckets: 1
      errorRate:
        errorRateThreshold: 100
        metricStatTimeWindow: 1s
        requestVolumeThreshold: 1

全文配套源码: https://github.com/lltx/spring-cloud-tencent-demo

本文由 mdnice 多平台公布

正文完
 0