AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 112199
Accepted
Hariharbalaji
Hariharbalaji
Asked: 2010-02-12 22:48:47 +0800 CST2010-02-12 22:48:47 +0800 CST 2010-02-12 22:48:47 +0800 CST

如何在java中连接到oracle服务器?

  • 772

我正在尝试连接到我的朋友 Oracle 服务器。但是在连接时我收到错误请帮助.....

JDBC 代码

Class.forName(oracle.jdbc.driver.OracleDriver).newInstance();
conn=DriverManager.getConnection(jdbc:oracle:thin:@<IPaddress>:<SID>,userName,password);
conn.close();

错误信息

java.sql.SQLException: The Network Adapter could not establish the connection
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:412)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:531)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:221)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:503)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at com.wipro.sample.min.main(min.java:28)

    Caused by: oracle.net.ns.NetException: The Network Adapter could not establish the connection
   at oracle.net.nt.ConnStrategy.execute(ConnStrategy.java:359)
   at oracle.net.resolver.AddrResolution.resolveAndExecute(AddrResolution.java:422)
   at oracle.net.ns.NSProtocol.establishConnection(NSProtocol.java:672)
   at oracle.net.ns.NSProtocol.connect(NSProtocol.java:237)
   at oracle.jdbc.driver.T4CConnection.connect(T4CConnection.java:1042)
   at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:301)
   ... 7 more

    Caused by: java.net.ConnectException: Connection refused: connect
   at java.net.PlainSocketImpl.socketConnect(Native Method)
   at java.net.PlainSocketImpl.doConnect(Unknown Source)
   at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
   at java.net.PlainSocketImpl.connect(Unknown Source)
   at java.net.SocksSocketImpl.connect(Unknown Source)
   at java.net.Socket.connect(Unknown Source)
   at oracle.net.nt.TcpNTAdapter.connect(TcpNTAdapter.java:141)
   at oracle.net.nt.ConnOption.connect(ConnOption.java:123)
   at oracle.net.nt.ConnStrategy.execute(ConnStrategy.java:337)
   ... 12 more
java oracle jdbc
  • 5 5 个回答
  • 10399 Views

5 个回答

  • Voted
  1. Best Answer
    Abhiram
    2010-02-12T23:29:08+08:002010-02-12T23:29:08+08:00

    看起来 oracle 服务器没有在听...

    连接到存在 oracle 的机器..

    运行su - oracle

    lsnrctl 状态

    侦听器是否处于非活动状态,然后执行lsnrctl start

    • 2
  2. Upul
    2010-02-12T22:54:52+08:002010-02-12T22:54:52+08:00

    您似乎无法连接到 Oracle 服务器。首先尝试使用 Oracle 的端口远程登录您的 Oracle 服务器。

    前任: telnet <Oracle Serrver IP> 1521

    • 1
  3. uthark
    2010-02-12T22:55:52+08:002010-02-12T22:55:52+08:00

    当您:

    1. 尝试连接到不同的主机:端口。仔细检查您的设置。
    2. Oracle 服务器已关闭。你需要启动它。
    3. 您的防火墙阻止了您与 oracle 的连接。您需要允许访问您的应用程序。
    • 1
  4. DCookie
    2010-02-14T10:04:31+08:002010-02-14T10:04:31+08:00

    典型的 Oracle 网络设置包括:

    1. 服务器上的数据库实例
    2. 正如@Abhiram 所说,“侦听器”也在服务器上运行,等待连接,默认情况下在端口 1521 上。
    3. 客户端在正确的端口上连接到服务器,侦听器将连接移交给数据库实例。

    正如其他人指出的那样,(1)数据库需要启动;(2) 监听器需要运行并且你需要知道什么端口;(3) 防火墙需要配置为允许端口上的流量,通常在服务器端。

    您的朋友可以通过侦听器(不是本地连接)在他们的系统上使用 ODBC 连接吗?换句话说,您的代码会在他们的系统上运行吗?

    • 0
  5. Peter Moh
    2014-12-30T11:14:45+08:002014-12-30T11:14:45+08:00

    扣板执行以下操作:

    1. ping IP 地址。如果超时,则表示存在网络连接问题。
    2. 如果 ping 结果表明连接正常,并且仍然出现相同的异常,则执行以下操作:使用命令 tracert Ip Address 到 gat 域名。
    3. 在连接字符串中使用域名而不是 ip addesss:

      conn=DriverManager.getConnection(jdbc:oracle:thin:@<IPaddress>:<SID>,userName,password);
      conn=DriverManager.getConnection(jdbc:oracle:thin:@<domain Name>:<SID>,userName,password);
      
    4. 使用DriverManager.registerDriver (new oracle.jdbc.OracleDriver()); 而不是 Class.forName(oracle.jdbc.driver.OracleDriver).newInstance();
    • -1

相关问题

  • jvm性能调优技巧/资源?

  • Linux 服务器上的多个*几乎*相同的进程

  • 您认为 Linux 服务器上的 Java 是个问题吗?[关闭]

  • 如何定期复制 SVN 存储库而不会丢失目标标签和分支?

  • GlassFish 更改 Web 服务的端口

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve