TSF 原生应用概述

最近更新时间: 2024-10-17 17:10:00

TSF 原生应用基于开源的 Spring Cloud 应用,无需改造可直接接入TSF,使用 TSF 服务治理和调用链等功能。

优势说明

  • 无需修改应用代码

  • 无需引入额外 SDK(除调用链外)

  • 无需额外配置

实现原理

应用到注册中心的所有请求如注册、发现,会被代理到我们自己的注册中心从而完成服务的注册和发现。当前的服务治理功能是基于 [TSF Mesh] 来实现的,服务调用会经过 TSF Mesh 的 sidecar,在 sidecar 中实现负载均衡、服务路由等治理功能。

注意:

服务中的熔断、限流功能可能会 TSF 自身的功能冲突,请确保只开启了一种,否则可能会产生非预期的结果。如果确定要启用 TSF 的治理功能来代替服务自身的,可以参考 【关闭服务熔断和限流规则】 。

功能说明

目前仅支持 Spring Cloud,且支持 Eureka/Consul 两种注册中心。后续可能支持更多语言和框架,以及更多注册中心。具体如下:

spring cloud功能 开源实现 原生应用 说明
注册发现 Netflix Eureka Consul Discovery 兼容 -
负载均衡 Netflix Ribbon Spring Cloud loadbalancer 兼容 -
服务调用 Feign RestTemplate 兼容 自定义标签,需在 HTTP 请求头添加 tsf-mesh-tag: KEY=VALUE
服务限流 - 支持 自定义标签,需在 HTTP 请求头添加 tsf-mesh-tag: KEY=VALUE
服务熔断 hystrix 支持 -
服务鉴权 - 支持 自定义标签,需在 HTTP 请求头添加 tsf-mesh-tag: KEY=VALUE
配置管理 Config Server Consul Config 支持 引入 tsf-sdk
链路追踪 Spring Cloud Sleuth zipkin 兼容 -
微服务网关 Spring Cloud Gateway Netflix Zuul 兼容 -