A communication architecture for massive multiplayer games

In this paper we present an approach for a communication architecture based on the publisher/subscriber model. The key issues considered here are scalability, ease of programming and dynamic system evolution. The division of the communication load into distinctive channels allows decoupling the domains of the game enabling the overall system to scale flexibly with the underlying network infrastructure, map size or number of players simultaneously online. Thus our approach is suitable to realize especially huge game-worlds as used in massive multiplayer online games. The underlying publisher/subscriber communication layer provides a high level of abstraction with a lean API therefore dramatically simplifying network programming in the game engine. Due to the fact that the communication is content-based, there is no fixed correlation between the game players and the game backend servers. This permits the dynamic evolution of the system by removing or adding not only players but also game servers and game content on the fly.