исключение lazyinitalization с wildfly 14: не удалось инициализировать прокси - сеанс владельца был закрыт - PullRequest
0 голосов
/ 16 ноября 2018

Если я запускаю свой код на сервере wildfly 14, я получаю следующее исключение.Тот же код работал с wildfly 13. В чем может быть проблема?

Caused by: org.hibernate.LazyInitializationException: could not initialize proxy [ch.example.tool.entity.Benutzer#12] - the owning Session was closed
    at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:172)
    at org.hibernate.proxy.AbstractLazyInitializer.getIdentifier(AbstractLazyInitializer.java:89)
    at org.hibernate.internal.SessionImpl.getProxyIdentifier(SessionImpl.java:1752)
    at org.hibernate.internal.SessionImpl.getContextEntityIdentifier(SessionImpl.java:1743)
    at org.hibernate.engine.internal.ForeignKeys.getEntityIdentifierIfNotUnsaved(ForeignKeys.java:271)
    at org.hibernate.type.EntityType.getIdentifier(EntityType.java:495)
    at org.hibernate.type.EntityType.nullSafeSet(EntityType.java:280)
    at org.hibernate.persister.entity.AbstractEntityPersister.dehydrate(AbstractEntityPersister.java:2868)
    at org.hibernate.persister.entity.AbstractEntityPersister.update(AbstractEntityPersister.java:3307)
    at org.hibernate.persister.entity.AbstractEntityPersister.updateOrInsert(AbstractEntityPersister.java:3229)
    at org.hibernate.persister.entity.AbstractEntityPersister.update(AbstractEntityPersister.java:3630)
    at org.hibernate.action.internal.EntityUpdateAction.execute(EntityUpdateAction.java:146)
    at org.hibernate.engine.spi.ActionQueue.executeActions(ActionQueue.java:604)
    at org.hibernate.engine.spi.ActionQueue.executeActions(ActionQueue.java:478)
    at org.hibernate.event.internal.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:356)
    at org.hibernate.event.internal.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:39)
    at org.hibernate.internal.SessionImpl.doFlush(SessionImpl.java:1454)
    ... 122 more

Ответы [ 3 ]

0 голосов
/ 02 января 2019

Я также выбрал обходной путь, все сущности @ManyToOne были аннотированы @NotAudited, поэтому Envers не пытается загрузить их после закрытия entityManager.Пока работает, похоже, ошибка Hibernate.

0 голосов
/ 30 мая 2019

Начиная с этой статьи , установка hibernate.jpa.compliance.proxy=false в вашей конфигурации может быть решением (так как Wildfly может устанавливать это значение в true).

0 голосов
/ 20 ноября 2018

Я должен явно загрузить ленивую ссылку на прокси для операции слияния в Wildfly 14. Вот так это работает.

Wildfly 13 и раньше:

@Transactional
public class VergleichDAOImpl implements VergleichDAO {

    @PersistenceContext
    private EntityManager em;


    @Override
    public void save(Vergleich vergleich) {     

        if(vergleich.getId() == null) {
            em.persist(vergleich);
        } else {
            em.merge(vergleich);
        }
    }

Wildfly 14

@Transactional
public class VergleichDAOImpl implements VergleichDAO {

    @PersistenceContext
    private EntityManager em;


    @Override
    public void save(Vergleich vergleich) {     

        if(vergleich.getId() == null) {
            em.persist(vergleich);
        } else {
            Benutzer benutzer  = em.find(Benutzer.class, vergleich.getBenutzer().getId());
            vergleich.setBenutzer(benutzer);
            em.merge(vergleich);
        }
    }
...