From 2ae97946dd7cfe3c2df22aa1b7904bcea3541e10 Mon Sep 17 00:00:00 2001 From: Norman Maurer Date: Wed, 6 Apr 2016 15:12:37 +0200 Subject: [PATCH] Allow to retrieve the number of active bytes per PoolArena. Motivation: To better understand how much memory is used by Netty for ByteBufs it is useful to understand how many bytes are currently active (allocated) per PoolArena. Modifications: - Add PoolArenaMetric.numActiveBytes() Result: The user is able to get better insight into the PooledByteBufAllocator. --- .../main/java/io/netty/buffer/PoolArena.java | 20 ++++++++++++++++++- .../java/io/netty/buffer/PoolArenaMetric.java | 5 +++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/buffer/src/main/java/io/netty/buffer/PoolArena.java b/buffer/src/main/java/io/netty/buffer/PoolArena.java index 84a2557c0e..5cb06249a1 100644 --- a/buffer/src/main/java/io/netty/buffer/PoolArena.java +++ b/buffer/src/main/java/io/netty/buffer/PoolArena.java @@ -65,6 +65,7 @@ abstract class PoolArena implements PoolArenaMetric { private final LongCounter allocationsTiny = PlatformDependent.newLongCounter(); private final LongCounter allocationsSmall = PlatformDependent.newLongCounter(); private final LongCounter allocationsHuge = PlatformDependent.newLongCounter(); + private final LongCounter activeBytesHuge = PlatformDependent.newLongCounter(); private long deallocationsTiny; private long deallocationsSmall; @@ -242,13 +243,17 @@ abstract class PoolArena implements PoolArenaMetric { } private void allocateHuge(PooledByteBuf buf, int reqCapacity) { - buf.initUnpooled(newUnpooledChunk(reqCapacity), reqCapacity); + PoolChunk chunk = newUnpooledChunk(reqCapacity); + activeBytesHuge.add(chunk.chunkSize()); + buf.initUnpooled(chunk, reqCapacity); allocationsHuge.increment(); } void free(PoolChunk chunk, long handle, int normCapacity, PoolThreadCache cache) { if (chunk.unpooled) { + int size = chunk.chunkSize(); destroyChunk(chunk); + activeBytesHuge.add(-size); deallocationsHuge.decrement(); } else { SizeClass sizeClass = sizeClass(normCapacity); @@ -535,6 +540,19 @@ abstract class PoolArena implements PoolArenaMetric { return max(numHugeAllocations() - numHugeDeallocations(), 0); } + @Override + public long numActiveBytes() { + long val = activeBytesHuge.value(); + synchronized (this) { + for (int i = 0; i < chunkListMetrics.size(); i++) { + for (PoolChunkMetric m: chunkListMetrics.get(i)) { + val += m.chunkSize(); + } + } + } + return max(0, val); + } + protected abstract PoolChunk newChunk(int pageSize, int maxOrder, int pageShifts, int chunkSize); protected abstract PoolChunk newUnpooledChunk(int capacity); protected abstract PooledByteBuf newByteBuf(int maxCapacity); diff --git a/buffer/src/main/java/io/netty/buffer/PoolArenaMetric.java b/buffer/src/main/java/io/netty/buffer/PoolArenaMetric.java index 3cbe25edbb..d3281f3bee 100644 --- a/buffer/src/main/java/io/netty/buffer/PoolArenaMetric.java +++ b/buffer/src/main/java/io/netty/buffer/PoolArenaMetric.java @@ -132,4 +132,9 @@ public interface PoolArenaMetric { * Return the number of currently active huge allocations. */ long numActiveHugeAllocations(); + + /** + * Return the number of active bytes that are currently allocated by the arena. + */ + long numActiveBytes(); }