Giri
Giri

Reputation: 551

AWS Lambda functions NodeJs for postgreSQL - timeout error

I am new to AWS. I am trying to connect to AWS RDS postgreSQL instance using Lambda functions. I followed the aws documentation. But it uses python for Lambda functions. Below is my code.

'use strict';
var pg = require('pg');
exports.handler = function (event, context) {
    var dbConfig = {
        username: '<username>',
        password: '<password>',
        database: '<database>',
        host: '<db-endpoint>',
    };
    var client = new pg.Client(dbConfig);
    try {
        client.connect();
        context.callbackWaitsForEmptyEventLoop = false;
        client.end();
    }
    catch (err) {
        console.log(err);
        client.end();
    }
};

I am getting timeout error as below

START RequestId: 368e619e-ed9d-4241-93a5-764ee01aa847 Version: $LATEST
2020-06-15T16:28:18.911Z    368e619e-ed9d-4241-93a5-764ee01aa847    INFO    connected
END RequestId: 368e619e-ed9d-4241-93a5-764ee01aa847
REPORT RequestId: 368e619e-ed9d-4241-93a5-764ee01aa847  Duration: 20020.16 ms   Billed Duration: 20000 ms   Memory Size: 128 MB Max Memory Used: 70 MB  Init Duration: 150.01 ms    
2020-06-15T16:28:38.901Z 368e619e-ed9d-4241-93a5-764ee01aa847 Task timed out after 20.02 seconds

Please advise on the error.

I have few other questions to ensure if my code is correct

Upvotes: 7

Views: 8325

Answers (3)

user2465134
user2465134

Reputation: 9803

I'm not sure if you're still having issues but my issue was using the callback parameter.

If you start a new Serverless framework project they no longer wrap responses with callback anymore. They just return. Try giving that a go. I'm not sure the inner workings of why using callback would cause issues, but once I removed it my calls no longer hung or caused a "pool has ended" errors.

I also recommend using this package for Serverless projects.

Lastly, in your try/catch add finally to end your session:

//client.clean() is from the library I linked, not pg-node
//though if you use pg-node, you could do pgPool.end() in the finally instead

finally {
  await client.clean()
}

This way it always runs at the end of your lambda and you have to put it only in one spot.

Upvotes: 0

ssuperczynski
ssuperczynski

Reputation: 3426

Here is the answer for async/await syntax

const { Client } = require("pg");

exports.handler = async (event, context, callback) => {
  const dbConfig = {
    host: process.env.RDS_HOSTNAME,
    user: process.env.RDS_USERNAME,
    password: process.env.RDS_PASSWORD,
    port: process.env.RDS_PORT,
    database: process.env.RDS_DATABASE,
  };
  const client = new Client(dbConfig);

  try {
    await client.connect();
    const res = await client.query("SELECT * FROM your_table");
    await client.end();
    callback(null, res.rows);
  } catch (err) {
    await client.end();
    callback(err)
  }
};

Upvotes: 3

Hemant Parashar
Hemant Parashar

Reputation: 3774

You're not returning anything from the lambda. So the request keeps hanging without a response until it times out.

Use the third argument callback supplied to the handler to respond or return a Promise.

'use strict';
var pg = require('pg');
exports.handler = function (event, context,callback) {
    var dbConfig = {
        username: '<username>',
        password: '<password>',
        database: '<database>',
        host: '<db-endpoint>',
    };
    var client = new pg.Client(dbConfig);
    try {
        client.connect();
        context.callbackWaitsForEmptyEventLoop = false;
        client.end();

        //send the response
        callback(null,"Some Response")
    }
    catch (err) {
        console.log(err);
        client.end();
        callback(err)
    }
};

AWS example : AWS Lambda NodeJS Connect to RDS Postgres Database

You can read the official js docs with all methods and properties here : https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/RDS.html

Hope this helps !

Upvotes: 5

Related Questions