payload: v2.3.0 causes mongo transaction issue "Attempted illegal state transition from [TRANSACTION_ABORTED] to [TRANSACTION_ABORTED]"
Link to reproduction
No response
Describe the Bug
Apologies in advance, I’m not going to be able to provide many details here. I’m experiencing this in a large project I can’t share and I have very little insight into what’s causing it. What I do know is my unit/integration tests are working and passing on my project on 2.2.1, when I upgrade to 2.3.0 with no other changes, my seeds break with this error during a locale create call.
This only occurs in the seed script, calling create via local API. Creating a record in this same collection via admin works fine.
/Users/seth/dev/backend/node_modules/mongodb/src/transactions.ts:168
    throw new MongoRuntimeError(
          ^
MongoRuntimeError: Attempted illegal state transition from [TRANSACTION_ABORTED] to [TRANSACTION_ABORTED]
    at Transaction.transition (/Users/seth/dev/backend/node_modules/mongodb/src/transactions.ts:168:11)
    at commandHandler (/Users/seth/dev/backend/node_modules/mongodb/src/sessions.ts:740:27)
    at /Users/seth/dev/backend/node_modules/mongodb/src/sessions.ts:810:7
    at /Users/seth/dev/backend/node_modules/mongodb/src/utils.ts:462:14
    at processTicksAndRejections (node:internal/process/task_queues:95:5) {
  [Symbol(errorLabels)]: Set(0) {}
}
And seeing this response on the local API create call:
{"ok":0,"code":251,"codeName":"NoSuchTransaction","$clusterTime":{"clusterTime":{"$timestamp":"7307627979285200993"},"signature":{"hash":"AAAAAAAAAAAAAAAAAAAAAAAAAAA=","keyId":0}},"operationTime":{"$timestamp":"7307627979285200993"}}
To Reproduce
Due to the complexity of my project and the relative lack of details in the error, I really have no way to isolate this issue or provide a simplified reproduction. My best guess is this is related to something happening in a hook executing during create. The one other thing that’s relevant is that this problem does not occur on the first 10 or so collection seeds which all complete as expected.
Payload Version
2.3.0
Adapters and Plugins
db-mongodb
About this issue
- Original URL
- State: closed
- Created 7 months ago
- Reactions: 1
- Comments: 50 (27 by maintainers)
Thanks for the extra info @BrianJM. I’ll take another look into this tomorrow.
Hey @iamacup!
I pulled your configuration into a new npx create-payload-app blank template. Connected to a mongodb Atlas instance to reproduce the errors. With #5156, I’ve packed payload on main and copied it over to the test repo and the error is no longer occuring when I save new
You can read the description, but what was happening was a race condition in the access function where the more fields you have, the more likely it was to error.
There are still improvements to be made on transactions overall, as I am looking at feedback posted here: https://github.com/payloadcms/payload/issues/4078#issuecomment-1960861769
Thanks everyone contributing to the conversation! This is high priority for us to get right.
This is not yet an option, but there is a PR (#4467) in the works.
I patched @payloadcms/db-mongodb/dist/index.js with the following:
Hi @DanRibbens
You still have access to my repo if you want to reproduce easily. The seed errors are definitely not generated by poorly handled async map. All the payload.create are awaited properly.
Thanks @DanRibbens - your efforts are much appreciated, I know how nebulous this one is!
A support rep at MongoDB Atlas pointed me to this related issue with the MongoDB Node.js driver. The rep said it was actively being looked into.
@BrianJM
Yes that is a good call!
I’ve gone and pruned out every single field apart from blocks and i am still getting the error reliably and instantly starting with no data - by creating a single record - my structure as you have seen is a bunch of nested blocks - i am certain somehow its getting messy down in the code when you get to a big nesting.
https://github.com/iamacup/payload-transactions/pull/1
I can remove the error entirely if i just chop the block structure off half way down.
edit: what i have said there is clearly a lie there is an array as well - brb removing
edit2: removing the array did not fix it - it is now just blocks in the project
@sandwit, You can disable all transactions by setting
transactionOptions: falsein the db adapter settings which will resolve your issues for now.I have shared it directly with you now @BrianJM. it ain’t pretty though 😃
@DanRibbens i have created a ‘minimal’ repo and shared it with you directly and am happy for you to share inside Payload - https://github.com/iamacup/payload-transactions/ - please read the readme.
I am using the word ‘minimal’ because while it is simple in terms of collections and payload config (no plugins etc.) it’s got a bunch of blocks and the error is coming from there.
video here: https://drive.google.com/file/d/1ziwb8tCrkRKgqIk0Zuj-fsQe6AztKNdR/view?usp=sharing
it’s causing both:
reliably
I SUSPECT it is to do with the media collection and uploads but i will do more today to see if i can get this more minimal.
EDIT: i have since removed the media collection entirely and the error is still there, in the example there are no relationship fields now.
@iamacup @denolfe @DanRibbens I am seeing the exact same issue, and have confirmed these recommendations.
I regularly receive these errors (latest payload) interacting with the UI, which causes the app to crash within minutes of use. These application crashed and errors occur on collections that have
relationshipfields,afterReadhooks (i.e., virtual fields), and/orfilterOptions.This seems like a race condition of sorts, as collections with more
relationshipfields andafterReadhooks consistently and more regularly cause application crashes.The issues started when switching from a local mongodb instance to Atlas (free tier), during the last round of testing before launching an MVP.
We have been using that flag since it’s available on mana.wiki for about a month. Nothing is broken yet!
The main problem would be we won’t unearth transaction race condition issues in larger production apps for PayloadCMS.
thanks @xHomu we have done this and its working, sorry to ask but do you know what the implications of doing this are in production?
@iamacup Not ideal, but we disabled transactions altogether with
transactionOptions: falsedocs, so we can focus on building out our app.@DanRibbens I just sent you an invitation to a repository, so you can reproduce. Just do
npm run seedhttps://github.com/franckmartin/payload-mongo-transactionI don’t know about others situations/projects, but it would be pretty difficult for me to create a reproduction. I think this only happens with a certain level of complexity/relationships/hooks that would be very difficult to simulate. I know that isn’t helpful, but it’s not for lack of trying! I also haven’t been able to reproduce in reasonably simple sandboxes, but I’m certain there’s an issue 😆
I think you’re instinct here @DanRibbens is correct re an error/abort during transaction. I’m hesitant to speak to this because I have very cursory understanding of node process management / workers / tasks (or even the payload hook system) but I think the single biggest development difficulty in Payload is lack of transparency in errors. Again I have no idea if that is fundamental to node async tasks so not necessarily a knock on Payload, but there does seem like there’s a huge swatch of errors like this that just get swallowed and if they were easily surfaced could significantly improve debugging.
I need to switch gears here, but I have been able to reliably reproduce it and more importantly reliably avoid it. I can’t say what I’ve found is super promising or helpful, but here it is.
I commented out data generators for my
postsseeds and one by one uncommented and re-run seeds. What I determined was when I generated data for arelationshipfield I got the transaction error. If I commented out that generator, the error went away (I repeated this many times to make sure this was in fact triggering it). It’s also worth noting I experimented a bit with some other relationship fields and some of them always work and some of them never work. I can’t find any pattern, some relationships to upload collections work, others do not, some relationships to other non-upload collections work, others do not. I was even able to reproduce it in admin and this is where it gets even weirder:I kept clicking Save over and over and the transaction id was always off by 1 and I kept getting that error, and then on the 9th time it saved successfully! It only happens on new
posts, if I select that seed file on any other existing post I never get an error on save…