zoukankan      html  css  js  c++  java
  • ORA-12545: 因目标主机或对象不存在, 连接失败

    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:AAAProgram

    Search Path:

    C:Program FilesInteliCLS Client;

    G:appAdministratorproduct11.2.0client_2in;

    C:Program FilesAMD APPinx86;

    C:WINDOWSsystem32;

    C:WINDOWS;

    C:WINDOWSSystem32Wbem;

    C:Program FilesATI TechnologiesATI.ACECore-Static;

    C:Program FilesIntelIntel(R) Management Engine ComponentsDAL;

    C:Program FilesIntelIntel(R) Management Engine ComponentsIPT;

    C:Program FilesCommon FilesAutodesk Shared;

    G:AAAprogram;

    G:AAAprogram

    Loaded "c:windowssystem32WS2_32.DLL" at address 0x71A20000.Successfully hooked module.

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

    Starting Directory: G:AAAProgram

    Search Path:

    C:Program FilesInteliCLS Client;

    G:appAdministratorproduct11.2.0client_2in;

    C:Program FilesAMD APPinx86;

    C:WINDOWSsystem32;

    C:WINDOWS;

    C:WINDOWSSystem32Wbem;

    C:Program FilesATI TechnologiesATI.ACECore-Static;

    C:Program FilesIntelIntel(R) Management Engine ComponentsDAL;

    C:Program FilesIntelIntel(R) Management Engine ComponentsIPT;

    C:Program FilesCommon FilesAutodesk Shared;

    G:AAAprogram;

    G:AAAprogram

    Loaded "g:aaaprogramWS2_32.DLL" at address 0x71A20000.Successfully hooked module.

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

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

    4. 解决办法

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

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

  • 相关阅读:
    人物-IT-张志东:张志东
    人物-IT-任正非:任正非
    人物-IT-张朝阳:张朝阳
    院校-清华大学:清华大学
    人物-丁磊:丁磊
    人物-李彦宏:李彦宏
    人物-IT-马云:马云
    inittab
    initlocation
    initdb
  • 原文地址:https://www.cnblogs.com/wanghaiyang1930/p/4125949.html
Copyright © 2011-2022 走看看