1

我无法在 Maven 构建环境中的 Jetty 上配置 JOTM。当我尝试运行我的应用程序时遇到的异常如下:

2009-07-21 19:47:23.499::WARN:  Config error at <New id="UserTransaction" class="org.mortbay.jetty.plus.naming.Transaction"><Arg>
                <Ref id="ut"/>
            </Arg></New>
    [INFO] Jetty server exiting.
    [INFO] ------------------------------------------------------------------------
    [ERROR] BUILD ERROR
    [INFO] ------------------------------------------------------------------------
    [INFO] Failure

    A flat name can only have a single component

我将此用作参考:http ://docs.codehaus.org/display/JETTY/JOTM

jetty.xml(maven的pom.xml中的jettyConfig,这个其实是被看到的)

<?xml version="1.0"?>
<!DOCTYPE Configure PUBLIC "-//Mort Bay Consulting//DTD Configure//EN" "http://jetty.mortbay.org/configure.dtd">
<Configure id="Server" class="org.mortbay.jetty.Server">
<!-- Configure a Jotm instance which provides a javax.transaction.TransactionManager     -->
    <!-- and a javax.transaction.UserTransaction implementation.                             -->
    <New id="jotm" class="org.objectweb.jotm.Jotm">
        <Arg type="boolean">True</Arg>
        <Arg type="boolean">False</Arg>
        <Call id="tm" name="getTransactionManager"/>
        <Call id="ut" name="getUserTransaction"/>
    </New>

    <!-- Set up the UserTransaction impl from JOTM as the transaction manager for jetty      -->
    <!--
    <New id="UserTransaction" class="org.mortbay.jetty.plus.naming.Transaction">
        <Arg>
            <Ref id="ut"/>
        </Arg>
    </New>
    -->
    <New id="userTransaction" class="org.mortbay.jetty.plus.naming.Resource">
        <Arg></Arg>
        <Arg>javax.transaction.TransactionManager</Arg>
        <Arg>
            <Ref id="ut"/>
        </Arg>
    </New>


    <New id="tx" class="org.mortbay.jetty.plus.naming.Transaction">
        <Arg>
            <Ref id="ut"/>
        </Arg>
    </New>

    <!-- If you want to be able to set up more references in webapp specific files -->
    <!-- such as context deployment files and WEB-INF/jetty-env.xml files, you     -->
    <!-- need to save a reference to the JOTM tm object:                           -->
    <!--
    <Call name="setAttribute">
    <Arg>tm</Arg>
    <Arg><Ref id="tm"/></Arg>
    </Call>
    -->
</Configure>

carol.properties (不太确定这是否被看到,但从例外情况来看,这是否相关?)

carol.start.ns=false
carol.start.jndi=false
carol.protocols=jrmp
carol.start.rmi=false
carol.jvm.rmi.local.call=true
carol.jndi.java.naming.factory.url.pkgs=org.mortbay.naming

有任何想法吗?

谢谢,沃尔特

4

2 回答 2

0

似乎 carol 正在使用自己的carol.jar/carol.properties文件而不是您的文件。我在jetty 8中准备了一个带有修改carol.jar/carol.properties文件的jta示例项目。它是http://github.com/beolnix/jta-in-jetty8。似乎一切正常,(提交,回滚 - 没问题)但有时会org.omg.CORBA.BAD_INV_ORDER出现异常。在我的示例中,此异常被忽略

try {
    ret = ctx.proceed()
    tx.commit()
} catch (org.omg.CORBA.BAD_INV_ORDER e) {
    //nop
} catch (Throwable e) {
    tx.rollback()
    throw new TransactionException(e.getMessage())
}

因为它不影响事务处理的结果

于 2012-01-30T21:47:50.400 回答
0

carol.properties 在您的项目中位于何处?

Maven 资源需要在 src/main/resources 下。Jetty 期望 carol.properties 位于资源文件夹中。

因此,您可能需要将 carol.properties 移动到 src/main/resources/resources 以便在启动 Jetty 之前通过 process-resources 阶段将该文件复制到 target/resources。

于 2009-07-23T21:20:24.220 回答