11

我正在尝试将域事件存储在 postgres 数据库中。很多事情我都不确定,也不想以后重新设计这个结构,所以我正在寻求有事件溯源经验的人的指导。我目前有下表:

domain events
    version - or event id, integer sequence, helps to maintain order by replays
    type - event type, probably classname with namespace
    aggregate - aggregate id, probably random string for each aggregate
    timestamp - when the event occured
    promoter - the promoter of the event, probably user id
    details - json encoded data about the properties

我不确定:

  1. 我应该存储领域事件的发起人吗?
    通过安全漏洞找到受损帐户可能会有所帮助,但我不知道要存储什么,例如通过 CRONjob。
  2. 我应该以什么格式存储事件类型?
    我应该添加一个包含事件类型的表,还是类名就足够了?
    我应该添加事件组吗?
  3. 我对有界上下文的定义感到困惑。据我所知,每个聚合都可以有多个有界上下文,因此我可以在多个模块中使用单个聚合的不同方面。听起来不错,因为例如帐户可以与许多事物相关,包括身份验证、授权、用户配置文件、用户帖子、用户合同等等……
    我不确定,域事件可以有多个有界上下文,还是只有一个,所以我也应该存储事件上下文吗?(对于我想重播与单个上下文相关的事件的情况)
    如何在单个聚合类中实现这么多属性,我应该使用某种组合吗?
4

1 回答 1

9

1.我应该存储领域事件的发起人吗?

我认为如果您将启动器存储为事件有效负载的一部分而不是元数据,它会更加灵活。安全问题应在域外处理。并非每个事件都是由用户提出的,尽管您可以为他们制作一个假的(CronJob 的系统管理员)。

例如:

ManualPaymentMadeEvent { //store this object as details in your schema
    amount,
    by_user//In this case, developers can determine whether store the promoter case by case
}

2.我应该以什么格式存储事件类型?
我应该添加一个包含事件类型的表,还是类名就足够了?我应该添加事件组吗?

我认为类名就足够了。添加另一个表会使事件读取复杂化(通过连接表),我认为它只会在重命名类名时增加价值(更新事件类型表中的一行)。但我认为使用它不会增加太多麻烦

update domain_events set 
    aggregate_type = 'new class name'
where aggregate_type = 'origin class name'

我不确定我是否了解事件组,您能否添加更多解释?

3.我不确定,域事件可以有多个有界上下文,或者只有一个,所以我也应该存储事件上下文吗?

有时事件用于集成多个上下文。但是每个事件仅在一个上下文中引发。例如,在 ordering 上下文中引发了 ManualPaymentMadeEvent,在 shipping 上下文中的事件侦听器也消费它,将其视为开始发货的触发器。

我更喜欢在每个上下文中使用每个数据库用户(oracle 术语)。shipping.domain_events 用于运输上下文,而 ordering.domain_events 用于订购上下文。

这是轴突框架中的模式,可能会有所帮助

create table DomainEventEntry (
    aggregateIdentifier varchar2(255) not null,
    sequenceNumber number(19,0) not null,
    type varchar2(255) not null,  --aggregate class name
    eventIdentifier varchar2(255) not null,
    metaData blob,   
    payload blob not null, -- details
    payloadRevision varchar2(255),
    payloadType varchar2(255) not null, --event class name
    timeStamp varchar2(255) not null
);

alter table DomainEventEntry
    add constraint PK_DomainEventEntry primary key (aggregateIdentifier, sequenceNumber, type);
于 2014-05-04T01:26:01.643 回答