-
-
Notifications
You must be signed in to change notification settings - Fork 74
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Confusion between 1-based and 0-based stream positions in different DB implementations of Event/Checkpoint Store #163
Comments
I am not sure why that is since the checkpoint should be the global position value of the last processed event. I would not expect the checkpoint store to manipulate the value in any way. It might be that the stored procedure that reads events from Postgres is doing something. Can you guess where the issue is coming from? |
I'd guess maybe in the Eventuous.SqlServer.Subscriptions namespace, SqlServerAllStreamSubscription, AsContext method: Looks like a hardcoded conversion from 1-leading to 0-leading to me? edit: this implementation is identical to the Postgres Subscription implementation. I can't remember seeing this issue there before.. I'll run a test. edit 2: The behaviour is identical (i.e. offset by one) using Postgres as the Checkpoint store: |
Yeah, I can't remember now. I was cleaning up the Postgres version, and it was taken as a baseline for the MS SQL version. Indeed, we'd better confirm what's where. My guess is the global position number is produced by the sequence (Postgres) or identity enumerator in SQL Server, and it always starts with one, not zero. As we want to keep the first event as zero position, it requires such manipulation. So, inside the system, it is consistent (zero-leading). |
Yes, you were right on the money. Postgres does not accept a 0-based sequence: (I had hoped this would work but it is a technical impossibility: ) Edit: Makes me wonder though, why should we want the first event as the zero position? This causes another issue that I will post shortly. |
That's what I meant. So, basically, the |
With #164 presumably fixed, is this one still relevant? |
@alexeyzimarev this issue is not specifically a bug, more like a feature :) I anticipate a hard time explaining to my colleagues why there is an offset between the global_position and the checkpoint position. But it is not breaking in any way so I guess we can live with it. It's just that I expect it to be confusing for (beginning) users of Eventuous. Adding a note to the documentation is of course always a good idea. |
Yeah, it's a bit too late as changing the sequence would produce hidden consequences of skipping one event. I haven't been able to document both SQL stores yet, will keep in mind this issue. |
I am working on a Proof-Of-Concept using Eventuous with PostgresDB as the Event Store, and Microsoft SQL Server as the Checkpoint Store / read model store.
I noticed the following confusing issue:
the global_position in the Postgres Schema is maintained as a 1-leading array:
However the Subscription in the receiving SQL Server store tracks the same global stream as a 0-leading array:
I have double-checked and the Subscription tracks in real-time, is in sync, no event was lost or skipped etc., my 'receiving' application is not stalling. Triggered one more event after above screenshots to demonstrate this:
[Postgres Event Store]
[SQL Server Checkpoint Store]
I find this confusing and not very intuitive. Am I missing some part of the implementation / intention here, or is this really just a little bug?
Kind regards,
Reinder
The text was updated successfully, but these errors were encountered: