Skip to content

heathcliff26/minecraft-exporter

Repository files navigation

CI Coverage Status Editorconfig Check Generate go test cover report Renovate

minecraft-exporter

This is a prometheus exporter for minecraft stats. It collects metrics from the save folder, as well as over RCON. This includes advancements, player stats, Tick stats and dynmap stats. The exporter is implemented purely in golang for a small image and memory footprint.

Before i created this exporter, i used the one from Joshi425, which is why the dashboard looks nearly identical. However it seems the other exporter is abandoned, so i wrote my own. There is zero compatibility to the other exporter.

Table of Contents

Container Images

Image location

Container Registry Image
Github Container ghcr.io/heathcliff26/minecraft-exporter
Docker Hub docker.io/heathcliff26/minecraft-exporter

Tags

There are different flavors of the image:

Tag(s) Description
latest Last released version of the image
rolling Rolling update of the image, always build from main branch.
vX.Y.Z Released version of the image

Usage

Output of minecraft-exporter -h

Usage of minecraft-exporter:
  -config string
        Optional: Path to config file
  -env
        Used together with -config, when set will expand enviroment variables in config
  -version
        Show the version information and exit

An example configuration can be found here.

The container can be run with:

podman run -d -p 8080:8080 -v /path/to/world:/world:ro ghcr.io/heathcliff26/minecraft-exporter:latest

Metrics will be available under http://localhost:8080/metrics.

Running the container with config file:

podman run -d -p 8080:8080 -v /path/to/world:/world:ro -v /path/to/config.yaml:/config/config.yaml ghcr.io/heathcliff26/minecraft-exporter:latest -config /config/config.yaml

Metrics

The following metrics are generated from the save and will always be exported:

Metric Description
minecraft_stat_blocks_mined Blocks a player mined
minecraft_stat_blocks_picked_up Blocks a player picked up
minecraft_stat_blocks_crafted Items a player crafted
minecraft_stat_deaths How often a player died. Cause minecraft:deaths is used for total deaths
minecraft_stat_jumps How often a player has jumped
minecraft_stat_cm_traveled How many cm a player traveled
minecraft_stat_xp_total How much total XP a player earned
minecraft_stat_current_level How many levels the player currently has
minecraft_stat_food_level How fed the player currently is
minecraft_stat_health How much health the player currently has
minecraft_stat_score The score of the player
minecraft_stat_entities_killed Entities killed by player
minecraft_stat_damage_taken Damage taken by player
minecraft_stat_damage_dealt Damage dealt by player
minecraft_stat_playtime Time in minutes a player was online
minecraft_stat_advancements Number of completed advancements of a player
minecraft_stat_slept Times a player slept in a bed
minecraft_stat_used_crafting_table Times a player used a crafting table
minecraft_stat_custom Custom minecraft stat

Reduced Metrics

In order to save metrics usage, the option to reduce the metrics series that will be exposed can be enabled in the configuration.

If the option is enabled, all minecraft_stat_blocks_* metrics will only contain the total per player, instead of per block. This results in significantly less metrics, as there won't be a series per player per block.

RCON Metrics

The following metrics will be exposed when RCON is enabled:

Metric Description
minecraft_player_online Show currently online players. Value is always 1

Forge Metrics

These metrics will be exposed when the server is forge:

Metric Description
forge_tps_dim TPS of a dimension
forge_ticktime_dim Time a Tick took in a Dimension
forge_tps_overall Overall TPS
forge_ticktime_overall Overall Ticktime
forge_entity_count Type and count of active entites

Paper Metrics

These metrics will be exposed when the server is paper:

Metric Description
paper_tps_1m 1 Minute TPS
paper_tps_5m 5 Minute TPS
paper_tps_15m 15 Minute TPS

Dynmap Metrics

These metrics will be exposed when dynmap is enabled:

Metric Description
dynmap_tile_render_stat Tile Render Statistics reported by Dynmap
dynmap_chunk_loading_count Chunk Loading Statistics reported by Dynmap
dynmap_chunk_loading_duration Chunk Loading Statistics reported by Dynmap

Dashboard

There are 2 different dashboards, one for stats for the server and one for stats for players.

Minecraft - Server

The server can be imported from json.

Here is a preview:

Minecraft - Player

The server can be imported from json.

Here is a preview: