| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright 2023 Red Hat
- */
- #ifndef STATISTICS_H
- #define STATISTICS_H
- #include "types.h"
- enum {
- STATISTICS_VERSION = 36,
- };
- struct block_allocator_statistics {
- /* The total number of slabs from which blocks may be allocated */
- u64 slab_count;
- /* The total number of slabs from which blocks have ever been allocated */
- u64 slabs_opened;
- /* The number of times since loading that a slab has been re-opened */
- u64 slabs_reopened;
- };
- /**
- * Counters for tracking the number of items written (blocks, requests, etc.)
- * that keep track of totals at steps in the write pipeline. Three counters
- * allow the number of buffered, in-memory items and the number of in-flight,
- * unacknowledged writes to be derived, while still tracking totals for
- * reporting purposes
- */
- struct commit_statistics {
- /* The total number of items on which processing has started */
- u64 started;
- /* The total number of items for which a write operation has been issued */
- u64 written;
- /* The total number of items for which a write operation has completed */
- u64 committed;
- };
- /** Counters for events in the recovery journal */
- struct recovery_journal_statistics {
- /* Number of times the on-disk journal was full */
- u64 disk_full;
- /* Number of times the recovery journal requested slab journal commits. */
- u64 slab_journal_commits_requested;
- /* Write/Commit totals for individual journal entries */
- struct commit_statistics entries;
- /* Write/Commit totals for journal blocks */
- struct commit_statistics blocks;
- };
- /** The statistics for the compressed block packer. */
- struct packer_statistics {
- /* Number of compressed data items written since startup */
- u64 compressed_fragments_written;
- /* Number of blocks containing compressed items written since startup */
- u64 compressed_blocks_written;
- /* Number of VIOs that are pending in the packer */
- u64 compressed_fragments_in_packer;
- };
- /** The statistics for the slab journals. */
- struct slab_journal_statistics {
- /* Number of times the on-disk journal was full */
- u64 disk_full_count;
- /* Number of times an entry was added over the flush threshold */
- u64 flush_count;
- /* Number of times an entry was added over the block threshold */
- u64 blocked_count;
- /* Number of times a tail block was written */
- u64 blocks_written;
- /* Number of times we had to wait for the tail to write */
- u64 tail_busy_count;
- };
- /** The statistics for the slab summary. */
- struct slab_summary_statistics {
- /* Number of blocks written */
- u64 blocks_written;
- };
- /** The statistics for the reference counts. */
- struct ref_counts_statistics {
- /* Number of reference blocks written */
- u64 blocks_written;
- };
- /** The statistics for the block map. */
- struct block_map_statistics {
- /* number of dirty (resident) pages */
- u32 dirty_pages;
- /* number of clean (resident) pages */
- u32 clean_pages;
- /* number of free pages */
- u32 free_pages;
- /* number of pages in failed state */
- u32 failed_pages;
- /* number of pages incoming */
- u32 incoming_pages;
- /* number of pages outgoing */
- u32 outgoing_pages;
- /* how many times free page not avail */
- u32 cache_pressure;
- /* number of get_vdo_page() calls for read */
- u64 read_count;
- /* number of get_vdo_page() calls for write */
- u64 write_count;
- /* number of times pages failed to read */
- u64 failed_reads;
- /* number of times pages failed to write */
- u64 failed_writes;
- /* number of gets that are reclaimed */
- u64 reclaimed;
- /* number of gets for outgoing pages */
- u64 read_outgoing;
- /* number of gets that were already there */
- u64 found_in_cache;
- /* number of gets requiring discard */
- u64 discard_required;
- /* number of gets enqueued for their page */
- u64 wait_for_page;
- /* number of gets that have to fetch */
- u64 fetch_required;
- /* number of page fetches */
- u64 pages_loaded;
- /* number of page saves */
- u64 pages_saved;
- /* the number of flushes issued */
- u64 flush_count;
- };
- /** The dedupe statistics from hash locks */
- struct hash_lock_statistics {
- /* Number of times the UDS advice proved correct */
- u64 dedupe_advice_valid;
- /* Number of times the UDS advice proved incorrect */
- u64 dedupe_advice_stale;
- /* Number of writes with the same data as another in-flight write */
- u64 concurrent_data_matches;
- /* Number of writes whose hash collided with an in-flight write */
- u64 concurrent_hash_collisions;
- /* Current number of dedupe queries that are in flight */
- u32 curr_dedupe_queries;
- };
- /** Counts of error conditions in VDO. */
- struct error_statistics {
- /* number of times VDO got an invalid dedupe advice PBN from UDS */
- u64 invalid_advice_pbn_count;
- /* number of times a VIO completed with a VDO_NO_SPACE error */
- u64 no_space_error_count;
- /* number of times a VIO completed with a VDO_READ_ONLY error */
- u64 read_only_error_count;
- };
- struct bio_stats {
- /* Number of REQ_OP_READ bios */
- u64 read;
- /* Number of REQ_OP_WRITE bios with data */
- u64 write;
- /* Number of bios tagged with REQ_PREFLUSH and containing no data */
- u64 empty_flush;
- /* Number of REQ_OP_DISCARD bios */
- u64 discard;
- /* Number of bios tagged with REQ_PREFLUSH */
- u64 flush;
- /* Number of bios tagged with REQ_FUA */
- u64 fua;
- };
- struct memory_usage {
- /* Tracked bytes currently allocated. */
- u64 bytes_used;
- /* Maximum tracked bytes allocated. */
- u64 peak_bytes_used;
- };
- /** UDS index statistics */
- struct index_statistics {
- /* Number of records stored in the index */
- u64 entries_indexed;
- /* Number of post calls that found an existing entry */
- u64 posts_found;
- /* Number of post calls that added a new entry */
- u64 posts_not_found;
- /* Number of query calls that found an existing entry */
- u64 queries_found;
- /* Number of query calls that added a new entry */
- u64 queries_not_found;
- /* Number of update calls that found an existing entry */
- u64 updates_found;
- /* Number of update calls that added a new entry */
- u64 updates_not_found;
- /* Number of entries discarded */
- u64 entries_discarded;
- };
- /** The statistics of the vdo service. */
- struct vdo_statistics {
- u32 version;
- /* Number of blocks used for data */
- u64 data_blocks_used;
- /* Number of blocks used for VDO metadata */
- u64 overhead_blocks_used;
- /* Number of logical blocks that are currently mapped to physical blocks */
- u64 logical_blocks_used;
- /* number of physical blocks */
- block_count_t physical_blocks;
- /* number of logical blocks */
- block_count_t logical_blocks;
- /* Size of the block map page cache, in bytes */
- u64 block_map_cache_size;
- /* The physical block size */
- u64 block_size;
- /* Number of times the VDO has successfully recovered */
- u64 complete_recoveries;
- /* Number of times the VDO has recovered from read-only mode */
- u64 read_only_recoveries;
- /* String describing the operating mode of the VDO */
- char mode[15];
- /* Whether the VDO is in recovery mode */
- bool in_recovery_mode;
- /* What percentage of recovery mode work has been completed */
- u8 recovery_percentage;
- /* The statistics for the compressed block packer */
- struct packer_statistics packer;
- /* Counters for events in the block allocator */
- struct block_allocator_statistics allocator;
- /* Counters for events in the recovery journal */
- struct recovery_journal_statistics journal;
- /* The statistics for the slab journals */
- struct slab_journal_statistics slab_journal;
- /* The statistics for the slab summary */
- struct slab_summary_statistics slab_summary;
- /* The statistics for the reference counts */
- struct ref_counts_statistics ref_counts;
- /* The statistics for the block map */
- struct block_map_statistics block_map;
- /* The dedupe statistics from hash locks */
- struct hash_lock_statistics hash_lock;
- /* Counts of error conditions */
- struct error_statistics errors;
- /* The VDO instance */
- u32 instance;
- /* Current number of active VIOs */
- u32 current_vios_in_progress;
- /* Maximum number of active VIOs */
- u32 max_vios;
- /* Number of times the UDS index was too slow in responding */
- u64 dedupe_advice_timeouts;
- /* Number of flush requests submitted to the storage device */
- u64 flush_out;
- /* Logical block size */
- u64 logical_block_size;
- /* Bios submitted into VDO from above */
- struct bio_stats bios_in;
- struct bio_stats bios_in_partial;
- /* Bios submitted onward for user data */
- struct bio_stats bios_out;
- /* Bios submitted onward for metadata */
- struct bio_stats bios_meta;
- struct bio_stats bios_journal;
- struct bio_stats bios_page_cache;
- struct bio_stats bios_out_completed;
- struct bio_stats bios_meta_completed;
- struct bio_stats bios_journal_completed;
- struct bio_stats bios_page_cache_completed;
- struct bio_stats bios_acknowledged;
- struct bio_stats bios_acknowledged_partial;
- /* Current number of bios in progress */
- struct bio_stats bios_in_progress;
- /* Memory usage stats. */
- struct memory_usage memory_usage;
- /* The statistics for the UDS index */
- struct index_statistics index;
- };
- #endif /* not STATISTICS_H */
|