All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.persistence.jpa.impl.Stats Maven / Gradle / Ivy

package org.infinispan.persistence.jpa.impl;

import java.util.concurrent.atomic.LongAdder;

/**
 * @author Radim Vansa <[email protected]>
 */
public class Stats {

   private class Operation {
      final LongAdder count = new LongAdder();
      final LongAdder sum = new LongAdder();

      void add(long duration) {
         count.increment();
         sum.add(duration);
      }

      @Override
      public String toString() {
         long count = this.count.sum();
         long sum = this.sum.sum();
         return String.format("[count=%d, avg=%.2f ms]", count, count == 0 ? Double.NaN : sum / (1000000.0 * count));
      }
   }

   private final Operation entityFind = new Operation();
   private final Operation entityMerge = new Operation();
   private final Operation entityRemove = new Operation();
   private final Operation metadataFind = new Operation();
   private final Operation metadataMerge = new Operation();
   private final Operation metadataRemove = new Operation();
   private final Operation txReadCommitted = new Operation();
   private final Operation txWriteCommitted = new Operation();
   private final Operation txRemoveCommitted = new Operation();
   private final Operation txReadFailed = new Operation();
   private final Operation txWriteFailed = new Operation();
   private final Operation txRemoveFailed = new Operation();


   public void addEntityMerge(long duration) {
      entityMerge.add(duration);
   }

   public void addMetadataMerge(long duration) {
      metadataMerge.add(duration);
   }

   public void addWriteTxCommited(long duration) {
      txWriteCommitted.add(duration);
   }

   public void addWriteTxFailed(long duration) {
      txWriteFailed.add(duration);
   }

   public void addEntityFind(long duration) {
      entityFind.add(duration);
   }

   public void addMetadataFind(long duration) {
      metadataFind.add(duration);
   }

   public void addReadTxCommitted(long duration) {
      txReadCommitted.add(duration);
   }

   public void addReadTxFailed(long duration) {
      txReadFailed.add(duration);
   }

   public void addEntityRemove(long duration) {
      entityRemove.add(duration);
   }

   public void addMetadataRemove(long duration) {
      metadataRemove.add(duration);
   }

   public void addRemoveTxCommitted(long duration) {
      txRemoveCommitted.add(duration);
   }

   public void addRemoveTxFailed(long duration) {
      txRemoveFailed.add(duration);
   }

   @Override
   public String toString() {
      return "Stats{" +
            "\nentityFind=" + entityFind +
            "\nentityMerge=" + entityMerge +
            "\nentityRemove=" + entityRemove +
            "\nmetadataFind=" + metadataFind +
            "\nmetadataMerge=" + metadataMerge +
            "\nmetadataRemove=" + metadataRemove +
            "\ntxReadCommitted=" + txReadCommitted +
            "\ntxReadFailed=" + txReadFailed +
            "\ntxWriteCommitted=" + txWriteCommitted +
            "\ntxWriteFailed=" + txWriteFailed +
            "\ntxRemoveCommitted=" + txRemoveCommitted +
            "\ntxRemoveFailed=" + txRemoveFailed +
            '}';
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy