java - 运行 Spring Boot Web 应用程序时 JVM 崩溃

标签 java maven spring-boot tomcat 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 在这里:

catalina.out

如果检查 jni 连接使用:

-Xcheck:jni

在 setenv.sh 中,然后在 catalina.out 中我得到: catalina-jni.out

当 JVM 崩溃时,它会创建一个日志文件 hs_err_pid40342.log,位于此处:

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/模型 但是没有名为 TspsPatentCustomizer 的类 我在这个包中有 2 个名称相似的类: TspsPatent 和 TspsPatentNumberChange 但它们都只是普通的 pojo。 为什么 JVM 正在寻找一个名为 TspsPatentCustomizer 的类,而这个类根本不存在?

NamedParameterJdbcTemplate 类处理 dB 连接。它位于:

spring-jdbc-5.0.7.RELEASE.jar

这个jar在我的war文件里

我的 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 不是我的 war 文件的一部分,它在 linux 上位于: /oracle/app/oracle/product/11.2.0/client_1

无法更改。 所以版本号略有不同,这会有所不同吗?如果有,我该如何更改我的 Maven 版本? 奇怪的 TspsPatentConversion 引用是副业,我主要关心的是让应用程序运行。我是否遗漏了任何与 Oracle 相关的设置或依赖项? 非常感谢任何帮助或建议

最佳答案

答案是 Oracle 客户端中的版本略有不匹配,请参阅: Oracle community

在我的 war 文件中,我有 ojdbc6-11.2.0.1.0.jar,我在 Linux 上 $ORACLE_HOME 中的 Oracle 客户端是 11.2.0,这两个版本不相同,这种不兼容性导致了 jvm 崩溃。解决方案是从 war 中删除 ojdbc6-11.2.0.1.0.jar 以强制我的应用程序在 $ORACLE_HOME 中使用 ojdbc6.jar。为此,您将“提供”的 ojdbc6 范围添加到 pom.xml 文件中。

关于java - 运行 Spring Boot Web 应用程序时 JVM 崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52947392/

相关文章:

java - 在 Java 中将一个数组中的特定元素添加到另一个数组中

java - 嵌套循环在 Mastermind 游戏中无法正常工作

java - CORBA 与 Web 服务

Java监控多个文件夹

java - 在非 Debug模式下运行 jar

java - 由于 servlet-api,Spring Boot 应用程序未启动

java - Maven 版本问题

java - LocalSessionFactoryBean 类型已弃用

spring-boot - 如何使用 OpenSSL 在 Alpine 中运行 Java SpringBoot 应用程序

java - 如何从IgniteCache中获取某种类型的所有条目的数量?