Fazer com que um sistema lance eventos de notificação para toda modificação no estado de uma entidade abre espaço para algumas soluções interessantes.

Podemos, por exemplo, usar os eventos de notificação para, além de permitir implementação desacoplada de consistência eventual entre aplicações,  contar a “história” de uma entidade, através de uma técnica conhecida como Event Sourcing.

A ideia central da técnica é reconhecer que o estado de uma entidade é “explicado” pela ocorrência de uma sequência clara de eventos, em uma ordem determinada.

Com posse do histórico de eventos de notificação de alteração de estado, podemos restituir qualquer um dos “estados históricos” de uma entidade, bastando, para isso, que realizar um replay do seu histórico de eventos até o ponto apropriado.

 

Em termos simples, matendo o histórico de eventos armazenado, podemos “recuperar” o estado de uma entidade, em qualquer momento. Podemos também saber quando mudanças ocorreram, quem fez essas mudanças e qual foi a intenção de negócio. Poderoso, porém complexo!

Sistemas que usam event sourcing costumam manter, além da base de eventos, uma outra base com materializações do estado da entidade em algum momento (geralmente o atual).

Essa materialização é útil por ser extermamente fácil de pesquisar. Podemos pensar essas materializações como “fotografias” do estado da entidade em algum momento. Talvez por isso, convencionou-se utililizar a designação snapshot. 

A base de dados utilizada para armazenar eventos geralmente é nosql (o NuBank, por exemplo, utiliza Datomic para registrar transações). A base para os snapshots pode ser quaquer uma, inclusive relacionais. Aliás, Greg Young, que formalizou o conceito de Event Sourcing, criou um banco de dados para armazenar eventos chamado EventStore.

Há diversas implementações de event sourcing em sistemas de mercado. Ou seja, existem diversos sistemas que mantém um histórico de eventos para justificar o estado de suas entidade.

Em um banco, poderíamos assumir que o “estado” do nosso saldo atual é explicado por uma série de eventos registrados em nosso extrato. No Github, o estado de nosso código fonte é explicado por uma série de commits. 

De qualquer forma, event sourcing está longe de ser tópico ou prática comum. Há uma diversidade gigantesca de complicações para uma implementação correta e precisa existir uma justificativa muito forte para que você o adote.

Já implementou um sistema usando event sourcing? Compartilhe suas impressões.

Compartilhe este insight:

Comentários

Participe deixando seu comentário sobre este artigo a seguir:

Subscribe
Notify of
guest
3 Comentários
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
Isaque
Isaque
3 anos atrás

Primeiramente parabéns pelo post e pelo conteúdo, que vem postando(realmente dotnet além do crud).
Event sourcing ou o uso de mensageria tem que justificar muito em um projeto. A complexidade aumenta muito até para depurar, com qualquer que seja a tecnologia escolhida (Rabbitmq, Kafka, Akka). Grandes poderes, Grandes responsabilidades.

Roberto Nascimento
Roberto Nascimento
3 anos atrás

Parabéns pelo artigo!!!

Já tive experiência com event-sourcing, mas não de um sistema e sim parte dele.

Nesse caso era referente a um cadastro de taxa de prestação de serviço, esta informação era enviada via integração por outro sistema. Então, todas as mudanças da entidade era armazenada numa estrutura NoSQL. Assim era possível ver quando a forma de cobrança era alterada e o motivo.

Gabriel
Gabriel
3 anos atrás

Elemar, me tire uma duvida por favor. Digamos que eu tenha um sistema onde parte dele é CRUD simples, onde vou ter configurações de alguns atributos para serem usados em processamento futuro. E a outra parte do sistema é referente a este processamento, onde com base nas configurações feitas nos CRUDs irei tomar decisões, essas decisões poderiam ser tratadas como eventos. Seria errado para o CRUD eu usar uma abordagem mais simples (sem eventos) e para a parte do processamento ai sim eu usaria eventos, handlers, etc?

E outra dúvida é com relação ao armazenamento de estado, é obrigatório ou boa prática ter armazenado o estado atual do meu item?

AUTOR

Elemar Júnior
Fundador e CEO da EximiaCo atua como tech trusted advisor ajudando empresas e profissionais a gerar mais resultados através da tecnologia.

NOVOS HORIZONTES PARA O SEU NEGÓCIO

Nosso time está preparado para superar junto com você grandes desafios tecnológicos.

Entre em contato e vamos juntos utilizar a tecnologia do jeito certo para gerar mais resultados.

Insights EximiaCo

Confira os conteúdos de negócios e tecnologia desenvolvidos pelos nossos consultores:

Engenharia de Software

Três vantagens reais de utilizar orquestradores BPM para serviços

Arquiteto de software e solução com larga experiência corporativa
Desenvolvimento de Software

Os principais desafios ao adotar testes

Especialista em Testes e Arquitetura de Software
Arquitetura de Dados

Insights de um DBA na análise de um plano de execução

Especialista em performance de Bancos de Dados de larga escala

Acesse nossos canais

Simplificamos, potencializamos e aceleramos resultados usando a tecnologia do jeito certo

EximiaCo 2022 – Todos os direitos reservados

3
0
Queremos saber a sua opinião, deixe seu comentáriox
()
x

Event Sourcing

Para se candidatar nesta turma aberta, preencha o formulário a seguir:

Condição especial de pré-venda: R$ 14.000,00 - contratando a mentoria até até 31/01/2023 e R$ 15.000,00 - contratando a mentoria a partir de 01/02/2023, em até 12x com taxas.

Tenho interesse nessa capacitação

Para solicitar mais informações sobre essa capacitação para a sua empresa, preencha o formulário a seguir:

Tenho interesse em conversar

Se você está querendo gerar resultados através da tecnologia, preencha este formulário que um de nossos consultores entrará em contato com você:

O seu insight foi excluído com sucesso!

O seu insight foi excluído e não está mais disponível.

O seu insight foi salvo com sucesso!

Ele está na fila de espera, aguardando ser revisado para ter sua publicação programada.

Tenho interesse em conversar

Se você está querendo gerar resultados através da tecnologia, preencha este formulário que um de nossos consultores entrará em contato com você:

Tenho interesse nessa solução

Se você está procurando este tipo de solução para o seu negócio, preencha este formulário que um de nossos consultores entrará em contato com você:

Tenho interesse neste serviço

Se você está procurando este tipo de solução para o seu negócio, preencha este formulário que um de nossos consultores entrará em contato com você:

× Precisa de ajuda?