【问题标题】:How to connect to the Oracle database using JDBC thin driver with TNSNames Alias Syntax如何使用带有 TNSNames 别名语法的 JDBC 瘦驱动程序连接到 Oracle 数据库
【发布时间】:2013-01-09 05:30:46
【问题描述】:

我正在尝试使用 Oracle JDBC 瘦驱动程序(11.2.0.2.0 的 ojdbc6.jar)和以下 JDBC URL 语法连接到 Oracle (11.2.0.2.0) 数据库:

jdbc:oracle:thin:@abcd

在我的 tnsnames.ora 文件中定义了“abcd”,如下所示:

    abcd, abcd.world, abcd.dk.xyz.com  =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = abcd.dk.xyz.com)(PORT = 1521))
    (CONNECT_DATA =
      (SERVICE_NAME = abcd)
    )
  )

我已经按照Oracle® Database JDBC Developer's Guide and Reference 提供了VM 选项-Doracle.net.tns_admin=/etc/tnsnames.ora

运行应用程序时出现以下错误:

    Listener refused the connection with the following error:
ORA-12504, TNS:listener was not given the SID in CONNECT_DATA

但是当我从 tnsnames.ora 中删除别名 abcd.world 和 abcd.dk.xyz.com 时,我的应用程序能够连接到数据库。

当 tnsnames.ora 文件中有多个别名时,ojdbc 驱动程序是否存在问题?

我的 JDK 版本是 1.6.0_31。

谢谢, 主播

【问题讨论】:

  • oracle.net.tns_admin 应该指向一个目录而不是一个文件。所以应该是-Doracle.net.tns_admin=/etc。另请注意,数据库集群可能有多个主机名,外加许多 DBA 可能想要设置的连接参数。 tnsnames.ora 确实应该是首选方式。 JDBC url 太“愚蠢”了。

标签: java jdbc


【解决方案1】:

看起来,Oracle JDBC 驱动程序不能使用多个服务名称。 使用这些条目

    abcd =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = abcd.dk.xyz.com)(PORT = 1521))
    (CONNECT_DATA =
      (SERVICE_NAME = abcd)
    )
  )
    abcd.world, abcd.dk.xyz.com  =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = abcd.dk.xyz.com)(PORT = 1521))
    (CONNECT_DATA =
      (SERVICE_NAME = abcd)
    )
  )

【讨论】:

    【解决方案2】:

    我可以通过以下方式通过tnsnames.ora成功连接到oracle

    1. 下载并解压flyway

    2. 从 oracle 站点下载最新的 ojdbcX.jar

    3. 将驱动程序目录中的文件放入flyway文件夹

    4. 将 flyway 文件夹(您可以在其中找到 flyway cli 脚本)放在路径中(es:在 linux 上 export PATH=/home/matteo/opt/flyway

    5. 编辑 flyway 二进制文件 /home/matteo/opt/flyway/flyway 放入 JAVA_ARGS="-Doracle.net.tns_admin= 指向包含 tnsnames.ora 的文件夹

    6. 注意:linux的flyway脚本在以下行中有一个错误 JAVA_ARGS="-Djava.security.egd=file:/dev/../dev/urandom $JAVA_ARGS" 你需要附加 $JAVA_ARGS 以不被覆盖

    7. 在您的项目文件夹中编辑一个您希望命名的文件,例如 flyway.conf

    8. 使用此命令测试飞行路径

      flyway -configFile=flyway.conf 信息

    我收到这个输出

    Boxfuse 的 Flyway 4.0.3

    数据库:jdbc:oracle:thin:@PSR.LAB_CERT (Oracle 11.2)

    +----------+-------------+----------+ ---------+

    |版本 |说明 |安装于 |状态 |

    +----------+-------------+----------+ ---------+

    |未找到迁移 |

    +----------+-------------+----------+ ---------+

    【讨论】:

      【解决方案3】:

      理想情况下,您不应该通过 TNS 连接,因为您需要在您的机器上安装 oracle 客户端。

      如果您使用如下连接 URL,则不需要 oracle 客户端:

      jdbc:oracle:thin:@//host:port/service_name
      

      【讨论】:

      • 你是对的。我更喜欢同样的。 oracle 客户端安装在每个环境中。我们被要求不要依赖主机名和端口号,因为这些可以随时更改,也可以在不同环境之间变化。并且还要尽量减少必须更改设置的地方的数量。用其他语言编写的应用程序似乎对这种设置没有任何问题。
      • 如果您仍想使用 TNS,我建议您使用以下链接:stackoverflow.com/questions/4832056/…。但是主机和端口不应随时间随机变化。它们应该是每个环境的马厩。您必须做的一件事是将应用程序中的 url 外部化,以便可以为每个环境设置它。
      • 感谢汤姆的链接。 url 已经外部化,我们现在使用jdbc:oracle:thin:@//host:port/service_name 格式。猜想当有多个别名时,我们无法使用 Oracle JDBC 驱动程序来使用 tnsnames.ora 中的 TNS 名称。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-12-13
      • 2017-10-16
      • 2011-04-24
      • 2015-06-20
      • 1970-01-01
      • 2021-01-29
      • 2021-09-28
      相关资源
      最近更新 更多