Transaction taking long time to execute
bingojava Nov 7, 2010 6:25 AMHi, I am using Jboss 5.1.0 GA, EJB 3.0 , MySQL 5.x
My application is running on a Linux server.
In my java program(client), multiple threads are trying to access the entity bean "LiveSubscriber" using following funtion:
//=====================================Stateless Session Bean==============================
package com.clubbeans;
import statements....
@Stateless
public class GameManagerBean implements GameManagerRemote {
@PersistenceContext (unitName="gamesproject") private EntityManager manager;
public GameManagerBean(){
}
@Override
public List<LiveSubscriber> getAllSubscribers() {
System.out.println("Inside Method");
try{
return (List<LiveSubscriber>)manager.createQuery("SELECT lb FROM LiveSubscriber lb").getResultList();
}catch(NoResultException nr){
System.out.println("getting out");
return null;
}
}// Method ENDS
}// Class ENDS
//=========================================================================================
My Problem: SOMETIMES (5 out of 100 tries, mostly when number of threads acccessing, increases) the control from this method doesnt return immediately ... it prints the statement "inside method"...but doesnt print the log statement at client side , immediately after this method call. It was printed after 4 to 5 minutes.
My guess is that since lots of threads accessing the LiveSubscriber (live_subscribers table in DB) , sometimes this thread gets locked for longer time and doesnt comeout immediately . If this happens for 1 or 2 minutes , its ok for my application , but it should come out atleast after 2 minutes , otherwise next scheduling gets screwd up.
here is information from my persistence.xml ---->
persistence-unit name="gamesproject" transaction-type="JTA"
jta-data-source---->jdbc/ser
class--->com.LiveSubscriber
property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"
property name="hibernate.hbm2ddl.auto" value="create"
I am not using any deployment descripter for session beans.
Do I need to change default isolation level for Datasource (How?) or this one perticular method should be bean managed using EntityManger.lock?
Basically can anybody tell how to prevent this transaction taking so much time?