java - 运行 Spring Boot Web 应用程序时 JVM 崩溃
问题描述
我的 Spring boot 2.0.3 Web 应用程序在 Eclipse 上运行良好,带有 Java 1.8-1.4.1 和嵌入式 Tomcat。但是当我构建我的war文件(使用mvn包)并将其部署到linux(uname -mrs给出Linux 4.9.77-31.58.amzn1.x86_64 x86_64),并在外部Tomcat 9.0.10上运行它(相同的java版本) ,JVM 在连接到 Oracle 时崩溃。发生崩溃的代码是:
@Repository
public class ReadFromDb {
@Autowired
private NamedParameterJdbcTemplate jdbcTemplate;
public TspsPatent readTspsPatent(TspsPatent tspsPatent)
{
System.out.println("DSxxx1");
// Next line crashes
List<TspsPatent> tspsPatents = jdbcTemplate.query("select 3 patent_sk from dual",
(rs, rowNum) -> new TspsPatent (rs.getString("patent_sk")));
System.out.println("DSxxx2");
if (tspsPatents.size() == 0) {return null;}
return tspsPatents.get(0);
}
}
即 DSxxx1 行打印在 catalina.out 中,但 DSxxx2 不是。完整的 catalina.out 在这里:
如果使用以下命令检查 jni 连接:
-Xcheck:jni
在 setenv.sh,然后在 catalina.out 我得到: catalina-jni.out
当 JVM 崩溃时,它会创建一个日志文件hs_err_pid40342.log
,该文件位于:
此日志文件在第 508 - 518 行包含一组,java/lang/ClassNotFoundException
其中之一是:
Event: 18.567 Thread 0x00007fe844620000 Exception <a 'java/lang/ClassNotFoundException': com/clarivate/dataviewer/model/TspsPatentCustomizer> (0x000000059e3dd210) thrown at [/HUDSON3/workspace/8-2-build-linux-amd64/jdk8u141/9370/hotspot/src/share/vm/classfile/systemDictionary.cpp, line 210]
我编写了包:com/clarivate/dataviewer/model,但没有名为 TspsPatentCustomizer 的类我在这个包中有 2 个名称相似的类:TspsPatent 和 TspsPatentNumberChange,但它们都只是普通的 pojo。为什么当这个类从未存在过时,JVM 会寻找一个名为 TspsPatentCustomizer 的类?
NamedParameterJdbcTemplate 类处理 dB 连接。它在:
spring-jdbc-5.0.7.RELEASE.jar
这个罐子在我的战争文件中
我的application.properties
有:
logging.level.root=INFO
server.port=8090
server.servlet.path=/
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
spring.datasource.initialization-mode=always
spring.datasource.url=jdbc:oracle:oci:@myDataBase
spring.datasource.username=myUser
spring.datasource.password=myPassword
spring.datasource.driver-class-name=oracle.jdbc.OracleDriver
我的pom.xml
文件包含:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.clarivate</groupId>
<artifactId>dataviewer</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>DataViewer</name>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<start-class>com.clarivate.dataviewer.DvMain</start-class>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<!-- DS may need to remove for tomcat installation -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
<exclusions>
<exclusion>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.1.0</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
<exclusions>
<exclusion>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-jdbc</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-taglibs</artifactId>
</dependency>
</dependencies>
<!-- Required to find ojdbc6, because Oracle don't make it available to maven-->
<repositories>
<repository>
<id>codelds</id>
<url>https://code.lds.org/nexus/content/groups/main-repo</url>
</repository>
</repositories>
<build>
<finalName>DataViewer</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<!-- <mainClass>com.clarivate.dataviewer.DvMain</mainClass>-->
<executable>true</executable>
</configuration>
</plugin>
</plugins>
</build>
<description>TSPS data viewer</description>
一个查询是这种依赖关系:
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.1.0</version>
</dependency>
我$ORACLE_HOME
的不是我的战争文件的一部分,它在 linux 上:
/oracle/app/oracle/product/11.2.0/client_1
这是无法改变的。所以版本号略有不同,这有什么不同吗?如果有,我该如何更改我的 Maven 版本?奇怪的 TspsPatentConversion 参考是副业,我主要关心的是让应用程序运行。我是否错过了任何与 Oracle 相关的设置或依赖项?非常感谢任何帮助或建议
解决方案
答案是 Oracle 客户端版本略有不匹配,请参阅: Oracle 社区
在我的战争文件中,我有 ojdbc6-11.2.0.1.0.jar,我在 Linux 上 $ORACLE_HOME 中的 Oracle 客户端是 11.2.0,这两个版本不相同,这种不兼容导致 jvm 崩溃。解决方案是从战争中删除 ojdbc6-11.2.0.1.0.jar 以强制我的应用程序在 $ORACLE_HOME 中使用 ojdbc6.jar。为此,您将 ojdbc6 范围“提供”添加到 pom.xml 中。
推荐阅读
- rx-java2 - SingleObserver.onError 在后台线程而不是主线程上调用
- zsh - zsh:像 `git` 一样完成 `mgit`
- go - 无法从 goroutine 中的通道读取
- html - Change style of a child component using parent class from parent component's style file
- c# - C#'String' 到 C++'std::string'
- reactjs - 如何在样式化组件中使用 {withTheme}。?请任何人给出实时示例
- android - 当我在 post 方法上点击 api 时得到空对象响应
- azure - 如何查看 Azure 订阅的详细成本明细
- pattern-matching - 最大子图匹配
- reactjs - TypeScript 中的 React 组件类型