【发布时间】: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