【问题标题】:Timeout when trying to connect to redshift from node using node-redshift尝试使用 node-redshift 从节点连接到 redshift 时超时
【发布时间】:2023-03-09 07:29:01
【问题描述】:

我正在尝试从我的 nodejs 代码连接到 redshift,以运行从 S3 复制到 redshift 的代码。 我使用下面的代码为此使用 node-redshift 包。

var Redshift = require('node-redshift');
 
var client = {
  user: 'awsuser',
  database: 'dev',
  password: 'zxxxx',
  port: '5439',
  host: 'redshift-cluster-1.xxxxxxxxxx.us-east-1.redshift.amazonaws.com',
};

var redshiftClient = new Redshift(client);
var pg_query = "copy test1 from 's3://aws-bucket/" + file_name + "ACCESS_KEY_ID 'xxxxxxx' SECRET_ACCESS_KEY 'xxxxxxxxxx';";
redshiftClient.query(pg_query, {raw: true}, function (err1, pgres) {
 if (err1) {
              console.log('error here');
              console.error(err1);
 } else {
            //upload successful
      console.log('success');
       }
 });
   }
    });

我也尝试过使用显式连接,但无论如何我都会收到如下超时错误 错误:错误:连接 ETIMEDOUT XXX.XX.XX.XX:5439

redshift 集群被分配给一个角色以获得 S3 完全访问权限,并且还分配了默认安全组。

我错过了什么吗?

【问题讨论】:

    标签: node.js amazon-redshift


    【解决方案1】:

    确保您的集群是公开可见的。集群应该位于某个子网中。对于该子网,VPC 中安全组的入站规则应该有一个条目,说明允许所有 IP 在端口 5439 上连接到您的 Redshift 集群。

    如果您的公共 IP 存在于该集合中,那么只有您可以连接到集群。

    假设您有 SQL Workbench/J,它允许您连接到 redshift 集群。如果你能连接到这个SQL客户端,你可以忽略上面的事情,因为这意味着你的IP可以通过SQL Workbench/J连接到redshift集群。

    【讨论】:

      猜你喜欢
      • 2017-10-22
      • 1970-01-01
      • 2017-12-09
      • 1970-01-01
      • 2019-10-22
      • 2015-03-31
      • 2018-03-28
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多