8

[原帖]

我见过几个类似的 SO 问题,但我认为它们中的任何一个都与操作系统无关。

长话短说,这是我在尝试建立与 Redshift 的 ssl 连接时看到的。

library(RPostgreSQL)
drv <- dbDriver("PostgreSQL")
con <- dbConnect(drv,
                 host = "XXXXXXXX.us-east-1.redshift.amazonaws.com",
                 port = 5439,
                 user = "XXXXXXXX",
                 password = "XXXXXXXX",
                 dbname = "db1")

> Error in postgresqlNewConnection(drv, ...) : 
    RS-DBI driver: (could not connect XXXXXXXX@XXXXXXXX.us-east-1.redshift.amazonaws.com on dbname "db1")

我尝试了以下方法,但都没有奏效。

  1. 使用 R 通过 SSL 连接到 Redshift
  2. 将文件从 PostgreSQL 导入到 R
  3. 使用 R 通过 SSL 连接到 Postgres
  4. https://groups.google.com/forum/#!topic/rpostgresql-dev/ELnVUJqjDbk

我在 AWS 中有一个 EC2 节点(Ubuntu),在办公室有另一个 Mac Pro,所以我尝试使用相同的代码从两者连接。

Linux 系统可以复制和粘贴完全相同的代码。这是Sys.info()Linux服务器上的:

sysname                                              Linux
release                                  3.13.0-48-generic
version        #80-Ubuntu SMP Thu Mar 12 11:16:15 UTC 2015
nodename                                   ip-xx-xxx-xx-xx
machine                                             x86_64
login                                              unknown
user                                                  bcui
effective_user                                        bcui

但是,Mac Pro 失败并显示完全相同的错误消息。这是 Mac Sys.info()(与我的 Mac 笔记本电脑相同):

sysname                                             Darwin
release                                             15.3.0
version                      Darwin Kernel Version 15.3.0:
                             Thu Dec 10 18:40:58 PST 2015;
                       root:xnu-3248.30.4~1/RELEASE_X86_64
nodename                                    bcui-MBP.local
machine                                             x86_64
login                                                 bcui
user                                                  bcui
effective_user                                        bcui

我想知道导致此错误消息的 Mac 和 Linux 配置有什么不同?

[2016/02/10 更新]

我试图卸载 R 和所有相关文件,然后从自制软件重新安装 R:

brew tap homebrew/science
brew install R

相同的错误信息:

> Error in postgresqlNewConnection(drv, ...) : 
    RS-DBI driver: (could not connect XXXXXXXX@XXXXXXXX.us-east-1.redshift.amazonaws.com on dbname "db1")

仅供参考,我可以使用相同的代码连接到其他非 SSL Redshift 集群,因此它可能与 Mac 上的 openssl 相关。

[2016/02/11 更新]

来自@MasashiMiyazaki 评论的更多信息:

我已经psql通过 CLI 进行连接,它工作正常。另外,我也可以使用 Python 模块成功连接psycopg2。但是,我必须禁用这条线.bash_profile才能让它们工作:

export DYLD_LIBRARY_PATH=/usr/lib:$DYLD_LIBRARY_PATH
4

1 回答 1

3

在这里在黑暗中拍摄。你试过RPostgres吗?

像这样安装

# install.packages("devtools")
devtools::install_github("RcppCore/Rcpp")
devtools::install_github("rstats-db/DBI")
devtools::install_github("rstats-db/RPostgres")

然后测试一下

library(DBI)
library(RPostgres)

con <- dbConnect(RPostgres::Postgres(),
           host = "XXXXXXXX.us-east-1.redshift.amazonaws.com",
           port = 5439,
           user = "XXXXXXXX",
           password = "XXXXXXXX",
           dbname = "db1")
于 2016-02-15T04:31:58.643 回答