ORA-12545: 因目标主机或对象不存在, 连接失败

1. 问题描述

  XP系统下同时安装了AX1应用程序和升级版AX2,连接同一个在本机Oracle客户端上配置的连接实例,其中AX2显示链接成功,而AX1却链接失败,其中Oracle实例配置一定正确,因为AX2已经链接成功。在此之前AX2和AX1都是能连接成功的,用户使用360杀毒后,AX1才出现问题。

2. 问题分析

  通过日志分析,发现AX1返回的错误信息是“ORA-12545: 因目标主机或对象不存在, 连接失败”。显然这个信息是错误的, Oracle错误的判断了问题的原因,因为我们所配置的主机是存在的,并且在AX2上已经链接成功了。

3. 解决办法

  为避免AX1的动态库影响,我们编写纯OCI的测试程序TestOCI.exe,这个exe只依赖Windows和OCI的动态库,将这个测试程序分别放到AX2的Program、AX1的 Program以及桌面随便的一个文件夹中,结果只有AX1的Program的显示链接失败,其他的两个文件夹下的测试程序都成功了。这就证明一定是AX1的 Program下的什么文件影响了连接过程。

  采用二分屏蔽法对AX1的Program所有文件进行分组测试,最后测试程序TestOCI.exe与ws2_32.dll 在同一个文件夹时,才会出现连接失败的问题,显然ws2_32.dll是Windows的Socket库,这个库出现在AX1的Program中时不正常的,所以可以断定这个问题是由ws2_32.dll文件引起的。

  然后我们就为什么这个库会影响我们的测试程序进行了分析,分别在问题机器上进行测试两组TestOCI.exe,一组是文件夹中只有测试exe,另一组文件夹中则包含测试exe和ws2_32.dll,分别打印这个exe启动运行时所加载的动态库。下面是两组测试结果,只摘录了部分重要信息。

  组1:文件夹中只有TestOCI.exe

Starting Directory: G:\AAA\Program\

Search Path:

C:\Program Files\Intel\iCLS Client\;

G:\app\Administrator\product\11.2.0\client_2\bin;

C:\Program Files\AMD APP\bin\x86;

C:\WINDOWS\system32;

C:\WINDOWS;

C:\WINDOWS\System32\Wbem;

C:\Program Files\ATI Technologies\ATI.ACE\Core-Static;

C:\Program Files\Intel\Intel(R) Management Engine Components\DAL;

C:\Program Files\Intel\Intel(R) Management Engine Components\IPT;

C:\Program Files\Common Files\Autodesk Shared\;

G:\AAA\program;

G:\AAA\program

Loaded "c:\windows\system32\WS2_32.DLL" at address 0x71A20000.Successfully hooked module.

  组2:文件夹中同时包含TestOCI.exe和ws2_32.dll

Starting Directory: G:\AAA\Program\

Search Path:

C:\Program Files\Intel\iCLS Client\;

G:\app\Administrator\product\11.2.0\client_2\bin;

C:\Program Files\AMD APP\bin\x86;

C:\WINDOWS\system32;

C:\WINDOWS;

C:\WINDOWS\System32\Wbem;

C:\Program Files\ATI Technologies\ATI.ACE\Core-Static;

C:\Program Files\Intel\Intel(R) Management Engine Components\DAL;

C:\Program Files\Intel\Intel(R) Management Engine Components\IPT;

C:\Program Files\Common Files\Autodesk Shared\;

G:\AAA\program;

G:\AAA\program

Loaded "g:\aaa\program\WS2_32.DLL" at address 0x71A20000.Successfully hooked module.

  从上面两个测试结果我们可以看出,两个测试程序的加载动态库的搜索路径是相同的,但是加载的ws2_32.dll动态库却不同,运行成功是加载c:\windows\system32下面的ws2_32.dll,而运行失败则是加载g:\aaa\program下的ws2_32.dll。g:\aaa\program\ws2_32.dll只有85K,而c:\windows\system32\WS2_32.DLL却有291K,显然g:\aaa\program\ws2_32.dll是一个错误的库,同时Windows的Socket是一整套的,只有这一个库被加载后,其他Socket库没有被加载也会出现问题。

  这个问题只出现在XP中,而在Win7中却不出现,可能的一个原因是XP和Win7搜索路径的优先级别不大相同吧,或是某些东西改变了动态库加载的环境等,但是不能确定。

4. 解决办法

  删除AX1/Program下的ws2_32.dll,即可恢复连接Oracle数据库。

版权所有,转载请注明出处。

