node.js - 操作 `posts.find()` 缓冲在 10000ms 后超时

标签 node.js mongodb heroku mongoose mern

我在本地尝试过,效果很好。但 Heroku 在服务器部署后出现此错误。有人可以帮忙吗?

{
  "message": "Operation `posts.find()` buffering timed out after 10000ms"
}

index.js

const express = require("express");
const cors = require("cors");
const mongoose = require("mongoose");
const bodyParser = require("body-parser");
require("dotenv").config();

const app = express();
const postRouter = require("./routes/post");
const port = process.env.PORT || 5000;

app.use(cors());
app.use(bodyParser.json({ limit: "30mb", extended: true }));
app.use(bodyParser.urlencoded({ limit: "30mb", extended: true }));

app.get("/", (req, res) => {
  res.send("it works");
});
//mongoose connection
const URL = process.env.CONNECTDB_URL;

mongoose.connect(URL, {
  useNewUrlParser: true,
  useCreateIndex: true,
  useUnifiedTopology: true,
});
const connection = mongoose.connection;
connection.once("open", () => {
  console.log("MongoDB database connection established successfully");
});

//router

app.use("/posts", postRouter);

//listening
app.listen(port, () => {
  console.log(`Server is running on port: ${port}`);
});

Controller 文件位于此处。我正在尝试获取所有帖子。在本地我没有遇到任何错误

const getPosts = async (req, res) => {
  try {
    const posts = await Post.find({});
    res.status(200).json(posts);
  } catch (error) {
    res.status(404).json({
      message: error.message,
    });
  }
};

最佳答案

我遇到了类似的问题,但意识到我没有在 Heroku 中正确设置 CONNECTDB_URL 变量的配置变量。这可能是你的问题。

关于node.js - 操作 `posts.find()` 缓冲在 10000ms 后超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65788688/

相关文章:

javascript - 使用 nightmarejs 单击图像

c++ - mongo-cxx-driver 安装会安装库

mongodb - 如何在grails 3.3.11中使用静态嵌入?

django - Gunicorn:停止服务器 'Worker failed to boot.'

heroku - 将自定义域链接到 Heroku 应用程序

javascript - Next Js 结合外部 REST API 身份验证和授权

node.js - 如何序列化/反序列化多个本地策略

javascript - Meteor 出现意外的 mongo 退出代码 100

ruby-on-rails - JW Player - 在 Heroku 上加载播放器 : HTML5 player not found in Rails 3. 2 应用程序时出错

node.js - Sequelize NodeJS 服务器抛出 "ERR_UNKNOWN_ENCODING"错误