【问题标题】:Maven - Tomcat 7 - Hibernate MySQL: Broken Pipe Exception when doing mvn deployMaven - Tomcat 7 - 休眠 MySQL:执行 mvn 部署时出现断管异常
【发布时间】:2015-02-24 11:23:57
【问题描述】:

对于我学校的编程考试,我们需要能够在 Tomcat (7) 服务器上使用 maven 构建和部署 Spring MVC 项目。这些东西大部分都在工作。 mvn clean install 提供 BUILD SUCCESS 这很好,我可以设置我的 tomcat 服务器。但是,当我尝试使用例如mvn tomcat7:deploy 运行或部署我的项目时,我得到了一个损坏的管道异常,它看起来像这样:

[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

我一直在为此苦苦挣扎,但我似乎永远找不到解决方案。当我使用 glassfish 服务器在我的 IDE (IntelliJ) 中运行这个项目时,它可以工作,但目标是使用终端(我在 Mac 上)运行它并将其部署在 Tomcat 服务器上。

我已经搜索过,但没有太多关于破管异常的信息。我发现它与 Hibernate 和 MySQL 有关。我在应用程序中有一个基本的 Hibernate 结构,只有一个基本的 hibernate.cfg/xml 有一些设置和一个 Util 类来获取会话,这样我就可以在数据库上保存和更新。 Broken Pipe 与我在项目中没有使用(据我所知)的连接池有关。

我真的希望任何人都可以帮助我,这个问题非常令人沮丧。如果需要任何额外的代码,请告诉我!

编辑

我的 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>

【问题讨论】:

  • 你能从 pom.xml 更新 mojo 插件信息吗
  • @kamoor 更新了问题。你是这个意思吗?
  • @kamoor 还是你还需要 pom.xml 依赖项?
  • @kamoor 我将如何检查它们?我怀疑 Tomcat 使用的某些端口正在使用中,是这样吗?
  • @kamoor 如果我尝试得到INFO: Starting ProtocolHandler ["http-bio-8080"],然后它不会做任何事情

标签: mysql hibernate maven spring-mvc tomcat


【解决方案1】:

随便用

mvn tomcat7:重新部署

如果您的应用程序已经部署。

否则您需要先取消部署应用程序,然后再执行 mvn tomcat7:deploy

【讨论】:

    【解决方案2】:

    我也有同样的问题。 到目前为止,我知道的唯一解决方法是切换回旧的且不受支持的 org.codehaus.tomcat maven 插件:

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

    显然这不是最终的解决方案,尽管我现在只能像这样部署我的战争。

    事实证明,如果 Web 上下文已经存在,则会发生此错误。不幸的是,错误消息并没有告诉我们。

    我通过使用官方 apache tomcat maven 插件 (link) 和自 tomcat maven plugin >=2.1 后可用的 maven redeploy 选项修复了它。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-03-02
      • 2013-07-24
      • 2017-07-03
      • 1970-01-01
      • 2013-07-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多