是的,之前至少有几次问过类似的事情。因此,我知道答案:您只需重放新处理程序上的事件,简单。但是,实际执行会引发一些问题。
我正在使用JOlivier的EventStore,这看起来不错。对于初学者,我会忽略SnapShots的概念,只是看一下让我的事件出来的方法。我能做的就是这段代码:
var commitList = Store.GetFrom(DateTime.UtcNow.AddSeconds(-1));
foreach (var commit in commitList)
{
foreach (var comittedEvent in commit.Events)
{
if (comittedEvent.Body is SomeDomainEvent)
Console.WriteLine(string.Format("Found interesting event: {0}", ((SomeDomainEvent)comittedEvent.Body).Value));
}
}
这里的第一个问题当然是:这是做到这一点的方法吗?我在使用“GetFrom”参数时遇到了麻烦,因为它只是一个DateTime,我无法确定所有服务器是否在时间上同步。如果一台服务器上的时钟落后于另一台服务器1分钟怎么办?还是½小时?我也在使用NServiceBus,所以新的处理程序队列会在某个时间点堆积事件 - 但我怎么能100%确定这里没有10秒丢失?请告诉我如何从EventStore中获取事件,同时100%(不是99%)确保新应用程序视图在启动时完全同步。
另外:您是否在代码中创建了一种特殊的导入方法?我的意思是,假设我的新应用程序中的处理程序在处理“SomeDomainEvent”时发送了一封电子邮件。我不希望它发送所有10.000个旧活动的电子邮件。你如何在praxis / code中执行“import”?
感谢。
答案 0 :(得分:1)