Galera, boa noite...
Eu estava acostumado a usar o toplink no Glassfish, porém recentemente precisando fazer um sistema menor, e estou usando tomcat + hibernate.
Quando usava o toplink + glassfish, o gerênciador de persistência fazia o load das named queries e demais configurações uma vez apenas, já no tomcat + hibernate, aparentemente isso está acontecendo a todo momento que envio uma instrução e com isso a performance está péssima...
Olha o exemplo, no código abaixo, cliquei duas vezes em um botão que envia um insert pro banco.
Cadastrando...
11/08/2010 21:20:46 org.hibernate.cfg.AnnotationBinder bindClass
INFO: Binding entity from annotated class: com.innova.entity.Executives
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findAll => SELECT e FROM Executives e
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByIdexecutives => SELECT e FROM Executives e WHERE e.idexecutives = :idexecutives
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByName => SELECT e FROM Executives e WHERE e.name = :name
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByTitle => SELECT e FROM Executives e WHERE e.title = :title
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByDegree => SELECT e FROM Executives e WHERE e.degree = :degree
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByInterest => SELECT e FROM Executives e WHERE e.interest = :interest
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByLastdegree => SELECT e FROM Executives e WHERE e.lastdegree = :lastdegree
11/08/2010 21:20:46 org.hibernate.cfg.annotations.QueryBinder bindQuery
MEIO <suprimi aqui>
INFO: Named query checking : enabled
11/08/2010 21:20:51 org.hibernate.impl.SessionFactoryImpl <init>
INFO: building session factory
11/08/2010 21:20:51 org.hibernate.impl.SessionFactoryObjectFactory addInstance
INFO: Not binding factory to JNDI, no JNDI name configured
Cadastrando...
11/08/2010 21:20:58 org.hibernate.cfg.AnnotationBinder bindClass
INFO: Binding entity from annotated class: com.innova.entity.Executives
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findAll => SELECT e FROM Executives e
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByIdexecutives => SELECT e FROM Executives e WHERE e.idexecutives = :idexecutives
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByName => SELECT e FROM Executives e WHERE e.name = :name
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByTitle => SELECT e FROM Executives e WHERE e.title = :title
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByDegree => SELECT e FROM Executives e WHERE e.degree = :degree
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByInterest => SELECT e FROM Executives e WHERE e.interest = :interest
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
INFO: Binding Named query: Executives.findByLastdegree => SELECT e FROM Executives e WHERE e.lastdegree = :lastdegree
11/08/2010 21:20:58 org.hibernate.cfg.annotations.QueryBinder bindQuery
MEIO <suprimi aqui>
INFO: Named query checking : enabled
11/08/2010 21:21:00 org.hibernate.impl.SessionFactoryImpl <init>
INFO: building session factory
11/08/2010 21:21:00 org.hibernate.impl.SessionFactoryObjectFactory addInstance
INFO: Not binding factory to JNDI, no JNDI name configured
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="innovaPU" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.innova.entity.Executives</class>
<class>com.innova.entity.Gr</class>
<class>com.innova.entity.Groups</class>
<class>com.innova.entity.Institute</class>
<class>com.innova.entity.Iproject</class>
<class>com.innova.entity.Project</class>
<class>com.innova.entity.Researcharea</class>
<class>com.innova.entity.Researcher</class>
<class>com.innova.entity.User</class>
<exclude-unlisted-classes>true</exclude-unlisted-classes>
<properties>
<property name="hibernate.connection.username" value="root"/>
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
<property name="hibernate.connection.password" value="abc123"/>
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/in"/>
<!-- <property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider"/> -->
<property name="hibernate.c3p0.max_size" value="5"/>
<property name="hibernate.c3p0.min_size" value="1"/>
<property name="hibernate.c3p0.timeout" value="5000"/>
<property name="hibernate.c3p0.max_statements" value="100"/>
<property name="hibernate.c3p0.idle_test_period" value="300"/>
<property name="hibernate.c3p0.acquire_increment" value="2"/>
</properties>
</persistence-unit>
</persistence>
Valeuuuu
Um abraço.