处理 Axon 中的重要命令和事件有效负载

Dealing with non-trivial command and event payloads in Axon

每当我看到 Axon Bank 时,我就开始怀疑我是否应该遵循一套事件和命令的设计规则。

在 Axon Bank 中,事件和命令都完全由原语组成。在我的应用程序中,我倾向于尽可能避免使用原始用法,主要是为了构建一个富有表现力的域并在任何可以获得的地方都具有类型安全性。

Axon 本身带有一些 DDD 参考,但无论我浏览哪些文档,都没有一个示例使用复合对象作为 event/command 有效负载的一部分。

这让我很困惑。对成熟的 xml 和 json 序列化有内置支持,不仅仅是一些键值对。

我理解特别是事件往往是小而简单的结构,因为它们只反映增量状态变化,但复杂的领域模型和事件(条目)之间总会存在某种差距。


在我的域中,我可以有一堆 类,例如 OverdraftLimitCurrentBalanceDepositAccountIdentifier

现在有两种可能的方式来设计事件和命令:

1。原语和广泛的转换

优点:

缺点:

2。表达有效载荷

优点:

缺点:

我需要第二个意见。有推荐的方法吗?

首先要记住的是,事件的序列化形式是您的正式合同。最后,您如何在 Java 类 中表示取决于每个应用程序。例如,如果您将序列化程序配置为忽略未知字段,则可以将您不关心的字段留在外面。

就我个人而言,我不介意事件中的原语。但是,我确实理解为某些字段使用显式值对象的价值,因为它们允许您表达每个字段所涉及的 "mathematics"。在标识符的情况下,它们可以防止 "mix-up" 使用标识符意外地尝试识别另一种类型的对象。

说到底,没那么重要。通过一些简单的 Jackson 注释,您可以将这些值对象转换为 JSON 中的简单值。例如,查看 @JsonValue

public class BankAccountCreatedEvent {
    private final BankAccountIdentifier bankAccountIdentifier;
    private final OverdraftLimit overdraftLimit;

    //..
}

将映射到:

{
    "bankAccountIdentifier": "abcdef1234",
    "overdraftLimit" : 1000
}

如果 BankAccountIdentifier 和 OverdraftLimit 类 都有一个 @JsonValue 注释方法,该方法将 return 它们的 'simple' 值。