telegraf/plugins/inputs/minecraft/README.md

85 lines
2.5 KiB
Markdown
Raw Normal View History

# Minecraft Input Plugin
2017-06-23 23:54:12 +00:00
The `minecraft` plugin connects to a Minecraft server using the RCON protocol
to collects scores from the server [scoreboard][].
2017-06-23 23:54:12 +00:00
This plugin is known to support Minecraft Java Edition versions 1.11 - 1.14.
When using an version of Minecraft earlier than 1.13, be aware that the values
for some criterion has changed and may need to be modified.
2017-06-23 23:54:12 +00:00
#### Server Setup
Enable [RCON][] on the Minecraft server, add this to your server configuration
in the [server.properties][] file:
```conf
2017-06-23 23:54:12 +00:00
enable-rcon=true
rcon.password=<your password>
rcon.port=<1-65535>
```
Scoreboard [Objectives][] must be added using the server console for the
plugin to collect. These can be added in game by players with op status,
from the server console, or over an RCON connection.
2017-06-23 23:54:12 +00:00
When getting started pick an easy to test objective. This command will add an
objective that counts the number of times a player has jumped:
```
/scoreboard objectives add jumps minecraft.custom:minecraft.jump
```
2017-06-23 23:54:12 +00:00
Once a player has triggered the event they will be added to the scoreboard,
you can then list all players with recorded scores:
2017-06-23 23:54:12 +00:00
```
/scoreboard players list
2017-06-23 23:54:12 +00:00
```
View the current scores with a command, substituting your player name:
```
/scoreboard players list Etho
```
2017-06-23 23:54:12 +00:00
### Configuration
2017-06-23 23:54:12 +00:00
```toml
[[inputs.minecraft]]
## Address of the Minecraft server.
# server = "localhost"
2017-06-23 23:54:12 +00:00
## Server RCON Port.
# port = "25575"
2017-06-23 23:54:12 +00:00
## Server RCON Password.
password = ""
```
2017-06-23 23:54:12 +00:00
### Metrics
2017-06-23 23:54:12 +00:00
- minecraft
- tags:
- player
- port (port of the server)
- server (hostname:port, deprecated in 1.11; use `source` and `port` tags)
- source (hostname of the server)
- fields:
- `<objective_name>` (integer, count)
2017-06-23 23:54:12 +00:00
### Sample Queries:
Get the number of jumps per player in the last hour:
```
SELECT SPREAD("jumps") FROM "minecraft" WHERE time > now() - 1h GROUP BY "player"
2017-06-23 23:54:12 +00:00
```
### Example Output:
```
minecraft,player=notch,source=127.0.0.1,port=25575 jumps=178i 1498261397000000000
minecraft,player=dinnerbone,source=127.0.0.1,port=25575 deaths=1i,jumps=1999i,cow_kills=1i 1498261397000000000
minecraft,player=jeb,source=127.0.0.1,port=25575 d_pickaxe=1i,damage_dealt=80i,d_sword=2i,hunger=20i,health=20i,kills=1i,level=33i,jumps=264i,armor=15i 1498261397000000000
2017-06-23 23:54:12 +00:00
```
[server.properies]: https://minecraft.gamepedia.com/Server.properties
[scoreboard]: http://minecraft.gamepedia.com/Scoreboard
[objectives]: https://minecraft.gamepedia.com/Scoreboard#Objectives
[rcon]: http://wiki.vg/RCON