在OSGi中的Hibernate中创建EntityManagerFactory

时间:2017-06-27 05:32:47

标签: hibernate jpa osgi

我正在使Hibernate与OSGi一起工作,因此该项目的基础是org.hibernate.osgi

我创建了以下 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 persistence_2_1.xsd"
    version="1.0">
    <persistence-unit name="DemoUnit" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>

        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect" />
            <property name="hibernate.connection.driver_class" value="org.h2.Driver" />
            <property name="hibernate.connection.username" value="sa" />
            <property name="hibernate.connection.password" value="" />
            <property name="hibernate.connection.url" value="jdbc:h2:mem:test;DB_CLOSE_DELAY=-1" />

            <property name="hibernate.hbm2ddl.auto" value="update" />
            <property name="org.hibernate.FlushMode" value="commit" />
            <property name="hibernate.current_session_context_class" value="thread" />
            <property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider" />
            <property name="hibernate.show_sql" value="true" />
        </properties>
    </persistence-unit>
</persistence>

我尝试使用以下代码访问它:

    BundleContext context = FrameworkUtil.getBundle(getClass()).getBundleContext();
    ServiceReference serviceReference = context.getServiceReference(PersistenceProvider.class.getName());
    PersistenceProvider persistenceProvider = (PersistenceProvider) context.getService(serviceReference);
    EntityManagerFactory emf = persistenceProvider.createEntityManagerFactory("DemoUnit", null);

之后,EntityManagerFactory为空。没有例外,没有记录,没有任何记录。

我所知道的:

  • 插件读取 persistence.xml ,如果格式不正确则会失败
  • 插件可以访问org.h2.Driver,因为我可以导入它
  • 某些消息来源表示使用Log4J和Logger.getLogger("org").setLevel(Level.ALL)之类的东西来获取异常;对我来说,如果我添加行
  • ,则没有任何变化

有人可以帮我找到问题的根源吗?

2 个答案:

答案 0 :(得分:0)

PersistenceProvider与持久性类和persistence.xml位于不同的包中。所以它看不到这些。

将ContextClassLoader设置为捆绑包的类加载器可能会有所帮助。

使用hibernate的更好方法是在中间使用Aries JPA。它以OSGi安全方式为您创建EntityManagerFactory,并将EMF作为OSGi服务提供。

请参阅Aries JPA examples

还支持使用pax-jdbc-config从配置创建DataSource作为服务。

答案 1 :(得分:0)

答案很简单:提供者是错的(或过时的?)。如果Hibernate打印日志会更容易找到:

<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>