CometBFT can report and serve the Prometheus metrics, which in their turn can be consumed by Prometheus collector(s).
This functionality is disabled by default.
To enable the Prometheus metrics, set instrumentation.prometheus=true
in your
config file. Metrics will be served under /metrics
on 26660 port by default.
Listen address can be changed in the config file (see
instrumentation.prometheus\_listen\_addr
).
The following metrics are available:
Name | Type | Tags | Description |
---|---|---|---|
consensus_height | Gauge | Height of the chain | |
consensus_validators | Gauge | Number of validators | |
consensus_validators_power | Gauge | Total voting power of all validators | |
consensus_validator_power | Gauge | Voting power of the node if in the validator set | |
consensus_validator_last_signed_height | Gauge | Last height the node signed a block, if the node is a validator | |
consensus_validator_missed_blocks | Gauge | Total amount of blocks missed for the node, if the node is a validator | |
consensus_missing_validators | Gauge | Number of validators who did not sign | |
consensus_missing_validators_power | Gauge | Total voting power of the missing validators | |
consensus_byzantine_validators | Gauge | Number of validators who tried to double sign | |
consensus_byzantine_validators_power | Gauge | Total voting power of the byzantine validators | |
consensus_block_interval_seconds | Histogram | Time between this and last block (Block.Header.Time) in seconds | |
consensus_rounds | Gauge | Number of rounds | |
consensus_num_txs | Gauge | Number of transactions | |
consensus_total_txs | Gauge | Total number of transactions committed | |
consensus_block_parts | Counter | peer_id | Number of blockparts transmitted by peer |
consensus_latest_block_height | Gauge | /status sync_info number | |
consensus_fast_syncing | Gauge | Either 0 (not fast syncing) or 1 (syncing) | |
consensus_state_syncing | Gauge | Either 0 (not state syncing) or 1 (syncing) | |
consensus_block_size_bytes | Gauge | Block size in bytes | |
consensus_step_duration | Histogram | step | Histogram of durations for each step in the consensus protocol |
consensus_block_gossip_parts_received | Counter | matches_current | Number of block parts received by the node |
p2p_message_send_bytes_total | Counter | message_type | Number of bytes sent to all peers per message type |
p2p_message_receive_bytes_total | Counter | message_type | Number of bytes received from all peers per message type |
p2p_peers | Gauge | Number of peers node’s connected to | |
p2p_peer_receive_bytes_total | Counter | peer_id, chID | Number of bytes per channel received from a given peer |
p2p_peer_send_bytes_total | Counter | peer_id, chID | Number of bytes per channel sent to a given peer |
p2p_peer_pending_send_bytes | Gauge | peer_id | Number of pending bytes to be sent to a given peer |
p2p_num_txs | Gauge | peer_id | Number of transactions submitted by each peer_id |
p2p_pending_send_bytes | Gauge | peer_id | Amount of data pending to be sent to peer |
mempool_size | Gauge | Number of uncommitted transactions | |
mempool_tx_size_bytes | Histogram | Transaction sizes in bytes | |
mempool_failed_txs | Counter | Number of failed transactions | |
mempool_recheck_times | Counter | Number of transactions rechecked in the mempool | |
state_block_processing_time | Histogram | Time between BeginBlock and EndBlock in ms |
Percentage of missing + byzantine validators:
((consensus\_byzantine\_validators\_power + consensus\_missing\_validators\_power) / consensus\_validators\_power) * 100