Skip to content
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

Closed
1 task done
sukhminderx opened this issue Oct 17, 2024 · 29 comments
Closed
1 task done
Labels
developer-experience This issue improves error messages, debugging, or reporting
Milestone

Comments

@sukhminderx
Copy link

Prerequisites

  • I have written a descriptive issue title

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.

import { ServerApiVersion } from "mongodb";
import mongoose from "mongoose";

const uri = process.env.MONGODB_URI as string;


const connection: {
  isConnected?: boolean;
} = {};

const dbConnect = async () => {
  if (connection.isConnected) return;
  mongoose.set("strictQuery", false);
  const db = await mongoose.connect(uri);

  connection.isConnected = Boolean(db.connections[0].readyState);
};
export default dbConnect;
export async function GET(req: Request) {
  try {
    await apiHandler(req, "");
    const countries: any = await Countries.find({}).exec();
    return NextResponse.json(countries, { status: 200 });
  } catch (error: any) {
    console.log("wb saas: countries");
    console.log(
      typeof error !== "string"
        ? error.message
          ? error.message
          : (error || {}).toString()
        : error
    );
    return errorHandler(error);
  }
}
@sukhminderx sukhminderx added help This issue can likely be resolved in GitHub issues. No bug fixes, features, or docs necessary help wanted labels Oct 17, 2024
@vkarpov15 vkarpov15 added this to the 8.7.3 milestone Oct 20, 2024
@garethlowriehive
Copy link

garethlowriehive commented Oct 22, 2024

We're also experiencing a very similar issue.

Using MongoDB Server 8.0 in Atlas and locally in Docker.
Node: 20.11.1
Mongoose 8.7.1

Everything works intermittently, but lots of buffering error across lots of different find’s and aggregates in all of our microservices.

Buffering timed out after 10000ms

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

@ksmithut
Copy link

ksmithut commented Oct 24, 2024

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.

@vkarpov15 vkarpov15 modified the milestones: 8.7.3, 8.7.4 Oct 25, 2024
@slavik-pastushenko
Copy link

slavik-pastushenko commented Oct 30, 2024

the same issue.
Mongo: 8.0
Node: 20.13.1
Mongoose 8.7.1

Buffering timed out after 10000ms

@vkarpov15
Copy link
Collaborator

The "Buffering timed out after 10000ms" is indicative of Mongoose not being connected to MongoDB. Here's a couple of suggestions you can try:

  1. Reduce your serverSelectionTimeoutMS. This will likely just change the error message, but the new error message will provide a little bit more info on why you can't connect to MongoDB:
const db = await mongoose.connect(uri, { serverSelectionTimeoutMS: 5000 });
  1. Fix your isConnected logic. isConnected is not tied to Mongoose's readyState, if Mongoose's readyState changes then isConnected is still tied to the initial value. Try the following instead.
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

@vkarpov15 vkarpov15 removed this from the 8.8.1 milestone Nov 1, 2024
@sukhminderx
Copy link
Author

My error got resolved somehow when I used these:

const options = {
serverApi: {
version: ServerApiVersion.v1,
strict: true,
deprecationErrors: true,
},
};

Please check.

Copy link

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

@github-actions github-actions bot added the Stale label Nov 18, 2024
@tabz24
Copy link

tabz24 commented Nov 19, 2024

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.

@sukhminderx
Copy link
Author

hi.. did you check with latest version ie 8.8.2?

@github-actions github-actions bot removed the Stale label Nov 20, 2024
@VanCoding
Copy link

VanCoding commented Nov 21, 2024

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.

@sukhminderx

hi.. did you check with latest version ie 8.8.2?

I did, no success.

@slavik-pastushenko
Copy link

any updates on it? I have the same issue as @VanCoding described above.

@atayahmet
Copy link

atayahmet commented Nov 27, 2024

We are also experiencing this issue in version 8.0.1.

@sukhminderx
Copy link
Author

My issue was resolved by this code:

import { ServerApiVersion } from "mongodb";
import mongoose from "mongoose";

const uri = process.env.MONGODB_URI as string;
const optionsOld = {
  useUnifiedTopology: true,
  useNewUrlParser: true,
  serverApi: ServerApiVersion.v1,
};

const options = {
  serverApi: {
    version: ServerApiVersion.v1,
    strict: true,
    deprecationErrors: true,
  },
};

