我正在尝试在Ubuntu 12.04计算机上的Jetty服务器中运行服务器和客户端应用程序。服务器启动没有问题,我使用了以下命令
$ mvn码头:运行
在发出此命令时,第一行是
在地址8787上监听传输dt_socket
但是,当我启动客户端时,出现以下错误
ERROR: transport error 202: bind failed: Address already in use
ERROR: JDWP Transport dt_socket failed to initialize, TRANSPORT_INIT(510)
JDWP exit error AGENT_ERROR_TRANSPORT_INIT(197): No transports initialized [../../../src/share/back/debugInit.c:690]
FATAL ERROR in native method: JDWP No transports initialized, jvmtiError=AGENT_ERROR_TRANSPORT_INIT(197)
Aborted
看起来与传输dt_socket有关。我不知道这是什么,以及如何为客户使用另一个地址?
编辑1
来自pom.xml的用于客户端的jetty-maven-plugin看起来像这样
<build>
<plugins>
<!-- Specific jetty-maven-plugin configuration for running Jetty during
development. None of its goals are run in a normal build lifecycle. -->
<plugin>
<groupId>org.mortbay.jetty</groupId>
<artifactId>jetty-maven-plugin</artifactId>
<version>${jetty-maven-plugin.version}</version>
<configuration>
<webAppConfig>
<contextPath>/</contextPath>
<extraClasspath>${basedir}/src/test/resources/</extraClasspath>
</webAppConfig>
<connectors>
<connector implementation="org.eclipse.jetty.server.nio.SelectChannelConnector">
<port>${servlet.port}</port>
<host>0.0.0.0</host>
</connector>
</connectors>
<reload>manual</reload>
<useTestClasspath>true</useTestClasspath>
</configuration>
</plugin>
</plugins>
</build>
我的假设是某些Jetty正在调试模式下启动,并尝试将调试器附加到端口8787上,该端口已经绑定到Server的调试器。
最佳答案
Jetty不会自动启动调试器。您很可能已将MAVEN_OPTS环境变量设置为包括-Xdebug参数。检查“echo $ MAVEN_OPTS”,您将看到类似以下内容:
-Xdebug -Xrunjdwp:transport=dt_socket,address=8787,server=y,suspend=n
您不能运行两个都尝试在端口8787上进行调试的Maven进程。因此,请更改全局MAVEN_OPTS(在osx上运行时在.bash_profile中)或为第二个终端会话更改MAVEN_OPTS:
export MAVEN_OPTS="-Xmx1024m -XX:MaxPermSize=512M"