Minetrack makes it easy to keep an eye on your favorite Minecraft servers. Simple and hackable, Minetrack easily runs on any hardware. Use it for monitoring, analytics, or just for fun. Check it out.
This project is not actively supported. Pull requests will be reviewed and merged (if accepted), but issues might not be addressed outside of fixes provided by community members. Please share any improvements or fixes you've made so everyone can benefit from them.
- 🚀 Real time Minecraft server player count tracking with customizable update speed.
- 📝 Historical player count logging with 24 hour peak and player count record tracking.
- 📈 Historical graph with customizable time frame.
- 📦 Out of the box included dashboard with various customizable sorting and viewing options.
- 📱(Decent) mobile support.
- 🕹 Supports both Minecraft Java Edition and Minecraft Bedrock Edition.
You can find a list of community hosted instances below. Want to be listed here? Add yourself in a pull request!
- https://minetrack.me
- https://bedrock.minetrack.me
- https://track.read-my-man.ga
- https://trackedservers.com
- https://suomimine.fi
- https://minetrack.geyserconnect.net
- https://minetrack.rmly.dev
- https://minetrack.fi
For updates and release notes, please read the CHANGELOG.
Migrating to Minetrack 5? See the migration guide.
- Node 12.4.0+ is required (you can check your version using
node -v
) - Make sure everything is correct in
config.json
. - Add/remove servers by editing the
servers.json
file - Run
npm install
- Run
npm run build
(this bundlesassets/
intodist/
) - Run
node main.js
to boot the system (may need sudo!)
(There's also install.sh
and start.sh
, but they may not work for your OS.)
Database logging is disabled by default. You can enable it in config.json
by setting logToDatabase
to true.
This requires sqlite3 drivers to be installed.
Minetrack can be built and run with Docker from this repository in several ways:
# build image with name minetrack and tag latest
docker build . --tag minetrack:latest
# start container, delete on exit
# publish container port 8080 on host port 80
docker run --rm --publish 80:8080 minetrack:latest
The published port can be changed by modifying the parameter argument, e.g.:
- Publish to host port 8080:
--publish 8080:8080
- Publish to localhost (thus prohibiting external access):
--publish 127.0.0.1:8080:8080
# build and start service
docker-compose up --build
# stop service and remove artifacts
docker-compose down
The following configuration enables Nginx to act as reverse proxy for a Minetrack instance that is available at port 8080 on localhost:
server {
server_name minetrack.example.net;
listen 80;
location / {
proxy_pass http://localhost:8080;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
}
}