Maven, Пристань, JOTM
Вопрос
Мне не удалось настроить JOTM поверх Jetty внутри среды сборки Maven.Исключение, которое я получаю при попытке запустить свое приложение, заключается в следующем:
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 (jettyConfig в maven pom.xml , это действительно видно)
<?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
Есть какие-нибудь идеи?
Спасибо, Уолтер
Решение
Где carol.properties находится в вашем проекте?
Ресурсы Maven должны находиться в разделе src/main/resources .Jetty ожидает, что carol.properties будет находиться в папке resources.
Поэтому вам может потребоваться переместить carol.properties в src/main/resources/ресурсы, чтобы файл был скопирован в target/resources на этапе process-resources перед запуском Jetty.
Другие советы
Похоже, что Кэрол использует собственные carol.jar/carol.properties
файл вместо вашего.я подготовил пример проекта с jta в jetty 8 с измененным carol.jar/carol.properties
файл.вот оно 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())
}
потому что это не влияет на результат обработки транзакции