0
votes

I'm currently using Event Driven Architecture in microservices. I have one question related to event based systems:

For example, suppose I have a Person model which reacts to ProfileChangeEvent(contains the name that the Person need to update with). Now I have the following situation in steps:

  1. Change profile name to 'Mike' and publish ProfileChangeEvent with name='Mike'
  2. Change profile name again to 'Micheal' and publish ProfileChangeEvent with name='Michael'
  3. The 2 events gets arrived in correct order but the first event handling failed and the event end up in the Dead Letter Queue(DLQ), eventually the Person's name is 'Michael' as the second event consumption succeed.
  4. After some time I noticed that first failing event in the DLQ and republish it and the consumption succeed, now the Person's name is 'Mike' which is not correct as 'Michael' is actually the more recent updated value.

Please provide advice on how to deal with such situations?

1

1 Answers

0
votes

You have to keep track of document versions in your source and target data store and publish it in the events:

Publish ProfileChangeEvent ({name:'Mike', documentVersion:1})
Publish ProfileChangeEvent ({name:'Michael', documentVersion:2})

The consuming service has to keep track of the versions it processes. It can only process a new version if it already has processed its predecessor.

So if 'Michael' appears, you can reject processing if 'Mike' hasn't been processed yet.