I have an index.js file which contains code like the following:
const dbConfig = require('./config/dbConfig')
const mysql = require('mysql')
var con = mysql.createConnection({
host: dbConfig.host,
user: dbConfig.username,
password: dbConfig.password,
database: dbConfig.database
})
function readMessages (event, context, callback) {
console.log('function triggered')
con.connect((err) => {
if (err) {
console.error(err)
callback(err)
} else {
console.log('Connected!')
con.query('SELECT * FROM Messages WHERE isDeleted = 0;', (err, result, fields) => {
if (err) {
console.error(err)
callback(err)
} else {
console.log(result)
con.end()
callback(null, result)
}
})
}
})
}
exports.handler = readMessages
The code correctly gets data from the mysql database and displays them on the screen when I run it on my local machine.
However, I got Task timed out after 7.01 seconds error when it is run on aws-lambda.
The code and its dependencies are packaged in a file named app.zip, then uploaded to aws-lambda.
app.zip
├── config
│ └── dbConfig.js
├── index.js
└── node_modules
The only log message being printed by my function is function triggered. I cannot find other log messages generated by my function in the cloud watch log.
Why does the function timed out on aws-lambda?