ORA-12545: 因目标主机或对象不存在, 连接失败的更多相关文章

  1. oracle ORA-12545:因目标主机或对象不存在

    解决方法: 1.首先从最基本的入手,这里打开计算机右击,选择管理 2. 找到里面的服务和应用程序,打开服务 3.找到: OracleOraDb11g_home1TNSListener OracleSe ...

  2. 【转】Java JDBC连接SQL Server2005错误:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败

    错误原因如下: Exception in thread "main" org.hibernate.exception.JDBCConnectionException: Cannot ...

  3. Java JDBC连接SQL Server2005错误:通过port 1433 连接到主机 localhost 的 TCP/IP 连接失败

    错误原因例如以下: Exception in thread "main" org.hibernate.exception.JDBCConnectionException: Cann ...

  4. Java JDBC连接SQL Server2005错误:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败 及sql2008外围服务器

    转载:Java JDBC连接SQL Server2005错误:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败 错误原因如下: Exception in thread & ...

  5. SQLServerException:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败。

    一.问题描述: 1.连接数据库时抛出的异常: com.microsoft.sqlserver.jdbc.SQLServerException: 通过端口 1433 连接到主机 localhost 的 ...

  6. 修复ORACLETNS-12545 因目标主机或对象不存在错误

    现象: ORACLE启动不了,输入cmd->lsnrctl后,出现如下错误, 经查资料,发现是主机名可能解析有问题,后来在D:\oracle\ora92\network\admin下打开list ...

  7. ORA-12545:因目标主机或对象不存在,连接失败!

    错误原因是配置错误主机名 解决: 1. 搜索你自己安装的Oracle路径,找到这俩个文件 tnsnames.ora 和 listener.ora,修改这两个文件,修改HOST=自己的主机名 我的路径如 ...

  8. “ORA-12545: 因目标主机或对象不存在,连接失败”怎么办?

    大概知道是因为主机名或者IP地址的原因引起的,但是不知道究竟,就去百度上查了查,然后就根据几种答案做出了以下就该: 1.E:\oracle\product\10.2.0\db_1\NETWORK\AD ...

  9. 改计算机名导致 Oracle因目标主机或对象不存在

    手贱修改了计算机名, 结果导致登陆oracle数据库报如下错误,一查资料,说是修改了计算机名导致的,需要进到oracle安装目录: \oracle\product\10.2.0\db_1\NETWOR ...

随机推荐

  1. IISExpress配置文件的一个坑

    现象: 昨天在处理PBS系统问题的时候意外发现两个js错误(而同样的代码在同事机器上都没有问题),如下图. 图1 图2 图3 原因分析: 初步看起来是因为页面上没有id为'form1'的form和id ...

  2. iOS不显示状态栏(电池和信号栏)

    //隐藏状态栏 - (BOOL)prefersStatusBarHidden { return YES; } 在viewcontroller里面加入

  3. ncs安装及初次运行

    Tail-f NCS 作为网络配置程序和基础设备之间的接口,能够展现各种服务,修改各开发商不相同的设备配置,同时能及时同步网络设备状态到cdb(configuration database,配置数据库 ...

  4. wdcp升级php版本到5.3,5.5

    官网省级方法 wget http://down.wdlinux.cn/in/php_up53.shsh php_up53.sh 看到"php update is OK"提示表示,顺 ...

  5. 数据结构-Stack和Queue

    实现: #include "c2_list.h" template <typename object> class Stack{ public: bool isEmpt ...

  6. HDU 4627 E(Contest #3)

    Description There are many unsolvable problem in the world.It could be about one or about zero.But t ...

  7. 【转发】Linux下清除系统日志方法

    摘要:相信大家都是用过Windows的人.对于Windows下饱受诟病的各种垃圾文件都需要自己想办法删除,不然你的系统将会变得越来越大,越来越迟钝!windows怎么清理垃圾相信大家都知道的,那么li ...

  8. RPI学习--环境搭建_串口连接

    有两种, 一种是通过MAX2323芯片连接的串口,要接VCC为芯片供电. 另一种是通过PL2302芯片连接的USB,可不接VCC,用电脑USB口为芯片供电. 下面以通过MAX2323方式为例. 1,V ...

  9. centos ssh 无密码登录

    在linux系统中,ssh是远程登录的默认工具,因为该工具的协议使用了RSA/DSA的加密算法.该工具做linux系统的远程管理是非常安全的.telnet,因为其不安全性,在linux系统中被搁置使用 ...

  10. Linux文件管理系统

    首先了解一般linux文件系统的构成. */usr/bin./bin : 存放所有用户可以执行的命令 */usr/sbin ./sbin :存放只有root可以执行的命令 */home : 用户缺省宿 ...