Author: chetanm
Date: Wed Dec 23 09:12:18 2015
New Revision: 1721509

URL: http://svn.apache.org/viewvc?rev=1721509&view=rev
Log:
OAK-3823 - Expose the count maintained by various stats

Use of count posed a problem with Meters which get reset each second i.e. 
counter used is reset in TimeSeries part. For this we would need to maintain 
our own counters. Given that Meter is used in very time sensitive operation 
like reads introducing a new AtomicLong might impact performance. For now 
making bast effort by using a primitive Long. With JDK8 LongAdder would be a 
better option

Modified:
    
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/stats/SimpleStats.java
    
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/stats/SimpleStatsTest.java

Modified: 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/stats/SimpleStats.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/stats/SimpleStats.java?rev=1721509&r1=1721508&r2=1721509&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/stats/SimpleStats.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/stats/SimpleStats.java
 Wed Dec 23 09:12:18 2015
@@ -25,7 +25,22 @@ import java.util.concurrent.atomic.Atomi
 public final class SimpleStats implements TimerStats, MeterStats, 
CounterStats, HistogramStats {
     public enum Type {COUNTER, METER, TIMER, HISTOGRAM}
     private final AtomicLong statsHolder;
-    private final AtomicLong counter = new AtomicLong();
+    private long counter;
+
+    /*
+        Using 2 different variables for managing the sum in meter calls
+        1. Primitive variant is used for just increment
+        2. AtomicLong variant is used for increment by 'n'
+
+        This is done to ensure that more frequent mark() is fast (used for 
Session reads)
+        and overhead of AtomicLong is used only for less critical flows
+
+        Once we move to JDK 8 we can probably use LongAdder from that has 
lesser
+        impact on performance
+     */
+    private long meterSum;
+    private final AtomicLong meterSumRef = new AtomicLong();
+
     private final Type type;
 
     public SimpleStats(AtomicLong statsHolder, Type type) {
@@ -40,12 +55,15 @@ public final class SimpleStats implement
             case TIMER:
                 //For timer and histogram we need to manage explicit
                 //invocation count
-                return counter.get();
-            default :
-                //For meter and counter the statsHolder value is
-                //same as count
+                return counter;
+            case COUNTER:
                 return statsHolder.get();
+            case METER:
+                //For Meter it can happen that backing statsHolder gets
+                //reset each second. So need to manage that sum separately
+                return meterSum + meterSumRef.get();
         }
+        throw new IllegalStateException();
     }
 
     @Override
@@ -71,16 +89,18 @@ public final class SimpleStats implement
     @Override
     public void mark() {
         inc();
+        meterSum++;
     }
 
     @Override
     public void mark(long n) {
+        meterSumRef.getAndAdd(n);
         statsHolder.getAndAdd(n);
     }
 
     @Override
     public void update(long duration, TimeUnit unit) {
-        counter.incrementAndGet();
+        counter++;
         statsHolder.getAndAdd(unit.toMillis(duration));
     }
 
@@ -91,7 +111,7 @@ public final class SimpleStats implement
 
     @Override
     public void update(long value) {
-        counter.incrementAndGet();
+        counter++;
         statsHolder.getAndAdd(value);
     }
 

Modified: 
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/stats/SimpleStatsTest.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/stats/SimpleStatsTest.java?rev=1721509&r1=1721508&r2=1721509&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/stats/SimpleStatsTest.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/stats/SimpleStatsTest.java
 Wed Dec 23 09:12:18 2015
@@ -110,7 +110,26 @@ public class SimpleStatsTest {
         assertNotNull(ts.getValuePerSecond());
         assertNotNull(ts.getValuePerWeek());
         assertEquals(0, ts.getMissingValue());
+    }
+
+    @Test
+    public void meterResetAndCount() throws Exception{
+        AtomicLong counter = new AtomicLong();
+        MeterStats stats = new SimpleStats(counter, SimpleStats.Type.METER);
+
+        stats.mark();
+        assertEquals(1, stats.getCount());
+
+        stats.mark();
+        assertEquals(2, stats.getCount());
+
+        stats.mark(5);
+        assertEquals(7, stats.getCount());
+
+        counter.set(0);
+        assertEquals(7, stats.getCount());
 
     }
 
+
 }


Reply via email to