You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
A recurring concern was raised in Discord and then in dapr/dapr#8208 indicating that it was unclear why the app would fail to start up during workflow initialization and this was later traced to there not being an actorStateStore registered to use.
While this makes for a prime documentation target to clarify, the SDK could do more on this front as well.
The specific details need more consideration, but I'm initially thinking that because of the hot reload capability for components, this should be implemented as a sort of health check (read: recurring) registered whenever the developer registers the Dapr actor runtime or the Dapr workflow client. As @olitomlinsonmentioned, rather than necessarily expand on the Health API here, this could simply retrieve the configuration from the Metadata endpoint and indicate whether an actor-compatible state store is registered, then fail in the application with a clear exception.
Release Note
RELEASE NOTE: ADD Validate whether actor state store is correctly registered during SDK initialization preempting endless connection failures
The text was updated successfully, but these errors were encountered:
I think using the metadata endpoint for an initial check is fine, as this is going to cover most common use-cases.
I also think that if a mismatch is detected, then the SDK should throw an Exception, rather than just log an error/warning.
The solution can eventually be upgraded to support post-initialisation changes i.e. with hot-reload support, but I see this as a should, not a must at this point.
I started to take a look at this.
My sample is running with Aspire and contains a Redis state store and a workflow-invoking API application.
How would I know whether or not an actor state store is configured based on the v1.0/metadata response?
The JSON below looks similar in both situations.
Describe the feature
A recurring concern was raised in Discord and then in dapr/dapr#8208 indicating that it was unclear why the app would fail to start up during workflow initialization and this was later traced to there not being an actorStateStore registered to use.
While this makes for a prime documentation target to clarify, the SDK could do more on this front as well.
The specific details need more consideration, but I'm initially thinking that because of the hot reload capability for components, this should be implemented as a sort of health check (read: recurring) registered whenever the developer registers the Dapr actor runtime or the Dapr workflow client. As @olitomlinson mentioned, rather than necessarily expand on the Health API here, this could simply retrieve the configuration from the Metadata endpoint and indicate whether an actor-compatible state store is registered, then fail in the application with a clear exception.
Release Note
RELEASE NOTE: ADD Validate whether actor state store is correctly registered during SDK initialization preempting endless connection failures
The text was updated successfully, but these errors were encountered: