Orleans 2.0 官方文档 —— 4.9.5 Grains -> 事件溯源 -> 通知

通知

通常很方便地就能够对状态变化作出反应。所有回调均受到Orleans的回合机制的保证;另请参阅“并发保证”一节。

追踪确认的状态

若要通知确认状态的任何更改,JournaledGrain子类可以重写此方法:

protected override void OnStateChanged()
{
   // read state and/or event log and take appropriate action
}

每当更新确认的状态时,会调用OnStateChanged,即版本号增加。这可能发生在:

  1. 从存储中加载了更新的版本的状态。
  2. 此实例激发的事件已成功写入存储。
  3. 从其他一些实例收到通知消息。

请注意,由于所有grain的初始版本都为0,因此在存储的初始加载完成之前,这意味着每当初始加载完成且版本大于0时,就会调用OnStateChanged

追踪暂定状态

若要通知暂定状态的任何更改,JournaledGrain子类可以重写此方法:

protected override void OnTentativeStateChanged()
{
   // read state and/or events and take appropriate action
}

每当暂定状态改变时,即组合序列(ConfirmedEvents + UnconfirmedEvents)更改时,都会调用OnTentativeStateChanged特别是,OnTentativeStateChanged()的回调始终在发生在RaiseEvent期间

你可能感兴趣的:(Orleans)