我正在尝试打开与 Google Cloud Spanner 数据库的 JDBC 连接,但收到以下错误消息:
java.lang.IllegalArgumentException:此服务需要项目 ID,但无法从构建器或环境中确定。请使用构建器设置项目 ID。
我的 JDBC URL 如下:
jdbc:cloudspanner://localhost;Project=project-id;Instance=instance-id;Database=database-name;PvtKeyPath=path-to-key-file
如果我Project
从 URL 中删除该属性,则会收到以下异常:
java.sql.SQLNonTransientConnectionException:[Simba]JDBC 连接被拒绝:[Simba]JDBC 所需的连接键:项目;[Simba]JDBC 可选连接键:语言、模式
所以看起来驱动程序确实拿起了我的项目 ID,但不知何故不接受它。我已经检查并仔细检查了我的项目 ID 确实等于我在 Google 上创建的项目 ID,我还尝试将值更改为项目名称而不是项目 ID,但无济于事。
有没有人有一个有效的 URL 示例?
编辑:它似乎与对私钥文件的引用有关。如果我将环境变量 GOOGLE_APPLICATION_CREDENTIALS 指向我的私钥文件,则可以成功建立连接。如果我删除这个环境变量,我会得到上述异常。