org.neo4j.kernel.impl.api.TransactionExecutionStatistic Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-kernel Show documentation
Show all versions of neo4j-kernel Show documentation
Neo4j kernel is a lightweight, embedded Java database designed to
store data structured as graphs rather than tables. For more
information, see http://neo4j.org.
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* Neo4j is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package org.neo4j.kernel.impl.api;
import org.neo4j.time.SystemNanoClock;
import static java.util.concurrent.TimeUnit.NANOSECONDS;
public class TransactionExecutionStatistic
{
public static final TransactionExecutionStatistic NOT_AVAILABLE = new TransactionExecutionStatistic();
private final Long heapAllocatedBytes;
private final Long nativeAllocatedBytes;
private final Long estimatedUsedHeapMemory;
private final Long cpuTimeMillis;
private final long waitTimeMillis;
private final long elapsedTimeMillis;
private final Long idleTimeMillis;
private final long pageFaults;
private final long pageHits;
private TransactionExecutionStatistic()
{
heapAllocatedBytes = null;
nativeAllocatedBytes = null;
estimatedUsedHeapMemory = null;
cpuTimeMillis = null;
waitTimeMillis = -1;
elapsedTimeMillis = -1;
idleTimeMillis = null;
pageFaults = 0;
pageHits = 0;
}
public TransactionExecutionStatistic( KernelTransactionImplementation tx, SystemNanoClock clock, long startTimeMillis )
{
long nowMillis = clock.millis();
long nowNanos = clock.nanos();
KernelTransactionImplementation.Statistics statistics = tx.getStatistics();
this.waitTimeMillis = NANOSECONDS.toMillis( statistics.getWaitingTimeNanos( nowNanos ) );
this.heapAllocatedBytes = nullIfNegative( statistics.heapAllocatedBytes() );
this.nativeAllocatedBytes = nullIfNegative( statistics.usedNativeMemory() );
this.estimatedUsedHeapMemory = nullIfNegative( statistics.estimatedHeapMemory() );
this.cpuTimeMillis = nullIfNegative( statistics.cpuTimeMillis() );
this.pageFaults = statistics.totalTransactionPageCacheFaults();
this.pageHits = statistics.totalTransactionPageCacheHits();
this.elapsedTimeMillis = nowMillis - startTimeMillis;
this.idleTimeMillis = this.cpuTimeMillis != null ? elapsedTimeMillis - this.cpuTimeMillis - waitTimeMillis : null;
}
public Long getEstimatedUsedHeapMemory()
{
return estimatedUsedHeapMemory;
}
public Long getHeapAllocatedBytes()
{
return heapAllocatedBytes;
}
public Long getNativeAllocatedBytes()
{
return nativeAllocatedBytes;
}
public Long getCpuTimeMillis()
{
return cpuTimeMillis;
}
public long getWaitTimeMillis()
{
return waitTimeMillis;
}
public long getElapsedTimeMillis()
{
return elapsedTimeMillis;
}
public Long getIdleTimeMillis()
{
return idleTimeMillis;
}
public long getPageHits()
{
return pageHits;
}
public long getPageFaults()
{
return pageFaults;
}
private static Long nullIfNegative( long value )
{
return value >= 0 ? value : null;
}
}