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数据库。
版权所有,转载请注明出处。