HHH-6258: Wrap trace and debug log statements to lessen the load on JBossLogManagerLogger.doLog. This improved throughput quite a bit.

This commit is contained in:
Andrig Miller 2011-05-25 17:40:49 -06:00 committed by Steve Ebersole
parent a917bb4b40
commit e01bb8a911
9 changed files with 60 additions and 22 deletions

View File

@ -69,7 +69,9 @@ public abstract class AbstractResultSetProxyHandler extends AbstractProxyHandler
@Override
protected Object continueInvocation(Object proxy, Method method, Object[] args) throws Throwable {
String methodName = method.getName();
if (LOG.isTraceEnabled()) {
LOG.trace("Handling invocation of ResultSet method [" + methodName + "]");
}
// other methods allowed while invalid ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
if ( "close".equals( methodName ) ) {

View File

@ -85,7 +85,9 @@ public abstract class AbstractStatementProxyHandler extends AbstractProxyHandler
@Override
protected Object continueInvocation(Object proxy, Method method, Object[] args) throws Throwable {
String methodName = method.getName();
if (LOG.isTraceEnabled()) {
LOG.trace("Handling invocation of statement method [" + methodName + "]");
}
// other methods allowed while invalid ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
if ( "close".equals( methodName ) ) {

View File

@ -183,7 +183,9 @@ public class LoadContexts {
if (collectionLoadContexts == null) collectionLoadContexts = IdentityMap.instantiate(8);
else context = (CollectionLoadContext)collectionLoadContexts.get(resultSet);
if ( context == null ) {
if (LOG.isTraceEnabled()) {
LOG.trace("Constructing collection load context for result set [" + resultSet + "]");
}
context = new CollectionLoadContext( this, resultSet );
collectionLoadContexts.put( resultSet, context );
}

View File

@ -132,7 +132,9 @@ public class TransactionCoordinatorImpl implements TransactionCoordinator {
}
public void afterTransaction(TransactionImplementor hibernateTransaction, int status) {
if (LOG.isTraceEnabled()) {
LOG.trace( "after transaction completion" );
}
final boolean success = JtaStatusHelper.isCommitted( status );
@ -217,7 +219,9 @@ public class TransactionCoordinatorImpl implements TransactionCoordinator {
if ( ! transactionContext.shouldAutoJoinTransaction() ) {
if ( currentHibernateTransaction.getJoinStatus() != JoinStatus.MARKED_FOR_JOINED ) {
if (LOG.isDebugEnabled()) {
LOG.debug( "Skipping JTA sync registration due to auto join checking" );
}
return;
}
}
@ -235,20 +239,26 @@ public class TransactionCoordinatorImpl implements TransactionCoordinator {
// Can we resister a synchronization
if ( ! jtaPlatform.canRegisterSynchronization() ) {
if (LOG.isTraceEnabled()) {
LOG.trace( "registered JTA platform says we cannot currently resister synchronization; skipping" );
}
return;
}
// Should we resister a synchronization
if ( ! transactionFactory().isJoinableJtaTransaction( this, currentHibernateTransaction ) ) {
if (LOG.isTraceEnabled()) {
LOG.trace( "TransactionFactory reported no JTA transaction to join; skipping Synchronization registration" );
}
return;
}
jtaPlatform.registerSynchronization( new RegisteredSynchronization( getSynchronizationCallbackCoordinator() ) );
synchronizationRegistered = true;
if (LOG.isDebugEnabled()) {
LOG.debug( "successfully registered Synchronization" );
}
}
@Override
public SynchronizationCallbackCoordinator getSynchronizationCallbackCoordinator() {
@ -259,7 +269,9 @@ public class TransactionCoordinatorImpl implements TransactionCoordinator {
}
public void pulse() {
if (LOG.isTraceEnabled()) {
LOG.trace( "Starting transaction coordinator pulse" );
}
if ( transactionFactory().compatibleWithJtaSynchronization() ) {
// the configured transaction strategy says it supports callbacks via JTA synchronization, so attempt to
// register JTA synchronization if possible

View File

@ -242,7 +242,9 @@ public abstract class AbstractFlushingEventListener implements Serializable {
*/
private void flushCollections(EventSource session) throws HibernateException {
if (LOG.isTraceEnabled()) {
LOG.trace("Processing unreferenced collections");
}
List list = IdentityMap.entries( session.getPersistenceContext().getCollectionEntries() );
int size = list.size();
@ -256,7 +258,9 @@ public abstract class AbstractFlushingEventListener implements Serializable {
// Schedule updates to collections:
if (LOG.isTraceEnabled()) {
LOG.trace("Scheduling collection removes/(re)creates/updates");
}
list = IdentityMap.entries( session.getPersistenceContext().getCollectionEntries() );
size = list.size();

View File

@ -854,12 +854,16 @@ public abstract class Loader {
EntityKey[] keys = new EntityKey[entitySpan]; //we can reuse it for each row
if (LOG.isTraceEnabled()) {
LOG.trace("Processing result set");
}
int count;
for ( count = 0; count < maxRows && rs.next(); count++ ) {
if (LOG.isDebugEnabled()) {
LOG.debugf("Result set row: %s", count);
}
Object result = getRowFromResultSet(
rs,
@ -881,7 +885,9 @@ public abstract class Loader {
}
if (LOG.isTraceEnabled()) {
LOG.trace("Done processing result set (" + count + " rows)");
}
}
finally {

View File

@ -74,8 +74,10 @@ public final class ServiceBinding<R extends Service> {
public void setService(R service) {
if ( this.service != null ) {
if (log.isDebugEnabled()) {
log.debug( "Overriding existing service binding [" + serviceRole.getName() + "]" );
}
}
this.service = service;
}
}

View File

@ -65,14 +65,18 @@ public abstract class BasicBinder<J> implements ValueBinder<J> {
*/
public final void bind(PreparedStatement st, J value, int index, WrapperOptions options) throws SQLException {
if ( value == null ) {
if (LOG.isTraceEnabled()) {
LOG.trace(String.format(NULL_BIND_MSG_TEMPLATE, index, JdbcTypeNameMapper.getTypeName(sqlDescriptor.getSqlType())));
}
st.setNull( index, sqlDescriptor.getSqlType() );
}
else {
if (LOG.isTraceEnabled()) {
LOG.trace(String.format(BIND_MSG_TEMPLATE,
index,
JdbcTypeNameMapper.getTypeName(sqlDescriptor.getSqlType()),
getJavaDescriptor().extractLoggableRepresentation(value)));
}
doBind( st, value, index, options );
}
}

View File

@ -62,11 +62,15 @@ public abstract class BasicExtractor<J> implements ValueExtractor<J> {
public J extract(ResultSet rs, String name, WrapperOptions options) throws SQLException {
final J value = doExtract( rs, name, options );
if ( value == null || rs.wasNull() ) {
if (LOG.isTraceEnabled()) {
LOG.trace("Found [null] as column [" + name + "]");
}
return null;
}
else {
if (LOG.isTraceEnabled()) {
LOG.trace("Found [" + getJavaDescriptor().extractLoggableRepresentation(value) + "] as column [" + name + "]");
}
return value;
}
}