我在一个独立的应用程序中使用CDI + DeltaSpike + Camel。
下面是我当前的设置:
persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="primary" transaction-type="RESOURCE_LOCAL">
<shared-cache-mode>DISABLE_SELECTIVE</shared-cache-mode>
</persistence-unit>
EntityManagerFactoryProducer上的自定义属性:
properties.put("hibernate.connection.provider_class", "org.example.HikariConnectionProvider");我使用DeltaSpike JPA事务处理(https://deltaspike.apache.org/documentation/jpa.html):
我想使用Infinispan同步我的应用程序缓存。根据Infinispan的说法:
强烈建议使用JTA事务配置Hibernate
如何使用JTA事务?我试图将"RESOURCE_LOCAL“更改为"JTA”,但我不明白我应该配置什么:
我不使用JNDI,也不在应用程序服务器中。
另外,我希望使用@javax.transaction.Transactional而不是DeltaSpike。
发布于 2016-10-29 15:52:22
本质上,您是在询问如何在不使用Java容器的情况下使用大多数Java特性。
当然,有些JTA实现可以嵌入到“独立”应用程序中,比如Atomikos。
另一方面,从一个成熟的Java环境开始,然后忽略或排除任何您不需要的东西,可能要容易得多。
应用服务器现在相当轻量级,如果一个自带的可执行文件对你来说是必须的,那么请看一看WildFly群集或PayaraMicro.com。
https://stackoverflow.com/questions/40284287
复制相似问题