Skip to content

kurafuto/kurafuto

Repository files navigation

Kurafuto

Minecraft Classic load balancer, similar to nginx or BungeeCord (hopefully!).

This is definitely pre-release software, so it will probably go through sweeping changes every few commits, and may: crash, "accidentally" lose packets, eat your pets, or burn down your house if you look at it wrong. You've been warned.

What I'm saying is, don't use this in production yet.

NB! The phrases "balancer", "proxy" and "Kurafuto" are used somewhat interchangeably in this document. All it means is the box between clients and backend servers.

Usage

There are a few steps to using Kurafuto in its current state:

# Install Kurafuto
$ go get github.com/sysr-q/kurafuto
$ go install github.com/sysr-q/kurafuto

# Set up where you're "running" Kurafuto from
$ mkdir /path/to/kura
$ cd /path/to/kura
$ cp $GOPATH/src/github.com/sysr-q/kurafuto/kurafuto.json .

# Modify the configuration to your liking & run!
$ vim kurafuto.json
$ kurafuto -config="$(pwd)/kurafuto.json"

Topology

Ideally, this would act as a transparent proxy, acting more as a gateway/hub server in a linked network of servers. Think an IRC network, in terms of hub/leaf server links.

   +----------+                                 +----------+
   | Client A |<----+                     +---->| Server A |
   +----------+     |                     |     +----------+
   +----------+     |    +----------+     |     +----------+
   | Client B |<----+--->| Kurafuto |<----+---->| Server B |
   +----------+     |    +----------+     |     +----------+
   +----------+     |                     |     +----------+
   | Client C |<----+                     +---->| Server C |
   +----------+                                 +----------+

As there is no native signal for a server to indicate that a client (or a balancer masquerading as a client) should jump server, Kurafuto has to make use of some imperfect workaround solutions in the mean time.

A client-side command, which Kurafuto intercepts, allowing the client to "force" a redirection. :kura jump ServerA , for example. (This is what is currently implemented.)

Client-commands

  • TBA: command prefix.
  • :kura help
  • :kura list
  • :kura jump ServerA

Proxying

When a client connects to the balancer (Kurafuto), the balancer will make a connection on the behalf of the client to one of the linked servers, and proxy packets back and forth between the two.

Kurafuto makes use of Kyubu to parse packets out of the client and server streams. This allows the balancer to do things like inject, drop, or modify packets on-the-fly as they pass through.

Use of a custom parser, rather than a dumb TCP proxy does mean, however, that any unrecognised packets will be an issue - if there's a custom packet you want to recognise, be sure to register it with Kyubu (which is documented in Kyubu's repo, and quite simple), and Kurafuto will pass it through just fine.

Note, though, that the packet id 0xff is given special meaning: it's used to register packet handlers which listen for any packet. This might be an issue if a future packet uses that id.

Authentication

Authentication (if enabled: "authentication": true) is handled at the edge by the balancer. This means that servers will have to disable their authentication and any throttling limitations.

If authentication is enabled, this means that only valid connections will be coming from the edge balancer, and the servers will have authentication disabled, it would make sense for the servers to be configured to blacklist connections from anyone but the balancer.

Heartbeats

Backend servers should either disable their heartbeats, or if this isn't possible, set themselves to "private", ensuring that there aren't servers in the public listings which shouldn't be present.

Kurafuto will be able to make heartbeats on the behalf of the servers, but the exact specifics of this (how the MOTD, etc. are set) is still TBA.

Roadmap (haphazard)

Things to work on:

  • Parse proxy mode
  • Handle SIGHUP to reload configuration (preferably without disconnecting clients)
  • Handle SIGINT and SIGTERM to gracefully shut down (kicking clients).
  • Heartbeats
    • ClassiCube?
    • Notchian
  • Authentication (requires parse mode so it's not hellish)
    • ClassiCube authentication is supported.
    • Notchian authentication
  • Encryption (latest Minecraft protocol)
  • Zipping (latest Minecraft protocol)
  • Forwarding on the "real" IP in an X-Forwarded-For manner.
    • Potentially we could add an out-of-band Bukkit plugin, but that's TBA.
  • There's a slight delay when users connect where Kurafuto dials to the hub.
    • Should we keep a hot pool of connections to pick from?
  • Handling redirection signals
    • How will we handle buffering packets so that the next server gets basic information about the connecting client? Which packets do we need to buffer?
  • Allow multiple Kurafuto servers to mesh link sideways, allowing extra crazy setups, and load balancing. Probably not required, but nice idea anyway.
  • Add extra debugging information, tidy up existing information, and ensure that (in the case of bugs), it's all easily accessible to server admins.
  • Add modularity with GopherLua.
    • Hooks, event-based. Basically hooks.go but tied into Lua.

About

Minecraft balancer/proxying server, like BungeeCord/Lilypad/nginx.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages