我一直在寻找使用J Oliver的EventStore和mongo作为持久层的新项目的事件采购,但是遇到了一些问题:
- 在尝试事件采购之前,我的域名持久存储到数据库,我一直在使用Udi的域事件pattern,这对我来说非常有效,NHibernate负责管理工作单元。但是我最终得到了一个可以影响多个聚合的工作单元,例如。
我“结帐”我的购物篮聚合,它会引发一个事件,处理程序通过创建发票聚合来响应,这反过来又会引发一个事件(这只是一个例子)
在这种情况下,我有一个工作单元改变了两个聚合根 - 在事件存储中我可以将引发的事件添加到两个不同的事件流中,但它们不会以原子方式持久化(第一个可能成功,第二个失败) 。那么人们做些什么来避免发生这种情况呢?
- 在github主页上,它建议您可以使用流畅的界面来配置EventStore,但是当我下载源代码时,编译它并查看示例中的连接类似乎不可用 - 它是否在不同的分支中? (我有主人)
- 处理IStoreEvents impl的推荐方法是什么?作为一个类似于Nhibernates会议工厂的单身人士?