-
Notifications
You must be signed in to change notification settings - Fork 48
Beginners Guide How Everything Fits Together
So you know what Github is, what CMaNGOS stands for and you have a general idea of what a database is. Hopefully you also understand what the realmd and mangosd applications are as well. How do all of these things communicate with each other and make it so you can play WoW on your own server? Read on and find out!
An MMO is a massively complicated piece of work and so it takes many different pieces to make it run. It's not as simple as playing a game on your local computer like The Sims or Skyrim. Why? Well in those types of games all of the information is stored on your computer and there is no need to be online to play them. They have their own databases built into the game and there is only one player so you only have to load each room or area where the player is. In an MMO, however, the entire game world is always running and there are multiple players communicating and interacting with it. Furthermore, variables throughout the world cannot be saved locally because: (1) the more information that is on the client, the more potential for hacking and exploiting there is because players have access to the client; and (2) different players interact with the same world which responds to their actions. Therefore information needs to be saved in a neutral location, otherwise information stored on one player's client would suddenly become unavailable to other players when that player disconnected from the game. All of this necessitates the concept of having a single "server" that hosts the world and multiple "clients" that connect to it.
The mangosd.exe application is the server which runs the realm and all the events that happen inside of it. The game server not only hosts the physical environment but also manages all non-player actions and events such as NPCs and creatures, the weather system, game events like the various seasonal festivals, and pretty much anything else you can think of that isn't your character moving around.
The wow.exe application is the client which players use to launch the game and connect to and communicate with the game server.
You can't just connect to a server without having created an account first and so we need a login server to manage accounts and passwords. This is the realmd.exe application which also directs connecting clients to the realm that they want to play on after authenticating the player's login credentials.
Even if we have a mangosd.exe and a realmd.exe running, there still needs to be a place to store the accounts and passwords and the objects and things in the game as well as the many variables associated with a single player; and so we have a third server called the database to store all of this information.
So you have your servers running and you are ready to try it out. You launch wow.exe...
The first thing that happens is the client attempts to find a login server at the location you told it to look: the address you entered into the realmlist.wtf document. Say you want the client to look for a login server on the same computer that you are running wow.exe: you would direct it to 127.0.0.1 (a universal address for your local computer to connect to itself). Because you have realmd.exe running, the client finds it and you are now ready to login. You type in some credentials and the server tells you that they are wrong, why? Because the login server needs to have your account stored somewhere in order to accept your credentials.
So now you switch over to your mangosd.exe application to create a new account. You type in the command "account create user password" which then adds a new account to the "realmd" MySQL database with the name "user" and the password "password."
You can now go back to your wow.exe client and type in the new credentials; the login server accepts your connection and allows you to select a realm to enter and begin playing. There will only be one available realm which by default is called "Mangos." You click on the realm and it loads the characters screen. Because this account was just created there are no saved characters so you create a new human warrior called "test" and enter the world.
As soon as you create test the human warrior, it is assigned an id number and all of the starting statistics, skills, abilities, and items are added to the "characters" MySQL database. Any time anything with the character changes, mangosd.exe will send an update to the MySQL database with the new information and save it there (character saves also occur at regular intervals in case the server crashes).
So you talked to the guard and moved around a bit and you are ready to start slaying some wolves. You target a wolf and right click to begin attacking. Because you are standing too far away the game tells you that you must move closer. You run up to the wolf and as soon as you are within range, you swing and take the wolf down to 50% health and it begins attacking you back. You may not realize it but a dozen processes and checks were just executed for that simple encounter.
-
You right clicked on the creature: the game server checked to see if you were in range by comparing your coordinates stored locally on the client to the coordinates of the creature stored in the "mangos" database. When it determined that you were not within range for a melee attack, it returned an error and a message that you are out of range (and probably played a bit of audio of your character saying something like "I'm out of range").
-
You ran up to the wolf until you were in range: your melee attack attempts to connect every few seconds (based on your weapon's attack speed) and so every time it tries to attack it checks your coordinates vs. your target's to see if you are in range. Because you were moving toward your target, the game repeated this check probably several times before it finally "passed" because you were in range.
-
You hit the wolf and take it's health down by 50%: so the game confirmed that you were in range and that you hit your target. It checked your weapon's attack damage against the wolf's defenses and randomly calculated an amount of damage based on those variables. It then subtracted that amount from the wolf's health.
-
The wolf begins attacking you: the wolf creature template is associated with a certain script which determines its behavior. Because this script tells it to defend itself, the game server directed the wolf to attack the hostile player hitting it.
Now let's say you want to create a guild. You travel to Stormwind and talk to the guildmaster dude to get a charter. You then get some friends to sign the charter (after of course managing to get your server setup so that other players can connect to it) and go back to the guildmaster. You submit your charter and voila... your guild is created. In that transaction mangosd.exe accepted input from the wow.exe client and then sent a command to the "characters" MySQL database to store: the name of the guild, the guild master, the tabard design and emblem, the various characters who are now members and their ranks, and a number of other variables.
As you can see, every little action and exchange of information is incredibly complicated and requires a lot of quick and efficient communication between the client and the multiple pieces of the server.
Now you can move on to the installation instructions and get started! Remember that the forums and the #cmangos IRC channel are full of people available to help you with any issues so don't be afraid to ask. Once you have a server up and running we encourage you to participate in the community, report bugs, and if you have some programming skills, try your hand at fixing or enhancing the repositories. There is plenty of information on the forums about how to participate and help out.