【问题标题】:MongoDB Deployed on Raspberry Pi Timing out on Nodejs Server with SSLMongoDB 部署在 Raspberry Pi 上使用 SSL 在 Nodejs 服务器上超时
【发布时间】:2021-04-27 22:25:11
【问题描述】:

我最近在树莓派上部署了我的 nodejs 服务器和 mongoDb,一切正常,但 mongoDB 请求超时。我认为该错误与 ssl 有关,因为当我删除 SSL 时它可以正常工作。

我得到的错误是我向服务器发出的任何 api 请求是:

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

我的 mongodb 连接字符串是:

  "connectionString":"mongodb://username:password@127.0.0.1:27017?authSource=dbWithUserCredentials&compressors=zlib&retryWrites=true&w=majority&ssl=true"

服务器中的连接代码为:

mongoose.connect(process.env.MONGODB_URI || config.get('connectionString'), {useNewUrlParser: true, useUnifiedTopology: true, useCreateIndex: true},(err,client)=>{
  if (err) return console.error(err);
  console.log('Connected to database');
});

我的 server.js 是:

require('rootpath')();
const express = require('express');
const app = express();
const cors = require('cors');
const bodyParser = require('body-parser');
var path = require('path');
var exec = require('exec');
const jwt = require('./clover-server-backend/_helpers/jwt');
const errorHandler = require('./clover-server-backend/_helpers/error-handler');

var https = require('https');

var fs = require('fs');

var options = {

  key: fs.readFileSync('./src/assets/ssl_key.txt'),

  cert: fs.readFileSync('./src/assets/sll.com.crt'),

  ca: fs.readFileSync ('./src/assets/ssl.com.ca-bundle')

};

app.use(express.static(__dirname + '/dist/softServer', { dotfiles: 'allow' }));
app.use(bodyParser.json({limit: '50mb'}));
app.use(bodyParser.urlencoded({limit: '50mb', extended: true}));
app.use(cors());

// app.get('/*', function(req,res) {
//
//   res.sendFile(path.join(__dirname+'/dist/softServer/index.html'));
// });
// use JWT auth to secure the api
app.use('/api/*', jwt());
// api routes
app.use('/api/users', require('./clover-server-backend/users/users.controller'));
app.use('/api/categories', require('./clover-server-backend/categories/categories.controller'));
app.get('/*', function(req,res) {
  res.sendFile(path.join(__dirname+'/dist/softServer/index.html'));
});
// global error handler
app.use(errorHandler);
// start server
console.log('In server.js'); //*MES*
const port = process.env.NODE_ENV === 'production' ? 443 : 4000;
var server = https.createServer(options, app);

server.listen(port, () => {
  console.log("server starting on port : " + port)
});

function execCallback(err,stdout, stderr){
  if(stdout){
    console.log(stdout)
  }
  if(stderr){
    console.log(stderr)
  }
}

【问题讨论】:

  • 您将 mongoDB 托管在与节点服务器相同的设备上。您不需要 ssl 证书,您的请求永远不会离开设备。如果您出于某种原因必须使用 ssl - 证书可能存在问题,或者它在 mongodb 上的配置方式存在问题。我还建议使用localhost 而不是127.0.0.1,因为拥有 IP 地址证书是非常不寻常的
  • @caffeinated.tech 感谢您的回复,但我在本地主机上进行了尝试,但没有成功。我仍然收到超时错误
  • 您是如何在 mongodb 上设置 ssl 证书的?可以分享一下配置文件吗?

标签: node.js mongodb mongoose raspberry-pi ssl-certificate


【解决方案1】:

确保您的数据库连接代码在您的 server.js 中,而不是外部文件中 如果它在外部文件中,请确保在 server.js 中调用它,否则它将无法连接到数据库

【讨论】:

    【解决方案2】:

    你不需要你的猫鼬连接功能吗?它不在你的 server.js 中。

    findOne 命令超时,因为没有活动连接。

    findOne 在您的服务器连接之前一直排队,如果没有活动连接,它会超时。

    你需要连接文件,或者在你的server.js中调用mongoose connect

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-01-21
      • 2022-11-06
      • 1970-01-01
      • 2014-04-02
      • 1970-01-01
      • 2018-07-12
      • 1970-01-01
      • 2020-06-18
      相关资源
      最近更新 更多