目标
目标
命名的策略被应用于目标。Dapr支持三种目标类型,这些类型适用于所有Dapr构建块的API:
apps
components
actors
应用程序
使用apps
目标,您可以将retry
、timeout
和circuitBreaker
策略应用于Dapr应用程序之间的服务调用。在targets/apps
下,策略应用于每个目标服务的app-id
。当sidecar之间的通信出现故障时,这些策略将被调用,如下图所示。
Dapr提供了内置的服务调用重试,因此任何应用的
retry
策略都是额外的。
data:image/s3,"s3://crabby-images/ed2b6/ed2b675325d23686a9ecd30d2ecc6c05edaadc67" alt="显示服务调用弹性的图示"
应用于目标应用程序app-id
为"appB"的策略示例:
specs:
targets:
apps:
appB: # 目标服务的app-id
timeout: general
retry: general
circuitBreaker: general
组件
使用components
目标,您可以将retry
、timeout
和circuitBreaker
策略应用于组件操作。
策略可以应用于outbound
操作(从Dapr sidecar到组件的调用)和/或inbound
(从sidecar到您的应用程序的调用)。
出站
outbound
操作是从sidecar到组件的调用,例如:
- 持久化或检索状态。
- 在pubsub组件上发布消息。
- 调用输出绑定。
某些组件可能具有内置的重试功能,并且可以在每个组件的基础上进行配置。
data:image/s3,"s3://crabby-images/519a3/519a32f03fcaac6c1d6288a6c03eadff889bdeeb" alt="显示服务调用弹性的图示"
spec:
targets:
components:
myStateStore:
outbound:
retry: retryForever
circuitBreaker: simpleCB
入站
inbound
操作是从sidecar到您的应用程序的调用,例如:
- pubsub订阅在传递消息时。
- 输入绑定。
某些组件可能具有内置的重试功能,并且可以在每个组件的基础上进行配置。
data:image/s3,"s3://crabby-images/1ab69/1ab69edcc844051fd4bf0fc5648ca6b7d24425d0" alt="显示服务调用弹性的图示"
spec:
targets:
components:
myInputBinding:
inbound:
timeout: general
retry: general
circuitBreaker: general
PubSub
在pubsub target/component
中,您可以同时指定inbound
和outbound
操作。
data:image/s3,"s3://crabby-images/03ddd/03ddd417a1c7518af111cf131da23f80d4b4512a" alt="显示服务调用弹性的图示"
spec:
targets:
components:
myPubsub:
outbound:
retry: pubsubRetry
circuitBreaker: pubsubCB
inbound: # 入站仅适用于从sidecar到应用程序的传递
timeout: general
retry: general
circuitBreaker: general
Actor
使用actors
目标,您可以将retry
、timeout
和circuitBreaker
策略应用于actor操作。
当为actors
目标使用circuitBreaker
策略时,您可以通过circuitBreakerScope
指定电路断开的范围:
id
:单个actor IDtype
:给定actor类型的所有actorboth
:以上两者
您还可以使用circuitBreakerCacheSize
属性指定要在内存中保留的电路断路器数量的缓存大小,提供一个整数值,例如5000
。
示例
spec:
targets:
actors:
myActorType:
timeout: general
retry: general
circuitBreaker: general
circuitBreakerScope: both
circuitBreakerCacheSize: 5000
下一步
尝试其中一个弹性快速入门:
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.