从AWS中的参数存储中获取值

时间:2018-12-29 22:24:26

标签: javascript node.js amazon-web-services aws-sdk

这是我的代码:

const AWS = require('aws-sdk');
const { Client } = require('pg');

function main() {
    AWS.config.update({region:'eu-west-2'});

    let db_user = {
        Name: "postgres_db_user",
        WithDecryption: false
    };

    let db_host = {
        Name: "postgres_db_host",
        WithDecryption: false
    };

    let db_database = {
        Name: "postgres_db_name",
        WithDecryption: false
    };

    let db_password = {
        Name: "postgres_db_password",
        WithDecryption: true
    };

    let db_port = {
        Name: "postgres_db_port",
        WithDecryption: false
    };

    let database_user_name;
    let database_host;
    let database_name;
    let database_port;
    let database_password;

    let ssm = new AWS.SSM();
    ssm.getParameter(db_user, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_user_name = data;
        }
    });

    ssm.getParameter(db_host, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_host = data;
        }
    });

    ssm.getParameter(db_database, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_name = data;
        }
    });

    ssm.getParameter(db_password, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_password = data;
        }
    });

    ssm.getParameter(db_port, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
           database_port = data;
        }
    });

    console.log(database_user_name);
    console.log(database_host);
    console.log(database_name);
    console.log(database_password);
    console.log(database_port);

    let client = new Client({
        user: database_user_name,
        host: database_host,
        database: database_name,
        password: database_password,
        port: database_port,
    });
}

main();

问题是当我打印变量时它们是未定义的,我也不知道为什么。 SSM getParameter函数之所以起作用,是因为如果使用调试器,我会看到这些值,但是由于某种奇怪的原因,它似乎并没有将数据变量保存在变量中。

如果有人可以帮助我解释为什么此代码未打印出变量的定义,我将不胜感激。

1 个答案:

答案 0 :(得分:1)

当约翰发表评论时,我正在草拟答案。

getParameter是异步函数,正在使用属性初始化客户端时执行。

这是一些初始化代码的示例方法(虽然不完美,但您可以理解)。

var AWS = require('aws-sdk');
AWS.config.update({ region: 'us-east-1' });
var ssm = new AWS.SSM();

function getParameter(param) {
  return new Promise(function (success, reject) {
    ssm.getParameter(param, function (err, data) {
      if (err) {
        reject(err);
      } else {
        success(data);
      }
    });
  });
};

function main() {
  let db_user = {
    Name: "postgres_db_user",
    WithDecryption: false
  };
  let database_user_name;
  var promises = [];
  promises.push(getParameter(db_user));

  Promise.all(promises)
    .then(function (result) {
      database_user_name = result[0].Parameter.Value;
      console.log(database_user_name);
      let client = new Client({
        user: database_user_name
        //rest of the properties
      });
      //rest of the main() function code
    })
    .catch(function (err) {
      console.log(err);
    });
}
main();

参考- https://stackoverflow.com/a/44868681/5030709