简体   繁体   English

码头无法启动战争档案

[英]Jetty can't start war file

I have a maven spring boot application and i successfully packaged a war file from Intellij. 我有一个Maven Spring Boot应用程序,并且我成功地打包了Intellij的war文件。 for a test i run jetty locally and put the war file in the webapps directory but i get this error: 为了进行测试,我在本地运行码头并将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} [failed] / 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],无法使用} { C:\\ Users \\ ricardo \\ Desktop \\ New文件夹\\ webapps \\ hallo.war} [失败]

The name is now hallo.war. 现在的名称是hallo.war。 Is there something wrong with my bootstrap jar? 我的引导罐有问题吗? this is my pom.xml 这是我的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>

If you need more information i can provide it. 如果您需要更多信息,我可以提供。

UPDATE 14-03: i have a error while starting the war file: 更新 14-03:启动war文件时出现错误:

2017-03-14 12:05:59.772 INFO 6184 --- [ Scanner-0] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration' of type [class org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration$$EnhancerBySpringCGLIB$$344f3674] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying) 2017-03-14 10:03:51.288 INFO 4468 --- [ main] osbwservlet.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/] 2017-03-14 12:05:59.772信息6184-[扫描器0] trationDelegate $ BeanPostProcessorChecker:类型[类org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration $类型的Bean'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration' $ EnhancerBySpringCGLIB $$ 344f3674]不符合所有BeanPostProcessors的处理要求(例如:不符合自动代理的条件)2017-03-14 10:03:51.288 INFO 4468 --- [main] osbwservlet.ServletRegistrationBean:映射Servlet :'dispatcherServlet'到[/]

2017-03-14 10:03:51.291 INFO 4468 --- [ 2017-03-14 10:03:51.291 INFO 4468 --- [
main] osbwservlet.FilterRegistrationBean : Mapping filter: 'errorPageFilter' to: [/*] main] osbwservlet.FilterRegistrationBean:映射过滤器:'errorPageFilter'到:[/ *]

2017-03-14 10:03:51.292 INFO 4468 --- [ 2017-03-14 10:03:51.292 INFO 4468 --- [
main] osbwservlet.FilterRegistrationBean : Mapping filter: 'characterEncodingFilter' to: [/ ] 2017-03-14 10:03:51.292 INFO 4468 --- [ main] osbwservlet.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/ ] [主要] osbwservlet.FilterRegistrationBean:将过滤器:'characterEncodingFilter'映射至:[/ ] 2017-03-14 10:03:51.292 INFO 4468 --- [[主要] osbwservlet.FilterRegistrationBean:映射过滤器:'hiddenHttpMethodFilter'映射至:[/ ]

2017-03-14 10:03:51.292 INFO 4468 --- [ main] osbwservlet.FilterRegistrationBean : Mapping filter: 'httpPutFormContentFilter' to: [/ ] 2017-03-14 10:03:51.293 INFO 4468 --- [ main] osbwservlet.FilterRegistrationBean : Mapping filter: 'requestContextFilter' to: [/ ] 2017-03-14 10:03:51.292 INFO 4468 --- [main] osbwservlet.FilterRegistrationBean:映射过滤器:'httpPutFormContentFilter'到:[/ ] 2017-03-14 10:03:51.293 INFO 4468 --- [main ] osbwservlet.FilterRegistrationBean:将过滤器:“ requestContextFilter”映射到:[/ ]

2017-03-14 10:03:51.402 WARN 4468 --- [ main] ationConfigEmbeddedWebApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration': Unsatisfied dependency expressed through constructor parameter 0; 2017-03-14 10:03:51.402 WARN 4468 --- [main] ationConfigEmbeddedWebApplicationContext:上下文初始化期间遇到异常-取消刷新尝试:org.springframework.beans.factory.UnsatisfiedDependencyException:创建名称为'org.springframework的bean时出错。 boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration':通过构造函数参数0表示的不满足依赖性; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Tomcat.class]: Bean instantiation via factory method failed; 嵌套的异常是org.springframework.beans.factory.BeanCreationException:创建在类路径资源[org / springframework / boot / autoconfigure / jdbc / DataSourceConfiguration $ Tomcat.class]中定义的名称为“ dataSource”的bean时出错:通过工厂方法实例化Bean失败; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.tomcat.jdbc.pool.DataSource]: Factory method 'dataSource' threw exception; 嵌套的异常是org.springframework.beans.BeanInstantiationException:无法实例化[org.apache.tomcat.jdbc.pool.DataSource]:工厂方法'dataSource'引发了异常; nested exception is java.util.ServiceConfigurationError: org.apache.juli.logging.Log: Provider org.eclipse.jetty.apache.jsp.JuliLog not a subtype 嵌套的异常是java.util.ServiceConfigurationError:org.apache.juli.logging.Log:提供者org.eclipse.jetty.apache.jsp.JuliLog不是子类型

2017-03-14 10:03:51.411 INFO 4468 --- [ main] utoConfigurationReportLoggingInitializer : 2017-03-14 10:03:51.411 INFO 4468 --- [main] utoConfigurationReportLoggingInitializer:

UPADTE POM.xml: 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>

在此处输入图片说明

You can exclude default Tomcat Embedded from Jar like this 您可以像这样从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>

Then you should include jetty 那你应该包括码头

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

run application using mvn spring-boot:run Hope this helps. 使用mvn spring-boot运行应用程序:运行希望这会有所帮助。

From Spring Boot Documentation - Create a deployable war file 从Spring Boot文档- 创建可部署的war文件

You need something like this, if you want run on application server 如果要在应用程序服务器上运行,则需要这样的内容

@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);
    }

}

You do not need to deploy a Spring Boot application if you are using web dependency, it will automatically embed Tomcat for you, plus all the dependencies. 如果您正在使用Web依赖项,则无需部署Spring Boot应用程序,它将自动为您嵌入Tomcat,以及所有依赖项。 Use a jar packaging, and you can run it directly using java: java -jar yourapp.java 使用jar包装,您可以直接使用java运行它:java -jar yourapp.java

what i have changed in my application to make a war file work with jetty: 我在应用程序中进行了哪些更改,以使码头可以使用战争文件:

The application class with the guide: http://docs.spring.io/spring-boot/docs/current/reference/html/howto-traditional-deployment.html 带有指南的应用程序类: 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);
    }

}

And the help of many I included the following in my pom file: 在许多人的帮助下,我的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>

Thank you for all the help. 感谢您的所有帮助。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM