如何使用aws Lambda和node.js

时间:2015-08-10 09:52:17

标签: node.js amazon-web-services aws-lambda

我正在使用aws lambda,我正在尝试使用带有node.js的lambda函数来放置一个Item。

我有以下代码..

var AWS = require('aws-sdk');

var dynamoDBConfiguration = {
    "accessKeyId": "AccessKey",
    "secretAccessKey": "Secratekey",
    "region": "us-west-2"
  };
AWS.config.update(dynamoDBConfiguration);
var dd = new AWS.DynamoDB();
var tableName = 'product_bhavik';

exports.handler = function(event, context) {


putItem = function(itemName,prod_Id, prod_Name, prod_Desc, prod_Price) {
    console.log(" putItem Function Called");
     var item = {
        'itemName': { 'S': itemName },
        'microtime': { 'N': new Date().getTime().toString() }
      };

      if (prod_Id) item.prod_Id = { 'N': prod_Id.toString()};
      if (prod_Name) item.prod_Name = { 'S': prod_Name };
      if (prod_Desc) item.prod_Desc = { 'S': prod_Desc };
      if (prod_Price) item.prod_Price = { 'N': prod_Price.toString()};

      console.log("Data: %j",item);
      var response = dd.putItem({
         'TableName': tableName,
         'Item': item
      }, function(err, data) {
         err && console.log("Error in putItem "+err);
      });
    };

putItem('Item1',1, 'Laptop', 'Laptop for the IT users',10000);
context.succeed("Successfully Inserted");
}

当我在日志中测试此代码时没有错误,我仍然无法将一个项目放到Dynamodb表中,你能不能帮助我通过我的方式找到问题来将项目放到dynamodb表中或者你能否建议使用lambda来放置项目的其他方式。

1 个答案:

答案 0 :(得分:13)

我认为您最直接的问题是您在DynamoDB的响应之前调用context.succeeded()。如果执行此操作,Lambda将停止执行,而不等待响应。

另外,我建议添加一个try / catch包装器,以查看DynamoDB回调中是否有任何错误报告。尝试这样的事情:

exports.handler = function(event, context) {
  try {
    putItem = function(itemName,prod_Id, prod_Name, prod_Desc, prod_Price) {
        console.log(" putItem Function Called");
         var item = {
            'itemName': { 'S': itemName },
            'microtime': { 'N': new Date().getTime().toString() }
          };

          if (prod_Id) item.prod_Id = { 'N': prod_Id.toString()};
          if (prod_Name) item.prod_Name = { 'S': prod_Name };
          if (prod_Desc) item.prod_Desc = { 'S': prod_Desc };
          if (prod_Price) item.prod_Price = { 'N': prod_Price.toString()};

          console.log("Data: %j",item);
          var response = dd.putItem({
             'TableName': tableName,
             'Item': item
          }, function(err, data) {
              if (err) {
                context.fail("Error in putItem "+err);
              } else {
                context.succeed("Successfully Inserted");
              }
          });
        };

    putItem('Item1',1, 'Laptop', 'Laptop for the IT users',10000);

  } catch (error) {
    context.fail("Caught: " + error);
  }

}