【问题标题】:Jetty can't start war file码头无法启动战争文件
【发布时间】:2017-07-30 11:56:02
【问题描述】:

我有一个 maven spring boot 应用程序,并且我成功地从 Intellij 打包了一个 war 文件。对于测试,我在本地运行 jetty 并将 war 文件放在 webapps 目录中,但出现此错误:

/hallo ---> oejwWebAppContext@6c86e993{/hallo,[file:///C:/Users/ricardo/AppData/Local/Temp/jetty-0.0.0.0-8080-hallo.war-_hallo- any-3522993186615732718.dir/webapp/, jar:file:///C:/Users/ricardo/AppData/Local/Temp/jetty-0.0.0.0-8080-hallo.war-_hallo-any-3522993186615732718.dir/webapp /WEB-INF/lib/jquery-3.1.1.jar!/META-INF/resources, jar:file:///C:/Users/ricardo/AppData/Local/Temp/jetty-0.0.0.0-8080- hallo.war-_hallo-any-3522993186615732718.dir/webapp/WEB-INF/lib/bootstrap-3.3.7.jar!/META-INF/resources, jar:file:///C:/Users/ricardo/AppData /Local/Temp/jetty-0.0.0.0-8080-hallo.war-_hallo-any-3522993186615732718.dir/webapp/WEB-INF/lib/bootstrap-3.3.7-1.jar!/META-INF/resources] ,UNAVAILABLE}{C:\Users\ricardo\Desktop\New folder\webapps\hallo.war} [失败]

名称现在是 halo.war。我的引导 jar 有什么问题吗?这是我的 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.example</groupId>
<artifactId>demoshop</artifactId>
<version>0.1.0</version>
<packaging>war</packaging>

<name>demoshop</name>
<description>tool</description>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.4.1.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>
</properties>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.amazonaws</groupId>
            <artifactId>aws-java-sdk-bom</artifactId>
            <version>1.11.22</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-test</artifactId>
        <version>4.1.3.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>com.amazonaws</groupId>
        <artifactId>aws-java-sdk-route53</artifactId>
    </dependency>
    <dependency>
        <groupId>com.h2database</groupId>
        <artifactId>h2</artifactId>
    </dependency>
    <dependency>
        <groupId>org.thymeleaf.extras</groupId>
        <artifactId>thymeleaf-extras-springsecurity4</artifactId>   
        <version>2.1.2.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>bootstrap</artifactId>
        <version>3.3.7-1</version>
    </dependency>
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>jquery</artifactId>
        <version>3.1.1</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.16.10</version>
        <scope>compile</scope>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

如果您需要更多信息,我可以提供。

更新 14-03:我在启动war文件时出错:

2017-03-14 12:05:59.772 INFO 6184 --- [Scanner-0] trationDelegate$BeanPostProcessorChecker:Bean 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration' 类型 [class org.springframework.transaction.annotation .ProxyTransactionManagementConfiguration$$EnhancerBySpringCGLIB$$344f3674] 不符合被所有 BeanPostProcessor 处理的条件(例如:不符合自动代理的条件) 2017-03-14 10:03:51.288 信息 4468 --- [主要] o.s.b.w.servlet.ServletRegistrationBean :映射servlet: 'dispatcherServlet' 到 [/]

2017-03-14 10:03:51.291 信息 4468 --- [
main] o.s.b.w.servlet.FilterRegistrationBean :映射过滤器: 'errorPageFilter' 到:[/*]

2017-03-14 10:03:51.292 信息 4468 --- [
main] o.s.b.w.servlet.FilterRegistrationBean :映射过滤器: 'characterEncodingFilter' 到:[/] 2017-03-14 10:03:51.292 信息 4468 --- [main] o.s.b.w.servlet.FilterRegistrationBean:映射过滤器:'hiddenHttpMethodFilter'到:[/]

2017-03-14 10:03:51.292 信息 4468 --- [主要] o.s.b.w.servlet.FilterRegistrationBean :映射过滤器: 'httpPutFormContentFilter' 到:[/] 2017-03-14 10:03:51.293 信息 4468 --- [main] o.s.b.w.servlet.FilterRegistrationBean:映射过滤器:'requestContextFilter'到:[/]

2017-03-14 10:03:51.402 警告 4468 --- [主要] ationConfigEmbeddedWebApplicationContext:遇到异常 在上下文初始化期间 - 取消刷新尝试: org.springframework.beans.factory.UnsatisfiedDependencyException: 创建具有名称的 bean 时出错 'org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration': 通过构造函数参数 0 表示的不满足的依赖关系; 嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 创建在类路径资源中定义的名称为“dataSource”的bean [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Tomcat.class]: 通过工厂方法实例化 Bean 失败;嵌套异常是 org.springframework.beans.BeanInstantiationException:失败 实例化[org.apache.tomcat.jdbc.pool.DataSource]:工厂方法 'dataSource' 抛出异常;嵌套异常是 java.util.ServiceConfigurationError:org.apache.juli.logging.Log: 提供者 org.eclipse.jetty.apache.jsp.JuliLog 不是子类型

2017-03-14 10:03:51.411 信息 4468 --- [主要] utoConfigurationReportLoggingInitializer :

UPADTE POM.xml:

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <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>
                <exclusion>
                    <groupId>org.apache.tomcat.embed</groupId>
                    <artifactId>tomcat-embed-el</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jetty</artifactId>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
        </dependency>
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.webjars</groupId>
            <artifactId>bootstrap</artifactId>
            <version>3.3.7-1</version>
        </dependency>
        <dependency>
            <groupId>org.webjars</groupId>
            <artifactId>jquery</artifactId>
            <version>3.1.1</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.10</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>org.json</groupId>
            <artifactId>json</artifactId>
        </dependency>
        <dependency>
            <groupId>org.webjars</groupId>
            <artifactId>webjars-locator</artifactId>
            <version>0.30</version>
        </dependency>
    </dependencies>

【问题讨论】:

  • * 我成功地从 Intellij 打包了一个战争文件。* 你是如何准确地创建战争的?您应该使用 maven 而不是 IntelliJ 的导出。
  • 我在命令行 mvn 和 IntelliJ 中都使用了它们,但两者的结果相同。命令:mvn compile package war:war
  • 应该有更多的日志表明失败的原因、异常或消息。
  • 我在上面做了一个编辑
  • 您应该只使用mvn compile package,这将为您带来一场适当的春季靴战。 war:war 将覆盖 spring boot 生成的一个普通的战争。

标签: java spring maven jetty war


【解决方案1】:

您可以像这样从 Jar 中排除默认的 Tomcat Embedded

  <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>
            <exclusion>
                <groupId>org.apache.tomcat.embed</groupId>
                <artifactId>tomcat-embed-el</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

那么你应该包括码头

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jetty</artifactId>
    </dependency>

使用 mvn spring-boot:run 运行应用程序 希望这会有所帮助。

【讨论】:

  • 在 intelij 中运行它可以正常工作,只是码头在更新中仍然有同样的错误
  • 您必须从您的应用程序战争中“排除”tomcat,然后将战争部署到 webapps 文件夹。 org.springframework.bootspring-boot-starter-tomcat提供
  • 我不能在排除中设置范围,但是如果我把它放在 pom 文件中,它会给出同样的错误
【解决方案2】:

来自 Spring Boot 文档 - Create a deployable war file

如果你想在应用服务器上运行,你需要这样的东西

@SpringBootApplication
public class Application extends SpringBootServletInitializer {

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
        return application.sources(Application.class);
    }

    public static void main(String[] args) throws Exception {
        SpringApplication.run(Application.class, args);
    }

}

【讨论】:

  • 我是否需要一个数据库路径,因为它是一个 h2 数据库,我认为数据库不会在 war 文件中创建?
  • 也许可以尝试使用 h2 内存模式
【解决方案3】:

如果您使用 Web 依赖项,则无需部署 Spring Boot 应用程序,它会自动为您嵌入 Tomcat 以及所有依赖项。使用jar打包,直接使用java即可运行:java -jar yourapp.java

【讨论】:

  • 只有我们公司使用 jetty 和 war 文件来部署应用程序,我应该更改依赖关系吗?
  • 在这里结帐第 85.1 节:docs.spring.io/spring-boot/docs/current/reference/htmlsingle/… 也许你错过了一步。
  • 好的,我试过了,但他不喜欢 bootstrap 和 jquery 依赖项
  • 我这样做了,那部分现在正在工作,我只有在启动应用程序时出现错误。
  • @RicardoBuijsman 你能显示你的 pom.xml(依赖项部分)
【解决方案4】:

我在我的应用程序中进行了哪些更改以使战争文件与码头一起使用:

带向导的应用类:http://docs.spring.io/spring-boot/docs/current/reference/html/howto-traditional-deployment.html

@SpringBootApplication
public class Application extends SpringBootServletInitializer {

@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
    return application.sources(Application.class);
    }

public static void main(String[] args) throws Exception {
    SpringApplication.run(Application.class, args);
    }

}

在许多人的帮助下,我在我的 pom 文件中包含了以下内容:

<packaging>war</packaging>

<properties>
    <jetty.version>9.1.0.v20131115</jetty.version>
    <servlet-api.version>3.1.0</servlet-api.version>
</properties>

<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>
    <dependency>
        <groupId>org.apache.tomcat</groupId>
        <artifactId>tomcat-juli</artifactId>
        <version>9.0.0.M17</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>webjars-locator</artifactId>
        <version>0.30</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jetty</artifactId>
    </dependency>

感谢大家的帮助。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-05-02
    • 1970-01-01
    • 2011-01-28
    • 2016-07-23
    相关资源
    最近更新 更多