-
-
Notifications
You must be signed in to change notification settings - Fork 3.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Connection timeout 10000ms when upgraded mongoose from 7.4.5 to 8.7.1 #14971
Comments
We're also experiencing a very similar issue. Using MongoDB Server 8.0 in Atlas and locally in Docker. Everything works intermittently, but lots of buffering error across lots of different find’s and aggregates in all of our microservices.
Posted about it here: https://www.mongodb.com/community/forums/t/buffering-timed-out-after-10000ms-8-7-0-mongoose-node-20-10-0/299932 |
We found the issue was introduced in 8.7. We were on 8.6, but only saw the issues when we upgraded to 8.7. |
the same issue.
|
The "Buffering timed out after 10000ms" is indicative of Mongoose not being connected to MongoDB. Here's a couple of suggestions you can try:
const db = await mongoose.connect(uri, { serverSelectionTimeoutMS: 5000 });
mongoose.set("strictQuery", false);
const dbConnect = async () => {
if (mongoose.connection.readyState === 1) {
return;
}
await mongoose.connect(uri);
};
export default dbConnect; You can read more on our Lambda docs |
My error got resolved somehow when I used these: const options = { Please check. |
This issue is stale because it has been open 14 days with no activity. Remove stale label or comment or this will be closed in 5 days |
We are also facing the same issue, which only happens in the production environment. We have tried multiple versions after 8.7.1 and none of them seems to be working so far. We are stuck at using 8.6.x as of now. Another thing to point out is that we have about 15 services and all of them fail when we go to 8.7.1 or above and that too only in production. |
hi.. did you check with latest version ie 8.8.2? |
I have the same issue. Downgrading to mongoose 8.6.x solved the issue. I tried everything, even created a new mongodb atlas cluster to make sure it's not the cluster, even though connecting to the db worked fine from other tools. There's definitely something wrong with mongoose or the mongodb package. Worth mentioning: It only fails to connect with the mongodb+srv:// scheme.
I did, no success. |
any updates on it? I have the same issue as @VanCoding described above. |
We are also experiencing this issue in version 8.0.1. |
My issue was resolved by this code:
Can anyone try this and confirm if this works for them? |
@sukhminderx what did you add, |
In case you encounter such connection errors where your connections are frequently disconnected (readyState = 0), consider using a Mongoose version below 8.7.0. Version 8.7.0 introduces a new variable to store the last heartbeat from the MongoDB server, which can lead to connection inconsistencies. For more details, refer to this comment: |
Will there be any fix soon? With this now being public but not being able to update mongoose 8.6.4 to any newer version it creates some urgency from my perspective. |
I haven't received any response from the maintainers, so I assume they don't believe this PR introduces a bug. For now, the best option, if you want to use the latest version with security updates, is to fork the repository, revert the changes introduced by this PR, republish the package, and use it until they acknowledge the issue with this PR for the serverless cold start bug. Hopefully, they either come up with a reliable solution or decide to revert the changes. @maxuai |
I replace my optionsOld with options,ie, the ones I got from Atlas connection steps. Did it work for anyone? |
Please try upgrading to 8.9.1, I believe the issue is specific to Atlas Serverless Instances and should be fixed by #15089. |
@vkarpov15 I've tried the new version but unfortunately the issue still exists for us. We are using a dedicated mongodb atlas cloud cluster. |
Okay, update regarding the timeout issue after 10000ms. This issue is still happening in version 8.9.2. I hope the next update will be usable. |
@maxuai @Server048 can you please provide more information on what your setup is like? Like what Node version, what runtime, what Atlas setup, etc. Can you also print out |
Hi @vkarpov15, we are using a About the error details: this is pretty hard to get as the only way for me to reproduce is to deploy the app using the "broken" mongoose version which also means I will have some user impact. Is there any known way how to reproduce the issue in a local setup? We also have a connection error event handler in place (as described here) which did not catch the error but just some random query failed. The only thing I have for now is an error like this:
|
There is unfortunately no known way to reproduce this issue locally. Can you confirm whether this buffering timed out error occurs right after server start, or after the server has been running for some time? If after the server has been running for some time, you can try setting await mongoose.connect(uri, { bufferCommands: false });
// Or with createConnection()
await mongoose.createConnection(uri, { bufferCommands: false }).asPromise(); That will disable buffering, which may make the issue go away if it is a Mongoose issue, or it may cause a MongooseServerSelectionError to happen instead of the buffering timed out error. |
@vkarpov15 I followed you recommendation and it seems that disabling the command buffer fixes the issue for us. Probably this means the issue must be located in the mongoose code? For us it currently would be acceptable to run without the commands buffer but maybe it would be worth for others to investigate why the issue happens with enabled commands buffer. |
That would be helpful. I'll add some additional research to see how we can make your issue easier to debug. |
This worked for me #14971 (comment) |
Hello, I add my experience on this for other people:
Before the npm audit, no error, after, the mentionned error started to pop totally randomly everywhere during runtime, not just after startup. |
@t-poirier do you create models once at startup, or do you have logic that creates Mongoose models while your application is running? |
fix(collection): avoid buffering if creating a collection during a connection interruption
Sorry to reply late, I see that you have completed the fix, great job I was waiting for it to upgrade to Mongo v8. |
Prerequisites
Mongoose version
8.7.1
Node.js version
20.x
MongoDB version
6.9
Operating system
None
Operating system version (i.e. 20.04, 11.3, 10)
No response
Issue
Last night, I upgraded my mongodb and mongoose from versions 5.8.1 to 6.9 and. 7.4.5 to 8.7.1 respectively.
I tested on my local. Everything worked fine. I promoted the changes to test env - AWS amplify - things were fine. Then, I moved the changes to production.
My db is hosted on mongo atlas serverless cluster.
On production, sometimes same queries will work fine but other times give timeout error with 10000ms. I mean same queries behaving differently.
I have been scratching my head because both test and prod env are exactly similar except that prod is connected to my domain name.
Please assist if someone has knowledge about this.
sharing my connection code and one query that fails/passes abruptly.
The text was updated successfully, but these errors were encountered: