我是一名前端程序员,正在努力学习更多后端技术。
我在 EC2 服务器上设置了一个 Mongo 数据库,并且我有一个 lambda 函数,我正尝试将其连接到我的 mongo 数据库。
import * as mongoose from "mongoose";
mongoose.Promise = global.Promise;
let isConnected: boolean = false;
export const connectToDatabase = () => {
if (isConnected) {
console.log('using existing database connection');
return Promise.resolve();
} else {
console.log('using new database connection', { isConnected });
console.log(process.env.MONGODB_URL);
return mongoose.connect(encodeURI(process.env.MONGODB_URL), {
auth: {
user: process.env.MONGODB_USER,
password: process.env.MONGODB_PASSWORD
}
}).then(db => {
isConnected = true;
});
}
};
这是我测试该功能时的错误日志:
2018-05-30T20:51:41.977Z 40fb5cd7-644b-11e8-b6d8-f74282cd6db5 using new database connection { isConnected: false }
2018-05-30T20:51:41.978Z 40fb5cd7-644b-11e8-b6d8-f74282cd6db5 mongodb://PRIVATE_IP:27017/myDeck
2018-05-30T20:51:42.041Z 40fb5cd7-644b-11e8-b6d8-f74282cd6db5 (node:1) UnhandledPromiseRejectionWarning: MongoNetworkError: failed to connect to server [PRIVATE_IP:27017] on first connect [MongoNetworkError: getaddrinfo ENOTFOUND PRIVATE_IP PRIVATE_IP:27017]
这是我尝试从我的功能连接的地址:mongodb://PRIVATE_IP:27017/myDeck
EC2 服务器位于同一个 VPC 上,并且我在 EC2 安全组上创建了入站规则。
答案1
我找到了我的问题的答案,我的 mongodb 服务器以等于 localhost 的 bind_ip 启动,因此无法接收来自 lambda 的连接。
我使用 bind_ip_all 进行测试,结果运行良好。