- TypeScript 55%
- Kotlin 40.5%
- Go 2.8%
- PowerShell 0.7%
- CSS 0.5%
- Other 0.4%
| .github | ||
| frontend | ||
| gradle/wrapper | ||
| helm | ||
| helper | ||
| ogcloud-api | ||
| ogcloud-common | ||
| ogcloud-controller | ||
| ogcloud-legacy-paper-plugin | ||
| ogcloud-loadbalancer | ||
| ogcloud-paper-plugin | ||
| ogcloud-template-loader | ||
| ogcloud-velocity-plugin | ||
| .editorconfig | ||
| .gitignore | ||
| build.gradle.kts | ||
| build.ps1 | ||
| gradle.properties | ||
| gradlew | ||
| gradlew.bat | ||
| LICENSE | ||
| README.md | ||
| settings.gradle.kts | ||
☁️ Kubernetes-native infrastructure for running Minecraft networks.
🚀 Provision servers on demand. 🌐 Route players intelligently. 🛠️ Manage your whole network from one control plane.
🧠 What We Are
OgCloud is a Kubernetes-native control plane for Minecraft networks.
It gives you one platform for:
- 🌐 network ingress and TCP routing
- 🎮 proxy and backend server lifecycle
- 📈 autoscaling and maintenance workflows
- 📦 templates and backing services
- 🖥️ dashboard + API operations
- 🔌 plugin-level integration APIs
Repository: https://github.com/Jevzo/ogcloud
🧪 Development Status
OgCloud is still actively in development.
Current status: beta and production-ready for teams comfortable with Kubernetes operations and iterative releases.
Planned roadmap: support multiple Minecraft versions in a single cluster through protocol-based routing at the load balancer, with plugin-side translation.
💡 Why OgCloud
- ✅ Replace hand-maintained server fleets with managed lifecycle automation.
- ✅ Scale by group rules and player demand, not guesswork.
- ✅ Keep gameplay plugins connected to live cloud state.
- ✅ Update API/controller/loadbalancer/dashboard independently.
- ✅ Use one platform model from local testing to production clusters.
⚔️ Why The Alternatives Lose
Practical version: most stacks in this space still fall into one of three buckets:
- legacy host-first architecture,
- infrastructure primitives sold as a complete platform,
- or process orchestration with modern branding on top.
OgCloud wins from a controller + API + load balancer perspective because it is built as a real control-plane stack:
- ✅ Controller lifecycle behavior for scale, churn, and failure handling (not start/stop scripts).
- ✅ Full operational API surface for scriptable, observable network operations.
- ✅ Dedicated Minecraft-aware ingress with proxy heartbeat tracking and clean drain behavior.
- ✅ Kubernetes-native deployment workflows with Helm and setup automation.
Competitor reality check:
- PoloCloud: promising, but still feels like a moving target and adds platform overhead before operational confidence.
- CloudNet: historically important, but still rooted in node-centric, host-first architecture from an older era.
- Shulker: technically strong, but closer to a substrate than a complete opinionated platform; teams still assemble too much themselves.
- SimpleCloud: calls itself "simply the best" but their own positioning admits Kubernetes is "not possible right now" and the Docker push stalled out. That is legacy process management with cloud branding.
For serious Minecraft networks, the gap is clear: OgCloud is built as a modern control plane, while most alternatives are either legacy models or incomplete platform stories.
✨ Feature List
- ☸️ Kubernetes-native architecture for Minecraft workloads
- 🧭 Dedicated Minecraft-protocol-aware load balancer
- 🤖 Controller-driven autoscaling and server orchestration
- 💻 Dashboard + REST API for network operations
- 🗂️ Template storage and distribution flow
- 📬 Kafka + Redis + MongoDB integration
- 🔌 Paper and Velocity plugin APIs
- 🧱 Helm charts split by concern: infra, platform, dashboard
- 🛣️ Planned: multi-version network support (single cluster, protocol-aware routing + plugin translation)
⚡ Quick Install Guide
✅ Prerequisites
kubectlconfigured for your target clusterhelm- Node.js 18+ (
npm/npx)
🚀 Fastest Path (Recommended)
If you want the easiest setup: this is it. Spin up the wizard, answer a few prompts, and you are deploying in minutes.
npx @ogcloud/setup
🧭 Straight Command Path
npx @ogcloud/setup --generate-config ogwars
npx @ogcloud/setup --deploy ogwars
🧰 Common Commands
npx @ogcloud/setup --generate-config <network>
npx @ogcloud/setup --deploy <network>
npx @ogcloud/setup --deploy <network> --without-backing
npx @ogcloud/setup --update <network> <dashboard|api|loadbalancer|controller> <tag>
npx @ogcloud/setup --destroy <network>
🗄️ Generated Local State
~/.ogcloud-setup/state.json~/.ogcloud-setup/networks/<network>/values.infra.yaml~/.ogcloud-setup/networks/<network>/values.platform.yaml~/.ogcloud-setup/networks/<network>/values.dashboard.yaml
🌍 Public Endpoints
A typical OgCloud deployment exposes:
mc.yourserver.io-> Minecraft ingress through OgCloud load balancerhttps://api.yourserver.io-> control-plane APIhttps://dashboard.yourserver.io-> admin dashboard
🔌 Plugin APIs
OgCloud exposes APIs for both Paper and Velocity plugins.
Use these artifacts as compileOnly or provided dependencies in your plugin. The OgCloud Paper or Velocity plugin
provides the runtime classes on the server.
GitHub Packages still requires authentication for Gradle and Maven downloads. Configure gpr.user and gpr.key in
your Gradle properties or export GITHUB_ACTOR and GITHUB_TOKEN.
Gradle Repository
repositories {
maven {
url = uri("https://maven.pkg.github.com/jevzo/ogcloud")
credentials {
username = project.findProperty("gpr.user") as String? ?: System.getenv("GITHUB_ACTOR")
password = project.findProperty("gpr.key") as String? ?: System.getenv("GITHUB_TOKEN")
}
}
}
Paper Dependency
dependencies {
compileOnly("io.ogwars.cloud:ogcloud-paper-plugin:LATEST_VERSION")
}
<dependency>
<groupId>io.ogwars.cloud</groupId>
<artifactId>ogcloud-paper-plugin</artifactId>
<version>LATEST_VERSION</version>
<scope>provided</scope>
</dependency>
Velocity Dependency
dependencies {
compileOnly("io.ogwars.cloud:ogcloud-velocity-plugin:LATEST_VERSION")
}
<dependency>
<groupId>io.ogwars.cloud</groupId>
<artifactId>ogcloud-velocity-plugin</artifactId>
<version>LATEST_VERSION</version>
<scope>provided</scope>
</dependency>
Paper Example: Lobby Switcher Using getPlayerGroup
This routes players to a different lobby group depending on their resolved permission group.
class LobbyCommand : CommandExecutor {
override fun onCommand(sender: CommandSender, command: Command, label: String, args: Array<out String>): Boolean {
val player = sender as? Player ?: return true
val cloud = OgCloudServerAPI.get()
val permissionGroup = cloud.getPlayerGroup(player.uniqueId)
val targetLobbyGroup = if (permissionGroup?.name.equals("staff", ignoreCase = true)) {
"staff-lobby"
} else {
"lobby"
}
cloud.transferPlayerToGroup(player.uniqueId, targetLobbyGroup)
.thenRun { player.sendMessage("Sending you to $targetLobbyGroup...") }
.exceptionally {
player.sendMessage("Failed to switch lobby.")
null
}
return true
}
}
Paper Example: Match Flow + Warm Spare Request
val cloud = OgCloudServerAPI.get()
cloud.setGameState(GameState.INGAME)
cloud.requestServer("minigame").thenAccept { serverInfo ->
logger.info("Warm spare requested: {} in group {}", serverInfo.id, serverInfo.group)
}
Velocity Example: Route On Join With getPlayerGroup
class AutoRouteListener {
@Subscribe
fun onJoin(event: PostLoginEvent) {
val player = event.player
val cloud = OgCloudProxyAPI.get()
val playerGroup = cloud.getPlayerGroup(player.uniqueId)
val destinationGroup = if (playerGroup?.name.equals("vip", ignoreCase = true)) {
"vip-lobby"
} else {
"lobby"
}
cloud.transferPlayerToGroup(player.uniqueId, destinationGroup)
.exceptionally {
logger.error("Failed to route {} to {}", player.username, destinationGroup, it)
null
}
}
}
🆘 Discord And Help
- Community and support: OgCloud | Support and Development
- Source and issues: https://github.com/Jevzo/ogcloud
❤️ Sponsoring
If OgCloud helps your network, sponsoring supports faster development and support capacity.
🛠️ Local Development
From repo root:
.\build.ps1 api
.\build.ps1 controller
.\build.ps1 dashboard
Docker build + push examples:
.\build.ps1 docker api -p
.\build.ps1 docker controller -p
.\build.ps1 docker loadbalancer -p
.\build.ps1 docker dashboard -p
📦 Publish @ogcloud/setup
cd helper/ogcloud-setup-cli
npm install
npm run build
npm version patch
npm publish --access public
After publish:
npx @ogcloud/setup