2014-12-27 3 views
2

Для моего школьного экзамена по программированию нам нужно построить и развернуть проект Spring MVC с использованием maven на сервере Tomcat (7). Большая часть этого материала работает. mvn clean install дает BUILD SUCCESS, который хорош, и я могу настроить мой сервер tomcat. Но whener я пытаюсь запустить или развернуть свой проект с, например mvn tomcat7:deploy я получаю сломанный исключение трубы, это выглядит следующим образом:Maven - Tomcat 7 - Hibernate MySQL: Broken Pipe Exception при развертывании mvn

[ERROR] Failed to execute goal org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:deploy (default-cli) on project SpringMVCBlog: Cannot invoke Tomcat manager: Broken pipe -> [Help 1] 

Полный трассировки стека (mvn tomcat7:deploy -e) выглядит следующим образом:

[ERROR] Failed to execute goal org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:deploy (default-cli) on project SpringMVCBlog: Cannot invoke Tomcat manager: Protocol wrong type for socket -> [Help 1] 
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:deploy (default-cli) on project SpringMVCBlog: Cannot invoke Tomcat manager 
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:216) 
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153) 
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145) 
    at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:116) 
    at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:80) 
    at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51) 
    at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:120) 
    at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:347) 
    at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:154) 
    at org.apache.maven.cli.MavenCli.execute(MavenCli.java:582) 
    at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:214) 
    at org.apache.maven.cli.MavenCli.main(MavenCli.java:158) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289) 
    at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229) 
    at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415) 
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356) 
Caused by: org.apache.maven.plugin.MojoExecutionException: Cannot invoke Tomcat manager 
    at org.apache.tomcat.maven.plugin.tomcat7.AbstractCatalinaMojo.execute(AbstractCatalinaMojo.java:141) 
    at org.apache.tomcat.maven.plugin.tomcat7.AbstractWarCatalinaMojo.execute(AbstractWarCatalinaMojo.java:68) 
    at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:132) 
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208) 
    ... 19 more 
Caused by: java.net.SocketException: Protocol wrong type for socket 
    at java.net.SocketOutputStream.socketWrite0(Native Method) 
    at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:92) 
    at java.net.SocketOutputStream.write(SocketOutputStream.java:136) 
    at org.apache.http.impl.io.AbstractSessionOutputBuffer.write(AbstractSessionOutputBuffer.java:181) 
    at org.apache.http.impl.io.ContentLengthOutputStream.write(ContentLengthOutputStream.java:115) 
    at org.apache.tomcat.maven.common.deployer.TomcatManager$RequestEntityImplementation.writeTo(TomcatManager.java:880) 
    at org.apache.http.entity.HttpEntityWrapper.writeTo(HttpEntityWrapper.java:89) 
    at org.apache.http.impl.client.EntityEnclosingRequestWrapper$EntityWrapper.writeTo(EntityEnclosingRequestWrapper.java:108) 
    at org.apache.http.impl.entity.EntitySerializer.serialize(EntitySerializer.java:117) 
    at org.apache.http.impl.AbstractHttpClientConnection.sendRequestEntity(AbstractHttpClientConnection.java:265) 
    at org.apache.http.impl.conn.ManagedClientConnectionImpl.sendRequestEntity(ManagedClientConnectionImpl.java:203) 
    at org.apache.http.protocol.HttpRequestExecutor.doSendRequest(HttpRequestExecutor.java:236) 
    at org.apache.http.protocol.HttpRequestExecutor.execute(HttpRequestExecutor.java:121) 
    at org.apache.http.impl.client.DefaultRequestDirector.tryExecute(DefaultRequestDirector.java:682) 
    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:486) 
    at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:863) 
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82) 
    at org.apache.tomcat.maven.common.deployer.TomcatManager.invoke(TomcatManager.java:742) 
    at org.apache.tomcat.maven.common.deployer.TomcatManager.deployImpl(TomcatManager.java:705) 
    at org.apache.tomcat.maven.common.deployer.TomcatManager.deploy(TomcatManager.java:388) 
    at org.apache.tomcat.maven.plugin.tomcat7.deploy.AbstractDeployWarMojo.deployWar(AbstractDeployWarMojo.java:85) 
    at org.apache.tomcat.maven.plugin.tomcat7.deploy.AbstractDeployMojo.invokeManager(AbstractDeployMojo.java:82) 
    at org.apache.tomcat.maven.plugin.tomcat7.AbstractCatalinaMojo.execute(AbstractCatalinaMojo.java:132) 
    ... 22 more 

Я боролся с этим для долгого пути, и я никогда не смогу найти решение. Когда я запускаю этот проект в своей среде IDE (IntelliJ), используя сервер Glassfish, он работает, но цель состоит в том, чтобы запустить его с помощью терминала (я нахожусь на Mac) и развернуть его на сервере Tomcat.

Я искал, но информации об обрыве трубы нет. Я обнаружил, что он имеет какое-то отношение к Hibernate и MySQL. У меня есть базовая структура Hibernate в приложении, просто базовый hibernate.cfg/xml с несколькими настройками и класс Util, чтобы получить сеанс, чтобы я мог сохранять и обновлять базу данных. Broken Pipe будет иметь какое-то отношение к Connection Pooling, которое я не использую (насколько мне известно) в моем проекте.

Я действительно надеюсь, что кто-нибудь может мне помочь, эта проблема крайне расстраивает. Пожалуйста, скажите мне, нужен ли какой-либо дополнительный код!

EDIT

Содержание сборки раздела моего pom.xml:

<build> 
     <plugins> 
      <plugin> 
       <groupId>org.apache.tomcat.maven</groupId> 
       <artifactId>tomcat7-maven-plugin</artifactId> 
       <version>2.2</version> 
      </plugin> 
     </plugins> 
     <pluginManagement> 
      <plugins> 
       <plugin> 
        <groupId>org.apache.tomcat.maven</groupId> 
        <artifactId>tomcat7-maven-plugin</artifactId> 
        <version>2.2</version> 
        <configuration> 
         <url>http://localhost:8080/manager/text</url> 
         <server>TomcatServer</server> 
         <username>root</username> 
         <password>root</password> 
         <path>/SpringMVCBlog</path> 
         <update>true</update> 
        </configuration> 
       </plugin> 
      </plugins> 
     </pluginManagement> 
    <finalName>SpringMVCBlog</finalName> 
    </build> 
+0

пожалуйста, вы можете обновить Mojo плагина информацию от pom.xml – kamoor

+0

@kamoor обновленного вопроса. Это ты имел в виду? –

+0

@kamoor или вам также нужны зависимости pom.xml? –

ответ

1

У меня точно такая же проблема. Единственный способ решения проблемы я не знаю до сих пор, чтобы вернуться к старому и неподдерживаемому org.codehaus.tomcat Maven плагину:

http://mvnrepository.com/artifact/org.codehaus.mojo/tomcat-maven-plugin

Очевидно, что это не может быть окончательным решением, хотя я только в состоянии развернуть мой как это сейчас.

Оказывается, эта ошибка возникает, если веб-контекст уже существует. К сожалению, сообщение об ошибке не беспокоит нас.

Я исправил его, используя официальный плагин apache tomcat maven (link) и вариант переадресации maven, доступный с плагином tomcat maven> = 2.1.

С уважением,

Маркус

1

Просто используйте

МВН tomcat7: повторно развернуть

если приложение уже развернуто.

В противном случае вам необходимо отменить развертывание приложения первым, прежде чем делать МВНЫ tomcat7: развернуть

Смежные вопросы