[jboss-user] [EJB/JBoss] - JBoss is not beginning transaction

holmes.j do-not-reply at jboss.com
Tue Sep 19 15:20:00 EDT 2006


Hi,
I'm using JBoss 4.0.4-GA with Hibernate 3.2CR4 and EJB 2.1.  Hibernate is complaining that "load is not valid without active transaction"  This comes form the TransactionManager that is checking to see if the Transaction is active.  The transaction exists, it just has not begun.

I have a stateless session bean using CMT that looks like this ...


  | /**
  |  * @ejb.bean name="GeoFeatureServer"
  |  *           jndi-name="com.free2be.framework.gis.feature.GeoFeatureServerHome"
  |  *           type="Stateless" view-type="remote"
  |  * @ejb.transaction type="Required"
  |  */
  | public abstract class GeoFeatureServerBean implements SessionBean {
  | 	/**
  | 	 * @ejb.interface-method
  | 	 */
  | 	public GeoFeature findGeoFeature(GeoFeaturePk geoFeaturePk) throws NoSuchElementException {
  | 		GeoFeature value = (GeoFeature) cache.getByKey(geoFeaturePk);
  | 		if (value == null) {
  | 			getLogger().debug(geoFeaturePk + " not cached...loading");
  | 			value = getGeoFeatureDao().findById(geoFeaturePk, false);
  | 			cache.addToCache(value);
  | 		}
  | 		return value;
  | 	}
  | }
  | 

The DAO code looks like this ...

  | 	@SuppressWarnings("unchecked")
  | 	public V findById(long id, boolean lock) {
  | 		V entity;
  | 		try {
  | 			Session session = getSession();
  | //			Transaction tx = session.beginTransaction();
  | 			if (lock)
  | 				entity = (V) session.load(getPersistentClass(), id, LockMode.UPGRADE);
  | 			else
  | 				entity = (V) session.load(getPersistentClass(), id);
  | 		} catch (HibernateException e) {
  | 			throw new NoSuchElementException(e.getMessage());
  | 		}
  | 		
  | 		return entity;
  | 	}
  | 

If I un-comment the session.beginTransaction(), the exception won't be thrown.  However, we're using CMT, so I shouldn't have to do that.  In fact, I shouldn't be allowed to do that.  Touching the transaction should throw an exception AFAIK.

My hibernate.properties file ...
hibernate.dialect=org.hibernate.dialect.MySQLDialect
  | hibernate.connection.driver_class=com.mysql.jdbc.Driver
  | hibernate.connection.url=jdbc:mysql://integration:3306/mbgeo
  | hibernate.connection.username=xxxx
  | hibernate.connection.password=xxxx
  | 
  | #don't use hibernate's pooling!  http://www.hibernate.org/hib_docs/v3/reference/en/html/session-configuration.html
  | hibernate.c3p0.min_size=5
  | hibernate.c3p0.max_size=20
  | hibernate.c3p0.timeout=1800
  | hibernate.c3p0.max_statements=50
  | 
  | hibernate.session_factory_name=hibernate/session_factory
  | jta.UserTransaction=UserTransaction
  | 
  | #hibernate.current_session_context_class=jta #can leave unset, default is jta
  | hibernate.transaction.factory_class=org.hibernate.transaction.CMTTransactionFactory
  | hibernate.transaction.manager_lookup_class=org.hibernate.transaction.JBossTransactionManagerLookup
  | hibernate.transaction.flush_before_completion=true
  | 
  | hibernate.cache.provider_class=org.hibernate.cache.NoCacheProvider
  | hibernate.show_sql=true
  | hibernate.format_sql=true
  | hibernate.generate_statistics=true
  | 
  | hibernate.bytecode.use_reflection_optimizer=false
  | hibernate.bytecode.provider=javassist

Anybody have any ideas as to what I'm doing wrong?

-Jason

View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=3972708#3972708

Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=3972708



More information about the jboss-user mailing list