mcexport is a Prometheus prober exporter to query the publicly available information on arbitrary Minecraft servers through the official ping protocol. Unlike many other available exporters, this exporter is explicitly designed to query Minecraft servers from the outside.
The idea is similar to the official Blackbox exporter, but mcexport is specialized in probing Minecraft servers along with their publicly available Server List information. It supports the Minecraft protocol for all servers that are using Minecraft version 1.7 and above.
While there are many Minecraft-related exporters available at GitHub, there's none that use the Multi-Target Exporter Pattern and that can be used without exposing RCON. Instead of exposing the internal processes and metrics of a single Minecraft server, mcexport probes any requested Minecraft server through the publicly available data.
Additionally, mcexport was developed in Rust, enabling great performance and therefore allowing to scrape server metrics on a large scale. Combined with its well-tested reliability and hardened security, this makes large-scale analysis of the Minecraft server ecosystem possible. Therefore, mcexport can be seen as a specialization of the official Blackbox exporter that offers fast and efficient Minecraft metric probing.
The difference between mcexport and other existing solutions like sladkoff/minecraft-prometheus-exporter, cpburnz/minecraft-prometheus-exporter and dirien/minecraft-prometheus-exporter is that those specialize in aggregating detailed metrics on a single Minecraft server (either as a plugin, mod or external service) while mcexport does aggregate only public data about dynamically submitted Minecraft servers.
The only existing solution that also supports dynamic probing is Scientistguy/minecraft-prometheus-exporter, which requires RCON to be enabled. That was not an option, as we want to scrape metrics from servers that we have no control over. Therefore, mcexport is the only solution for this scenario, offering dynamic probing on public Minecraft servers without any configuration or necessary adjustments.
Since metrics are bound to a specific instant in time, mcexport needed to be lightweight, scalable and hardened to be used as a reliable exporter in aggregating data. We offer robust container images and wanted to minimize any configuration and flags as much as possible. Any configuration is only done within Prometheus, making mcexport ready for Kubernetes from the get-go through Probe.
- Scrape multiple Minecraft servers through the public Server List Ping protocol.
- Expose information about the supported versions, current and maximum player count, latency and player samples.
- Configure the targets and scrape intervals directly within Prometheus.
- Start with zero configuration, no external resources or dependencies for mcexport.
- Use it without applying any changes to the queried Minecraft servers.
To select a specific protocol version to ping a target, you can use the module
field of the Probe Spec
and set it to the required protocol version number. Any number (negative and positive) is supported and
will be sent as the desired protocol version to the target. mcexport supports the latest iteration of the
Server List Ping protocol that all servers since Minecraft 1.7 use.
If no module is specified explicitly, the most recent version at the time of the last release is used instead (if not
explicitly configured). Therefore, this may not be the latest version at any time, but at least a somewhat recent
version. You can override the version with the module
field until a new release is created.
Ideally, we could use (and fall back to) -1
as the protocol version, as that is recommended to use, when determining
the appropriate/maximum supported version of a server. However, our practical tests revealed that only very few servers
would support this convention and would just reply with -1
on their side, meaning unsupported. And servers that
support -1
also support specifying a recent version. Therefore, the "somewhat recent" version is the best we can do by
default and without further configuration.
Warning
While mcexport is stable, please view the individual releases for any version-specific details that need to be considered while deploying. Changes are performed in adherence to Semantic Versioning.
Before any Minecraft servers can be probed, we first need to set up mcexport on the corresponding machine. This does not have to be the machine of the probed targets, but instead, it will probably be the same system that Prometheus runs on.
To run mcexport from a binary file, download the appropriate binary from our releases, make it executable and run it within the shell of your choice:
chmod +x mcexport
./mcexport
To run mcexport within Docker, we can use the images that we release within our Container Registry. Those images are hardened and provide the optimal environment to execute mcexport in a containerized environment.
docker run --rm \
-p 10026/tcp \
--name mcexport \
ghcr.io/scrayosnet/mcexport:latest
There's currently no public Helm Chart for mcexport. We're open for contributions! In the meantime, you can create your own deployment using Kustomize or any other tooling of your choice.
To verify whether everything works as expected, we can invoke the following command on the same machine and observe the reported result:
curl --request GET -sL --url 'http://localhost:10026/probe?target=mc.justchunks.net'
If the result shows any metrics, mcexport is now setup successfully and can be used to probe Minecraft servers.
Now that mcexport is working as expected, we need to configure Prometheus to probe any Minecraft server targets. Depending on the individual setup, this can be done in one of those ways:
In a normal (non-Kubernetes) deployment of Prometheus, we can probe any Minecraft server with a scrape configuration like this:
scrape_configs:
- job_name: "mcexport"
scrape_interval: 60s
scrape_timeout: 30s
static_configs:
- targets:
- 'mc.justchunks.net'
- 'example.com'
Assuming, there's a namespace mcexport
with a deployment of mcexport, and a corresponding service mcexport
is in
that namespace, that exposes the mcexport instances internally, we can probe metrics with this CRD configuration
using the Probe resource:
apiVersion: monitoring.coreos.com/v1
kind: Probe
metadata:
name: mcexport
namespace: mcexport
spec:
prober:
url: 'mcexport.mcexport.cluster.local:10026'
interval: 60s
scrapeTimeout: 30s
targets:
staticConfig:
static:
- 'mc.justchunks.net'
- 'example.com'
Depending on your setup, you may also need to add a label, so that the configuration is picked up by your Prometheus
instance. If you've installed it through the kube-prometheus-stack
helm chart, it could, for example, be
release: kube-prometheus-stack
. You can check the required labels in your Prometheus CRD.
To modify the behavior and global values of mcexport, CLI flags and environment variables may be used. To get an overview of the available settings and their respective keys, run the following command:
mcexport --help
All settings have sensible defaults that are suitable for production deployments of mcexport. Still, tweaking those settings can be beneficial for debugging or specific runtime models.
To report a security issue for this project, please note our Security Policy.
Participation in this project comes under the Contributor Covenant Code of Conduct.
Thanks for considering contributing to this project! In order to submit a Pull Request, please read our contributing guide. This project is in active development, and we're always happy to receive new contributions!
This project is developed and distributed under the MIT License. See this explanation for a rundown on what that means.