Лямбда: не удается найти модуль "./drivers/node-mongodb-native/connection", хотя добавлен слой мангусты
У меня есть приложение NestJS, в моем файле обработчика я импортирую mongoose, чтобы создать соединение:
import * as mongoose from 'mongoose';
let conn = null;
const uri = process.env.MONGO_URI;
mongoose.connection.on('connected', () => {
// log something
});
тогда, в моей функции обработчика:
export const handler: Handler = async (event: any, context: Context) => {
if (conn == null) {
conn = await mongoose.connect(uri, {
bufferCommands: false, // Disable mongoose buffering
bufferMaxEntries: 0, // and MongoDB driver buffering
useNewUrlParser: true,
});
}
context.callbackWaitsForEmptyEventLoop = false;
Теперь я развернул и протестировал свое приложение полностью без мангуста, и все работает.
Соответствующий бессерверный конфиг:
plugins:
- serverless-plugin-typescript
- serverless-plugin-optimize
- serverless-offline
package:
individually: true
И я добавил слой мангусты, внутри zip у меня была папка с именем 'nodejs', внутри которой у меня есть папки package.json и "node_modules", содержащие все зависимости, установленные npm.
До этого я использовал слои без проблем, установленных таким же образом.
Тем не менее, я все еще получаю это на консоли при попытке любой конечной точки:
"errorType": "Runtime.ImportModuleError",
"errorMessage": "Error: Cannot find module './drivers/node-mongodb-native/connection'",
"stack": [
"Runtime.ImportModuleError: Error: Cannot find module './drivers/node-mongodb-native/connection'",
" at _loadUserApp (/var/runtime/UserFunction.js:100:13)",
" at Object.module.exports.load (/var/runtime/UserFunction.js:140:17)",
" at Object.<anonymous> (/var/runtime/index.js:36:30)",
" at Module._compile (internal/modules/cjs/loader.js:776:30)",
" at Object.Module._extensions..js (internal/modules/cjs/loader.js:787:10)",
" at Module.load (internal/modules/cjs/loader.js:653:32)",
" at tryModuleLoad (internal/modules/cjs/loader.js:593:12)",
" at Function.Module._load (internal/modules/cjs/loader.js:585:3)",
" at Function.Module.runMain (internal/modules/cjs/loader.js:829:12)",
" at startup (internal/bootstrap/node.js:283:19)",
" at bootstrapNodeJSCore (internal/bootstrap/node.js:622:3)"
]
}
0 ответов
Это происходит из-за работы "serverless-plugin-optimize", которую мне пришлось удалить в конце и просто использовать лямбда-слой для своих зависимостей.