Stats - made by Lolmewn

Latest plugin release: HerePlugin issue tracker: Here
Latest plugin beta: Here
Latest Fluid MC Stats: HereWebsite issue tracker: Here

What does this plugin do?

This plugin provides you with a server-end plugin and a website-end set of files. It writes data collected through events to a MySQL database (plugin), and reads and displays that to users (website).

How do I install this?

It's really simple! Download the plugin, and drag the jar to the 'plugins' folder of your server.
Start your server, you don't have to worry about any settings file! When you join the server (You either have to be OP or have the permission-node 'stats.config'), the automatic configurator will start. This will guide you through the configuration of the plugin from in-game!
The website is also simple to install. You can check out the forum thread for detailed instructions.
And that's all! Now you can let the plugin worry about the rest ;)
Please remember to edit your server name in, as this will be sent to the global server to track your data with

Extra functionality


There now is a side-plugin which allows you to create Achievements. You can find it here:


A new plugin allowing you to track highscores with a configurable time basis. You can find it here:


Don't have a permissions plugin? Click here!

stats.track - All users who have this node will have their stats tracked and uploaded. - Allows users to place [Stats] signs.
stats.sign.destroy - Allows users to break [Stats] signs.
/stats - This command shows your stats! No permission node.
/stats <player> - This command shows someone else's stats. Permission node: stats.view.others
/stats reset - This command resets your statistics. Permission node: stats.reset.self
/stats reset <player> - This command resets <player>'s stats. Permission node: stats.reset.other

What does this plugin log?

This plugin logs all actions to a MySQL database. So, you might ask, what does it log?

