最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

如何在编译时从缓存参数中延迟“新函数”,等到它被使用

运维笔记admin13浏览0评论

如何在编译时从缓存参数中延迟“新函数”,等到它被使用

如何在编译时从缓存参数中延迟“新函数”,等到它被使用

我想开始一个red-shift client。但是,当我尝试首先加载我从AWS Secret Manager收到的环境变量时,它似乎加载以下代码/缓存连接的以下参数,这会导致错误,因为所有内容都是“未定义”。

const client = {
        user: process.env.user,
        password: process.env.pass,
        database: process.env.db,
        port: process.env.port,
        host: process.env.host
  };


const redshiftClient = new redshift(client, {rawConnection: false}) 

秘密加载后,我在同一个脚本中使用函数调用redshiftClient:

retrieveData() {
        return redshiftClient.query(`SELECT * 
            FROM cit.rules`, 
        {raw: true}, function(err, data){
            if(err) console.error(err);
            else {
                return data;
            }
        });
    }

我不确定为什么在请求完成之前立即调用/缓存。难道这不应该只是在我第一次调用redshiftClient之后才会发生吗?我该怎么做才能确保我的环境变量已从secretmanager加载,并且我仍然可以访问redshiftClient.query?

回答如下:

我想到了。由于它正在创建一个新对象,因此我可以通过执行以下操作在调用之前编辑密码值:

redshiftClient.config.password = process.env.pass;

我通过使用console.log显示redshiftClient对象的内容然后查看密码的存储位置来得到这个答案。

这将在调用我的查询之前更新该值。我确信有更好的方法可以做到这一点,但这是我能找到的解决方法。

发布评论

评论列表(0)

  1. 暂无评论