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. Entity Framework 复杂类型

      为了说明什么是复杂属性,先举一个例子. public class CompanyAddress { public int ID { get; set; } public string Compan ...

  2. JS对象的写法

    写法1: <script> var database = function () { function add(){ console.info("add"); } fu ...

  3. Htmlhelper—CheckBox自动生成两个input

    前言 在之前的一篇文章中小猪分享了Htmlhelper的用法.其中有意思的一个就是Checkbox,有必要单独拿出来讲一讲. Htmlhelper—CheckBox 细心的读者一定发现了当使用类似语法 ...

  4. 两天以来对plsqldev操作的记忆

    frist,开机后,打开服务,打开服务,打开服务(重要的事情说三遍). and then, 打开plsqldev,输入TEST账户而不是SYS账户,否则你会被许多未接触到的内容淹没你刚刚创建好的表. ...

  5. checkbox全选功能

    $("#cb_classType_all").change(function () { if ($(this).is(":checked")) { $(&quo ...

  6. mac下安装apache+php+mysql

    运行“sudo apachectl start”,再输入帐号密码,这样Apache就运行了. 运行“sudo apachectl -v”,你会看到Mac OS X 10.6.3中的Apache版本号: ...

  7. IntelliLock托管代码保护和许可授权管理系统软件详细介绍及下载

    IntelliLock是一个能用于控件与应用程序许可授权的100%托管的先进解决方案.与.NET Reactor提供的基于源代码保护的授权许可系统不同,IntelliLock选择了以100%托管的方式 ...

  8. APC to USB

    from :http://www.allpinouts.org/index.php/APC_USB_cable_schematic connector or cable wiring APC part ...

  9. [windows驱动]内核态驱动架构

    1.windows驱动简介: 1.1 windows组件简介: 1.2 windows驱动类型: windows驱动分为两种基本类型: 用户态驱动在用户态下执行.它们一般提供一套win32应用程序和内 ...

  10. SharePoint 2013 Nintex Workflow 工作流帮助(七)

    博客地址 http://blog.csdn.net/foxdave 工作流动作 11. Check out item(Libraries and lists分组) 与上一个对应,用于签出条目.如果一个 ...