首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法将云数据融合与PostgreSQL的Google连接

无法将云数据融合与PostgreSQL的Google连接
EN

Stack Overflow用户
提问于 2019-04-27 12:33:16
回答 3查看 3.7K关注 0票数 5

我的目标是通过云数据融合管道将数据从读取到BigQuery。

为此,我设置了一个云数据融合实例,并为服务帐户分配了以下两个权限:(请参阅权限)

  • Cloud客户机
  • 云数据融合API服务代理

作为下一步,我将自己连接到云数据融合实例,并导航到Wrangler -> Add Connection -> Database -> Google Cloud SQL for PostgreSQL

作为驱动程序,我上传了我在这里下载的postgres-socket-factory-1.0.13-jar-with-dependencies.jarhttps://github.com/GoogleCloudPlatform/cloud-sql-jdbc-socket-factory

对于驱动程序配置,我设置:

  • 名称: cloudsql-postgresql
  • 类名: org.postgresql.Driver

对于数据库连接,我设置:

  • 连接名称:<PROJECT_NAME>:<REGION>:<INSTANCE_CONNECTION_NAME>
  • 连接字符串:jdbc:postgresql://google/<DATABASE_NAME>?cloudSqlInstance=<INSTANCE_CONNECTION_NAME>&socketFactory=com.google.cloud.sql.postgres.SocketFactory
  • 用户名:数据库用户名
  • 密码:数据库密码

单击后,我将收到org.postgresql.Driver错误消息。

EN

回答 3

Stack Overflow用户

发布于 2019-04-28 21:18:28

很可能您需要一个驱动程序和JDBC套接字工厂才能使它正常工作。您应该将postgres连接器与套接字工厂捆绑到一个uber-jar中,看看这是否解决了问题。

下面是一个快速的(未经测试的) pom,它应该可以实现这一点:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.example</groupId>
   <artifactId>postgres-with-cloud-sql-socket-factory</artifactId>
   <packaging>pom</packaging>
   <version>0.0.1</version>

   <dependencies>
      <dependency>
         <groupId>org.postgresql</groupId>
         <artifactId>postgresql</artifactId>
         <version>42.2.5</version>
      </dependency>
      <dependency>
         <groupId>com.google.cloud.sql</groupId>
         <artifactId>postgres-socket-factory</artifactId>
         <version>1.0.13</version>
      </dependency>
   </dependencies>

   <build>
      <plugins>
         <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>2.4.1</version>
            <configuration>
               <!-- get all project dependencies -->
               <descriptorRefs>
                  <descriptorRef>jar-with-dependencies</descriptorRef>
               </descriptorRefs>
            </configuration>
            <executions>
               <execution>
                  <id>make-assembly</id>
                  <!-- bind to the packaging phase -->
                  <phase>package</phase>
                  <goals>
                     <goal>single</goal>
                  </goals>
               </execution>
            </executions>
         </plugin>
      </plugins>
   </build>
</project>
票数 3
EN

Stack Overflow用户

发布于 2019-07-30 18:12:28

@Sebastian Auberger,

我们也遇到了同样的问题,基本上数据融合创建了一个服务帐户,该帐户试图为Cloud实例创建一个IAP隧道。我们可以通过赋予角色"Cloud“来解决这个问题。

试试看,让我们知道!

票数 1
EN

Stack Overflow用户

发布于 2022-03-02 23:40:34

另外,如果数据融合是私有的,那么要通过私有接口(没有公共IP流量)到达Cloud实例,您将需要一个“代理VM",类似于这位医生中的描述,但是使用不同的启动脚本,这篇博客文章对如何实现这一点有一个很好的概述。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55880595

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档