const dbConnect = async () => {
  console.log("MONGO CONNECTION STATUS -- " + mongoose.connection.readyState);
  if (mongoose.connection.readyState === 1) {
    console.log("MONGO already connected");
    return;
  }
  try {
    const db = await mongoose.connect(uri, options);
    // mongoose.set("debug", true); // Logs every query

    // Listen for connection events
    mongoose.connection.on("connected", () => {
      console.log("MONGO connection established");
    });

    mongoose.connection.on("disconnected", () => {
      console.error("MONGO connection lost");
    });

    mongoose.connection.on("error", (error) => {
      console.error("MONGO connection error:", error);
    });
  } catch (error) {
    console.error("MONGO connection failed:", error);
    throw error;
  }
};
// Disconnect function
const dbDisconnect = async () => {
  if (mongoose.connection.readyState !== 0) {
    await mongoose.disconnect();
    console.log("MONGO disconnected");
  }
};

// Handle shutdown signals
process.on("SIGINT", async () => {
  await dbDisconnect();
  process.exit(0);
});

process.on("SIGTERM", async () => {
  await dbDisconnect();
  process.exit(0);
});

export default dbConnect;

Can anyone try this and confirm if this works for them?

@vkarpov15
Copy link
Collaborator

@sukhminderx what did you add, serverApi: ServerApiVersion.v1?

@halilbrhmtrn
Copy link

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:
#14812 (comment).

@maxuai
Copy link

maxuai commented Dec 6, 2024

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.

@halilbrhmtrn
Copy link

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

@sukhminderx
Copy link
Author

@sukhminderx what did you add, serverApi: ServerApiVersion.v1?

I replace my optionsOld with options,ie, the ones I got from Atlas connection steps. Did it work for anyone?

@vkarpov15
Copy link
Collaborator

Please try upgrading to 8.9.1, I believe the issue is specific to Atlas Serverless Instances and should be fixed by #15089.

@maxuai
Copy link

maxuai commented Dec 17, 2024

@vkarpov15 I've tried the new version but unfortunately the issue still exists for us. We are using a dedicated mongodb atlas cloud cluster.

@Server048
Copy link

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.

@vkarpov15
Copy link
Collaborator

@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 err.reason.servers and paste what the output is with sensitive information omitted (hostnames, etc)?

@maxuai
Copy link

maxuai commented Jan 7, 2025

@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 err.reason.servers and paste what the output is with sensitive information omitted (hostnames, etc)?

Hi @vkarpov15, we are using a node:22.12.0-alpine docker image to run our application. Our Atlas setup is using mongodb version 6.0.19 on GCP with a 3 nodes replica set. The used mongoose version was 8.9.1 and mongodb driver version was 6.12.0. What other information would be helpful?

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:

MongooseError: Operation `xxx.find()` buffering timed out after 10000ms
    at Timeout.<anonymous> (/xxx/node_modules/mongoose/lib/drivers/node-mongodb-native/collection.js:185:23)
    at listOnTimeout (node:internal/timers:594:17)
    at process.processTimers (node:internal/timers:529:7)

@vkarpov15
Copy link
Collaborator

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 bufferCommands: false on your connection, like the following

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.

@maxuai
Copy link

maxuai commented Jan 13, 2025

@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.

@vkarpov15
Copy link
Collaborator

That would be helpful. I'll add some additional research to see how we can make your issue easier to debug.

@vkarpov15 vkarpov15 added this to the 8.9.6 milestone Jan 14, 2025
@vkarpov15 vkarpov15 added developer-experience This issue improves error messages, debugging, or reporting and removed help This issue can likely be resolved in GitHub issues. No bug fixes, features, or docs necessary help wanted labels Jan 14, 2025
@prasannawilliams
Copy link

This worked for me #14971 (comment)

@t-poirier
Copy link

t-poirier commented Jan 20, 2025

Hello,

I add my experience on this for other people:

  • NodeJS 22.13.0
  • Mongoose 8.0.4, but npm audit executed the 17/01/2025 has set the version to 8.9.5
  • MongoDB Atlas v7.X

Before the npm audit, no error, after, the mentionned error started to pop totally randomly everywhere during runtime, not just after startup.
Setting bufferCommands: false immediately solved the issue.
Definitely a mongoose glitch between v8.0.4 and v8.9.5.

@vkarpov15
Copy link
Collaborator

@t-poirier do you create models once at startup, or do you have logic that creates Mongoose models while your application is running?

vkarpov15 added a commit that referenced this issue Jan 20, 2025
fix(collection): avoid buffering if creating a collection during a connection interruption
@t-poirier
Copy link

Sorry to reply late, I see that you have completed the fix, great job I was waiting for it to upgrade to Mongo v8.
For your question, yes we create models during runtime.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
developer-experience This issue improves error messages, debugging, or reporting
Projects
None yet
Development

No branches or pull requests