/* * Licensed to Elasticsearch under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch licenses this file to you under * the Apache License, Version 2.0 (the "License"); you may * not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ package org.elasticsearch.index.cache.request; import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamOutput; import org.elasticsearch.common.io.stream.Streamable; import org.elasticsearch.common.unit.ByteSizeValue; import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.XContentBuilder; import java.io.IOException; public class RequestCacheStats implements Streamable, ToXContent { long memorySize; long evictions; long hitCount; long missCount; public RequestCacheStats() { } public RequestCacheStats(long memorySize, long evictions, long hitCount, long missCount) { this.memorySize = memorySize; this.evictions = evictions; this.hitCount = hitCount; this.missCount = missCount; } public void add(RequestCacheStats stats) { this.memorySize += stats.memorySize; this.evictions += stats.evictions; this.hitCount += stats.hitCount; this.missCount += stats.missCount; } public long getMemorySizeInBytes() { return this.memorySize; } public ByteSizeValue getMemorySize() { return new ByteSizeValue(memorySize); } public long getEvictions() { return this.evictions; } public long getHitCount() { return this.hitCount; } public long getMissCount() { return this.missCount; } @Override public void readFrom(StreamInput in) throws IOException { memorySize = in.readVLong(); evictions = in.readVLong(); hitCount = in.readVLong(); missCount = in.readVLong(); } @Override public void writeTo(StreamOutput out) throws IOException { out.writeVLong(memorySize); out.writeVLong(evictions); out.writeVLong(hitCount); out.writeVLong(missCount); } @Override public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException { builder.startObject(Fields.REQUEST_CACHE_STATS); builder.byteSizeField(Fields.MEMORY_SIZE_IN_BYTES, Fields.MEMORY_SIZE, memorySize); builder.field(Fields.EVICTIONS, getEvictions()); builder.field(Fields.HIT_COUNT, getHitCount()); builder.field(Fields.MISS_COUNT, getMissCount()); builder.endObject(); return builder; } static final class Fields { static final String REQUEST_CACHE_STATS = "request_cache"; static final String MEMORY_SIZE = "memory_size"; static final String MEMORY_SIZE_IN_BYTES = "memory_size_in_bytes"; static final String EVICTIONS = "evictions"; static final String HIT_COUNT = "hit_count"; static final String MISS_COUNT = "miss_count"; } }