Block breakAll broken blocks with their DatavaluesitemId itemData breaking
Block placeAll placed blocks with their DatavaluesitemId itemData breaking
DeathAll deaths with their causescause entity(boolean, true is safest)
KillAll kills with their causestype
MoveWalking, sailing, riding a train, on the back of a pig or by horse.type (0=walk, 1=boat, 2=train, 3=pig, 4=pig in train, 5=horse)
PlaytimeTime played in seconds
ArrowsArrows shot
Xp gainedTotal XP gained
JoinsTotal times joined
Fish catchedTotal fish Caught (Yes, I know it's caught.)
Damage takenTotal damage taken
Times kickedTotal times kicked
Tools brokenTotal Tools broken
Eggs thrownTotal eggs thrown
Items craftedTotal items crafted
OmnomnomTotal times had a snack
On fireTotal times being on fire
Words saidTotal words said
Commands doneTotal commands done
VotesTotal times voted for the server (uses Votifier)
WorldchangeTotal times worlds changed
BucketfillTotal buckets filled
BucketemptyTotal buckets emptied
BedenterTotal times bed entered
ItemdropsTotal times items dropped
ItempickupsTotal times items picked up
TeleportsTotal times teleported
ShearTotal times sheared
LastjoinThe time the player joined the server last
LastleaveThe time the player left the server last

As of Stats v1.30 (using Beta functions), you can now enable per-world support. Just set useBetaFunctions to true in the config and you're all set. If you're coming from an old version, it will set all already collected stats to the main world (world 0).


As of Stats v1.30 (using Beta functions), you can now enable snapshots. Just set useBetaFunctions to true in the config and you're all set. Explanation of the config:

KeyDefault valueDescription
enabledtrueEnables or disables the creation of Snapshots
timeToLive1WAfter a certain amount of time, old snapshots get deleted if their name is 'auto_generated snapshot'. A list of what you can use:
  • m = Minute
  • h = Hour
  • d = Day
  • W = Week
  • M = Month
  • Y = Year
interval1DThe interval at which to take a snapshot. Note that taking snapshots is done off the main thread, and shouldn't affect performance.
previousThe timestamp at which the previous snapshot was taken. Do not change this.

Disabling certain stats

You can, as of v1.26, disable stats you want in the config. You can disable any stat, just put the statname in the list. You can find all statnames up on this page.


As of 1.15, Stats now supports signs showing statistics in-game. The layout of a sign must be the following when placing it:

SignDataType can be any Stat there is. Even custom ones provided by other plugins! Check the big table above and use the Stats' name on the sign.

SignType can be either player, global or custom.
If you use player on line 3, the name of the player of which you want his stats to display must be on line 4.
Global will take the total amount of that specific stat. Custom signs will ask you to say an SQL query. If you don't know what this is, you probably shouldn't use it. If the query succeeds, you are asked to say some text that will end up on line 2 and 3 of the sign. This can be 30 characters max (15 per line).

Global Stats
Proudly sponsored by

Development builds

Development builds of this project can be acquired at the provided continuous integration server.
These builds have not been approved by the BukkitDev staff. Use them at your own risk, they may or may not work at all.
Development builds for Stats can be found at my CI, over at

MCStats plugin stats

How many servers use this plugin? How many players have the benefits of this plugin?
You can see all that here:
Statistics of the global server

Stats API and dev portal

There's a small API for the plugin where you can get some data.
Here you can see how to use it.

Plugins using Stats

Configurable messages
Info board
Does your plugin hook into Stats, but is it not in the list? Send me a PM!

IRC Support

You can find me (and possibly, when I'm around, support) in my IRC channel #Lolmewn on - See you there!


Global statistics server disclaimer

You might be wondering what the global server is tracking. Here is a list of what it logs:

  • Your server name, specified in
  • Your server port, specified in
  • All queries the plugin has sent to the local MySQL server.

What would I need your server name and port for? This is to keep track of the different servers out there. There are servers where multiple servers run on one box (same IP), with the same name, the only thing different is the port it's running on. I need it to tell the difference between both servers.


This plugin utilises Hidendra's plugin metrics system, which means that the following information is collected and sent to

  • A unique identifier
  • The server's version of Java
  • Whether the server is in offline or online mode
  • The plugin's version
  • The server's version
  • The OS version/name and architecture
  • The core count for the CPU
  • The number of players online
  • The Metrics version

If you wish to disable this feature (/me cries), you can do so by opt-ing out, which you can do in the config file under /plugins/PluginMetrics/


This plugin has a built-in auto-updater, which connects to BukkitDev to check for updates. If you, for some reason, wish to disable this process, you can do so by setting 'update' to false in the plugins' settings file.


If you feel like giving something back to me, you can donate to me. All income from donations will be spent on coffee or similar.
I'm accepting donations through:

  • Bitcoins on address 1QC19kut8nuMJNAsMZ3QneKuW2a8f5QgQG
  • Dogecoins on address DKN8Lrm4KfC7Jh9M2KopjPkwcRfA7Ak3zj
  • Paypal, either via email lolmewn(at) or via this link

You must login to post a comment. Don't have an account? Register to get one!

  • Avatar of madtomic madtomic Apr 23, 2014 at 12:21 UTC - 0 likes

    @Lolmewn: Go


  • Avatar of Lolmewn Lolmewn Apr 23, 2014 at 07:41 UTC - 0 likes

    Priorities list: Stats, Achievements, Highscores, Skillz, Sortal, rest.

  • Avatar of madtomic madtomic Apr 23, 2014 at 03:23 UTC - 0 likes

    This won't work with mcmmo as it uses both /stats and /mcstats. Is there a way to change the command for this plugin?

  • Avatar of Zachary_DuBois Zachary_DuBois Apr 23, 2014 at 00:24 UTC - 0 likes

    @maxlehot1234: Go

    Lolmewn will need to help you. Please open a ticket on the Stats issue tracker listed at the top of the description.

    --Zachary J.DuBois

    Owner and founder of AccountProductions
    My Blog

  • Avatar of maxlehot1234 maxlehot1234 Apr 22, 2014 at 21:24 UTC - 0 likes

    Please help me with my problem...

  • Avatar of Zachary_DuBois Zachary_DuBois Apr 22, 2014 at 17:00 UTC - 0 likes

    New Fluid MC Stats Released! Version v0.1.3

    Please read the update notes for this version.

  • Avatar of maxlehot1234 maxlehot1234 Apr 21, 2014 at 22:29 UTC - 0 likes

    I found bug:

    I reset all stats and after, each command player enter in the chat, i see this in the console:


    So i remove your plugin from my server... I use the 2.0.0-DEV version because the latest version not work with the web-end...

    Last edited Apr 22, 2014 by maxlehot1234
  • Avatar of monkey8113 monkey8113 Apr 21, 2014 at 16:42 UTC - 0 likes

    @Liger_XT5: Go

    Thx a lot Liger_XT5

    Its fixed only that in "MySQL-Database: Stats" part I need to use the default database created for me by the hoster instead of making "Stats" as i dont have permission to create extra database

  • Avatar of Lolmewn Lolmewn Apr 21, 2014 at 09:33 UTC - 0 likes

    @CustomForms: Go

    Guess so. Please make a ticket so I won't forget.

    As for cross server options, the options in the config file are there but the actual code hasn't been made yet.

  • Avatar of CustomForms CustomForms Apr 21, 2014 at 03:03 UTC - 0 likes

    Would be pretty cool if you hooked into vault to get the players amount of money so we can display that number on our website.

    Also, all the cross server option. Are there any tutorials on that?

    Last edited Apr 21, 2014 by CustomForms


Date created
Aug 19, 2012
Last update
Apr 20, 2014
Development stage
GNU General Public License version 3 (GPLv3)
Curse link
Recent files



Optional dependency
Achievements Reloaded