1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

JPA + Transaction not active

Galera,

Estou com uma aplicação web que roda no Glassfish.

Com o sistema aberto e alguns minutos sem realizar nenhuma operação, quando o usuário retoma a operação do sistema no log de erro esta dando a seguinte mensagem:

java.lang.IllegalStateException: Transaction not active

O que devo fazer? Devo criar um JDBC no Glassfish para gerenciar as minhas conexões?

Abaixo os meus códigos:

persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" 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_1_0.xsd">
  <persistence-unit name="renovaPU" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <non-jta-data-source/>

    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
      <property name="hibernate.connection.username" value="root"/>
      <property name="hibernate.connection.password" value="123456"/>
      <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
      <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/renove?zeroDateTimeBehavior=convertToNull"/>
      <property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider"/>
      <property name="hibernate.connection.provider_class" value="org.hibernate.connection.C3P0ConnectionProvider"/>
      <property name="hibernate.c3p0.max_size" value="100"/>
      <property name="hibernate.c3p0.min_size" value="0"/>
      <property name="hibernate.c3p0.acquire_increment" value="1"/>
      <property name="hibernate.c3p0.idle_test_period" value="300"/>
      <property name="hibernate.c3p0.max_statements" value="0"/>
      <property name="hibernate.c3p0.timeout" value="100"/>
      <property name="hibernate.c3p0.maxPoolSize" value="10"/>
      <property name="hibernate.show_sql" value="false"/>
    </properties>
  </persistence-unit>
</persistence>

EntityManagerHelper.java

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;

public class EntityManagerHelper {

    private final static EntityManagerFactory emf;
    private static EntityManager manager;

    static {
        System.out.println("INICIANDO O BANCO");
        emf = Persistence.createEntityManagerFactory("renovaPU");
        manager = emf.createEntityManager();
    }

    public synchronized static EntityManager getEntityManager() throws RenoveException {
        try {
            if (!manager.isOpen()) {
                manager = emf.createEntityManager();
            }
            return manager;
        } catch (Exception e) {
            throw new RenoveException(e);
        }

    }

    public synchronized static void commit() throws RenoveException {
        try {
            getEntityManager().getTransaction().commit();
        } catch (Exception e) {
            throw new RenoveException(e);
        }

    }

    public synchronized static void rollback() throws RenoveException {
        getEntityManager().getTransaction().rollback();
    }

    public synchronized static Query createQuery(String query) throws RenoveException {
        return getEntityManager().createQuery(query);
    }
}

DaoPrincipal.java

public class DaoPrincipal<T> implements Serializable {

    private static final long serialVersionUID = 9223105081416063943L;
    private final Class objectClass;

    public DaoPrincipal(Class objectClass) {
        this.objectClass = objectClass;
    }

    public void salvar(T object) throws RenoveException {
        EntityManager em = null;
        try {
            try {
                em = EntityManagerHelper.getEntityManager();
            } catch (Exception e) {
                throw new RenoveException(e);
            }
            EntityTransaction tx = em.getTransaction();
            tx.begin();
            em.persist(object);
            tx.commit();
        } catch (Exception e) {
            if (em != null) {
                em.getTransaction().rollback();
            }
            throw new RenoveException(e);
        } finally {
            if (em != null) {
                em.close();
            }
        }
    }
}

SUGESTÂO DO METODO

  public void salvar(T object) throws RenoveException {
        EntityManager em = null;
        EntityTransaction tx = null;
        try {
            em = EntityManagerHelper.getEntityManager();
            tx = em.getTransaction();
            tx.begin();
            em.persist(object);
            tx.commit();
        } catch (Exception e) {
            if(tx != null){
                if(tx.isActive()){
                    tx.rollback();
                }
            }
            throw new RenoveException(e);
        } finally {
            if (em != null) {
                em.close();
            }
        }
    }
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

2 respostas

Não é a resposta que estava procurando? Procure outras perguntas com as tags jpa hibernate jsf ou faça a sua própria pergunta.