[英]What is causing Mongodb timeout error on AWS Lambda?
我有一個節點 lambda function 使用 Z758D31F351CE114BF27C522F51 查詢 mongoDb
大約 20% 的時間,似乎是隨機的,我在嘗試連接時收到以下錯誤: MongoNetworkTimeoutError: connection timed out
雖然 MongoDb 似乎建議使用 context.callbackWaitsForEmptyEventLoop = false 並嘗試在調用之間重用相同的連接,但我讀到其他帖子說解決此問題的方法是每次都主動重新打開連接。 我試過了,但它仍然在發生。 有沒有人有任何想法?
這是我的代碼:
let conn = mongoose.createConnection(process.env.MONGO_URI, {
bufferCommands: false, // Disable mongoose buffering
bufferMaxEntries: 0, // and MongoDB driver buffering
useNewUrlParser: true,
useUnifiedTopology: true,
socketTimeoutMS: 45000,
keepAlive: true,
reconnectTries: 10
})
try {
await conn
console.log('Connected correctly to server')
} catch (err) {
console.log('Error connecting to DB')
console.log(err)
console.log(err.stack)
}
await conn
這是來自 Cloudwatch 的完整錯誤 output:
{
"errorType": "Runtime.UnhandledPromiseRejection",
"errorMessage": "MongoNetworkTimeoutError: connection timed out",
"reason": {
"errorType": "MongoNetworkTimeoutError",
"errorMessage": "connection timed out",
"name": "MongoNetworkTimeoutError",
"stack": [
"MongoNetworkTimeoutError: connection timed out",
" at connectionFailureError (/var/task/node_modules/mongodb/lib/core/connection/connect.js:342:14)",
" at TLSSocket.<anonymous> (/var/task/node_modules/mongodb/lib/core/connection/connect.js:310:16)",
" at Object.onceWrapper (events.js:420:28)",
" at TLSSocket.emit (events.js:314:20)",
" at TLSSocket.EventEmitter.emit (domain.js:483:12)",
" at TLSSocket.Socket._onTimeout (net.js:484:8)",
" at listOnTimeout (internal/timers.js:554:17)",
" at processTimers (internal/timers.js:497:7)"
]
},
"promise": {},
"stack": [
"Runtime.UnhandledPromiseRejection: MongoNetworkTimeoutError: connection timed out",
" at process.<anonymous> (/var/runtime/index.js:35:15)",
" at process.emit (events.js:326:22)",
" at process.EventEmitter.emit (domain.js:483:12)",
" at processPromiseRejections (internal/process/promises.js:209:33)",
" at processTicksAndRejections (internal/process/task_queues.js:98:32)",
" at runNextTicks (internal/process/task_queues.js:66:3)",
" at listOnTimeout (internal/timers.js:523:9)",
" at processTimers (internal/timers.js:497:7)"
]
}
我有同樣的問題(我有一個快速應用程序,但這沒關系)。 解決方案是將數據庫連接 object 移到處理程序方法之外並緩存/重用它。
'use strict'
const serverless = require('serverless-http')
const MongoClient = require('mongodb').MongoClient
const api = require('./modules/api')
const SecureConfig = require('./modules/secureConfig')
let dbObject = null
const getDBConnection = async (event, context) => {
try {
if (dbObject && dbObject.serverConfig.isConnected()) return dbObject
const client = await MongoClient.connect(SecureConfig.mongodb.host, SecureConfig.mongodb.mongoConfig)
dbObject = client.db(SecureConfig.mongodb.db)
return dbObject
} catch(err) {
throw(err)
}
}
module.exports.handler = async (event, context) => {
const db = await getDBConnection()
const server = serverless(api.default(db));
try {
/**
* Lambda’s context object exposes a callbackWaitsForEmptyEventLoop property,
* that effectively allows a Lambda function to return its result to the caller
* without requiring that the MongoDB database connection be closed.
* This allows the Lambda function to reuse a MongoDB connection across calls.
*/
context.callbackWaitsForEmptyEventLoop = false
return await server(event, context)
} catch (error) {
console.error('Lambda handler root error.')
throw error
}
}
您可以在此處找到更多詳細信息: https://www.mongodb.com/blog/post/optimizing-aws-lambda-performance-with-mongodb-atlas-and-nodejs
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.