blob: e22addd354f26237e1011758777f8a0808fee4e4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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.apache.hadoop.ozone.container.common.volume;
import org.apache.hadoop.metrics2.MetricsSystem;
import org.apache.hadoop.metrics2.annotation.Metric;
import org.apache.hadoop.metrics2.lib.DefaultMetricsSystem;
import org.apache.hadoop.metrics2.lib.MutableCounterLong;
/**
* This class is used to track Volume IO stats for each HDDS Volume.
*/
public class VolumeIOStats {
private String metricsSourceName = VolumeIOStats.class.getSimpleName();
private String storageDirectory;
private @Metric MutableCounterLong readBytes;
private @Metric MutableCounterLong readOpCount;
private @Metric MutableCounterLong writeBytes;
private @Metric MutableCounterLong writeOpCount;
private @Metric MutableCounterLong readTime;
private @Metric MutableCounterLong writeTime;
@Deprecated
public VolumeIOStats() {
init();
}
/**
* @param identifier Typically, path to volume root. e.g. /data/hdds
*/
public VolumeIOStats(String identifier, String storageDirectory) {
this.metricsSourceName += '-' + identifier;
this.storageDirectory = storageDirectory;
init();
}
public void init() {
MetricsSystem ms = DefaultMetricsSystem.instance();
ms.register(metricsSourceName, "Volume I/O Statistics", this);
}
public void unregister() {
MetricsSystem ms = DefaultMetricsSystem.instance();
ms.unregisterSource(metricsSourceName);
}
public String getMetricsSourceName() {
return metricsSourceName;
}
/**
* Increment number of bytes read from the volume.
* @param bytesRead
*/
public void incReadBytes(long bytesRead) {
readBytes.incr(bytesRead);
}
/**
* Increment the read operations performed on the volume.
*/
public void incReadOpCount() {
readOpCount.incr();
}
/**
* Increment number of bytes written on to the volume.
* @param bytesWritten
*/
public void incWriteBytes(long bytesWritten) {
writeBytes.incr(bytesWritten);
}
/**
* Increment the write operations performed on the volume.
*/
public void incWriteOpCount() {
writeOpCount.incr();
}
/**
* Increment the time taken by read operation on the volume.
* @param time
*/
public void incReadTime(long time) {
readTime.incr(time);
}
/**
* Increment the time taken by write operation on the volume.
* @param time
*/
public void incWriteTime(long time) {
writeTime.incr(time);
}
/**
* Returns total number of bytes read from the volume.
* @return long
*/
public long getReadBytes() {
return readBytes.value();
}
/**
* Returns total number of bytes written to the volume.
* @return long
*/
public long getWriteBytes() {
return writeBytes.value();
}
/**
* Returns total number of read operations performed on the volume.
* @return long
*/
public long getReadOpCount() {
return readOpCount.value();
}
/**
* Returns total number of write operations performed on the volume.
* @return long
*/
public long getWriteOpCount() {
return writeOpCount.value();
}
/**
* Returns total read operations time on the volume.
* @return long
*/
public long getReadTime() {
return readTime.value();
}
/**
* Returns total write operations time on the volume.
* @return long
*/
public long getWriteTime() {
return writeTime.value();
}
@Metric
public String getStorageDirectory() {
return storageDirectory;
}
}