blob: 952becc4ffff28bb2e746064554197c7511ab377 [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.
#ifndef IMPALA_RUNTIME_BUFFER_POOL_COUNTERS_H
#define IMPALA_RUNTIME_BUFFER_POOL_COUNTERS_H
#include "util/runtime-profile.h"
namespace impala {
/// A set of counters for each buffer pool client.
struct BufferPoolClientCounters {
public:
/// Total amount of time spent inside BufferAllocator::AllocateBuffer().
RuntimeProfile::Counter* alloc_time;
/// Total amount of time spent inside the system allocator (subset of 'alloc_time').
RuntimeProfile::Counter* sys_alloc_time;
/// Number of buffers allocated via BufferAllocator::AllocateBuffer().
RuntimeProfile::Counter* cumulative_allocations;
/// Bytes of buffers allocated via BufferAllocator::AllocateBuffer().
RuntimeProfile::Counter* cumulative_bytes_alloced;
/// Amount of time spent waiting for reads from disk to complete.
RuntimeProfile::Counter* read_wait_time;
/// Total number of read I/O operations issued.
RuntimeProfile::Counter* read_io_ops;
/// Total bytes read from disk.
RuntimeProfile::Counter* bytes_read;
/// Amount of time spent waiting for writes to disk to complete.
RuntimeProfile::Counter* write_wait_time;
/// Total number of write I/O operations issued.
RuntimeProfile::Counter* write_io_ops;
/// Total bytes written to disk.
RuntimeProfile::Counter* bytes_written;
/// The peak total size of unpinned pages.
RuntimeProfile::HighWaterMarkCounter* peak_unpinned_bytes;
};
}
#endif