当前位置: 代码迷 >> java >> JBoss在libclient64.dylib访问时崩溃
  详细解决方案

JBoss在libclient64.dylib访问时崩溃

热度:87   发布时间:2023-08-04 09:22:22.0

我正在尝试启动Oracle Instantclient并在Java 1.6.0_65的OS X上运行。 我执行了Oracle文档中描述的所有步骤: : 但问题仍然相同:

位置0x0的内存访问无效rip = 0x106369f87

堆栈跟踪为:

Process:               java [6234]
Path:                  /Library/Java/JavaVirtualMachines/jdk1.6.0_65.jdk/Contents/Home/bin/java
Identifier:            com.apple.javajdk16.cmd
Version:               1.0 (1.0)
Code Type:             X86-64 (Native)
Parent Process:        sh [6222]
Responsible:           Terminal [1179]
User ID:               33291

PlugIn Path:             /Library/Java/JavaVirtualMachines/jdk1.6.0_65.jdk/Contents/Home/bundle/Libraries/libclient64.dylib
PlugIn Identifier:       libclient64.dylib
PlugIn Version:          ??? (1)

Date/Time:             2015-07-28 11:22:49.211 +0200
OS Version:            Mac OS X 10.10.4 (14E46)
Report Version:        11
Anonymous UUID:        54BA4C92-323A-644A-55CF-CDBEDA054F4E


Time Awake Since Boot: 5500 seconds

Crashed Thread:        27  Java: main

Exception Type:        EXC_BAD_ACCESS (SIGSEGV)
Exception Codes:       KERN_INVALID_ADDRESS at 0x0000000000000000

VM Regions Near 0:
--> 
    __TEXT                 0000000106233000-000000010623b000 [   32K] r-x/rwx SM=COW  /Library/Java/JavaVirtualMachines/jdk1.6.0_65.jdk/Contents/Home/bin/java

Application Specific Information:
Java information:
 Exception type: Bus Error (0xa) at pc=106369f87

 Java VM: Java HotSpot(TM) 64-Bit Server VM (20.65-b04-462 mixed mode macosx-amd64)

Current thread (7fddcf86d800):  JavaThread "main" [_thread_in_vm, id=309616640, stack(112646000,112746000)]
Stack: [112646000,112746000]
Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
j  oracle.jdbc.driver.T2CConnection.t2cSetSessionTimeZone(JLjava/lang/String;)I+0
j  oracle.jdbc.driver.T2CConnection.logon()V+825
j  oracle.jdbc.driver.PhysicalConnection.<init>(Ljava/lang/String;Ljava/util/Properties;Loracle/jdbc/driver/OracleDriverExtension;)V+323
....

我尝试了32和64版本。 我使用适当的客户端版本以及在应用程序启动时激活或停用-d32标志来完成此操作。

两种接缝都有相同的问题。

有谁知道这里可能有什么问题吗?

谢谢

更新:

我将OCI替换为THIN,并将崩溃提前了。

jdbc:oracle:thin:@${dbserver:our.domain.de}:${dbport:1234}:${dbsid:OURSID}
jdbc:oracle:oci:@(description=(ADDRESS=(COMMUNITY=tcp.world)(PROTOCOL=TCP)(Host=our.domain.de)(Port=1521))(connect_data=(sid=OURSID)))

读取数据源后,它立即崩溃:

12:53:52,490 INFO  [ConnectionProviderFactory] Initializing connection provider: org.hibernate.ejb.connection.InjectedDataSourceConnectionProvider
12:53:52,490 INFO  [InjectedDataSourceConnectionProvider] Using provided datasource
Invalid memory access of location 0x0 rip=0x10ff50f87

Oracle没有很好地维护AFAIK客户端库,并且它们多年来根本不支持最新的OS X版本。 他们在Mac上崩溃了

尝试使用12c驱动程序。 但是,即使瘦驱动程序使JVM崩溃,您的Java安装也肯定有问题。 也许您的类路径中有多个JDBC驱动程序?