node.js - 通过 Mongoose (nodejs) 从远程服务器连接到 MongoDB
问题描述
我在 Digital Ocean 中有一个运行 MongoDB (4.0.3) 和 Ubuntu (18.04) 的液滴。我用他们的一键编队创建了这个。我按照数字海洋教程来保护 mongodb并配置远程访问。如果我 ssh 进入盒子并使用 mongo shell,一切都会很好。但是,我无法通过 nodejs/mongoose 从我的笔记本电脑建立与服务器的连接。
你能帮我弄清楚我的配置有什么问题吗?或者帮我解释错误信息
这是有效的:
- [终端] -
ssh
进入盒子并使用mongo
外壳 - [节点] - 使用
tunnel-ssh
我可以建立到远程服务器的连接 - [节点] - 使用 npm
mongodb
包我可以创建到数据库的连接
但是,我无法与mongoose
using建立联系tunnel-ssh
。这是我正在尝试的代码:
const mongoose = require('mongoose')
const tunnel = require('tunnel-ssh');
const config = {
username: 'user',
password: 'pass',
host: 'myLaptopIp',
port: 22,
dstHost: 'severRunningMongo',
dstPort: 27017, // this was open via `sudo ufw allow from myLaptopIp to any port 27017`
localHost: '127.0.0.1',
localPort: 27017
};
tunnel(config, (error, server) => {
if (error) {
console.log('SSH connection error: ' + error);
}
const url = 'mongodb://${dbuser}:${dbpass}@127.0.0.1:27017/${dbname}';
mongoose.connect(url, { useNewUrlParser: true });
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'DB connection error:'));
db.once('open', function() {
console.log('DB connection successful');
});
});
我得到的错误是
Error: connect ECONNREFUSED myLaptopIp:22
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1137:16)
Emitted 'error' event on Server instance at:
at Client.emit (events.js:311:20)
at Socket.<anonymous> (/~/node_modules/ssh2/lib/client.js:294:10)
at Socket.emit (events.js:311:20)
at emitErrorNT (internal/streams/destroy.js:92:8)
at emitErrorAndCloseNT (internal/streams/destroy.js:60:3)
at processTicksAndRejections (internal/process/task_queues.js:84:21) {
errno: 'ECONNREFUSED',
code: 'ECONNREFUSED',
syscall: 'connect',
address: 'myLaptopIp',
port: 22,
level: 'client-socket'
}
如果我更改localPort
为2000
OR 如果我更改 mongo 连接 url 以包含 mongoServerIp,我会收到错误消息:
MongoNetworkError: failed to connect to server [127.0.0.1:27017] on first connect [Error: connect ECONNREFUSED 127.0.0.1:27017
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1137:16) {
name: 'MongoNetworkError'
解决方案
你知道当你问一个问题,然后 1 分钟后你想尝试一些新的东西,并且这个新东西完全有效吗?
我想我根本不需要使用tunnel-ssh
,因为我已经打开了服务器以允许从我的笔记本电脑进行远程访问。这对我有用
const mongoose = require('mongoose')
const url = 'mongodb://{dbUser}:{dbPass}@{mongoServerIp}:27017/{dbName}?authSource=admin';
mongoose.connect(url);
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'DB connection error:'));
db.once('open', function() {
console.log('DB connection successful');
});
我确实需要添加?authSource=admin
到 url 的末尾,否则它将不起作用。我按照 DO 教程中的建议将我的 dbuser 添加到了 admin db
我仍然不确定为什么隧道不起作用,我原以为它仍然可以工作?
推荐阅读
- c# - “警告:建立数据库连接问题!” 但连接字符串是正确的
- r - 当我尝试将两个变量绘制到同一个图上时,为什么我的图看起来像这样?
- javascript - 如何将数据从变量传输到 redux 存储?
- r - 如何使用带有 method = glmmTMB::glmmTMB 和点权重的 ggplot 可视化交互效果
- apache-spark - Spark Streaming 作业在 HD Insights 上 7 天后完全失败,没有错误日志
- r - 创建整数间隔向量以从 R 中的数据框中删除多行
- javascript - 如何允许用户覆盖输入类型数字中的数字(当已经有两个数字时)?
- clang++ - Emscripten Clang 生成 ELF 64 位可执行文件和 wasm 二进制交叉编译器目标
- c# - 在 Azure c# 上下载、处理和保存在数据库中作为服务器 less
- java - 从 IntentService 开始一个活动