Skip to content

LordOfPomelo installation guide

Dirk Krause edited this page Nov 27, 2013 · 5 revisions

Runtime Environment

  • node.js
  • Windows, Linux, or MacOS
  • MySQL database

LordOfPomelo installation

Download the source code

git clone https://github.com/NetEase/lordofpomelo.git

Dependencies installation

Enter the directory: cd lordofpomelo

Install dependencies :

  • apt-get install sysstat
  • sh npm-install.sh(Windows: npm-install.bat)

MySQL database creation and data import

Create the database

sql file path: ./game-server/config/schema/Pomelo.sql

  • Install MySql database(abbreviated)
  • Login MySql: mysql -u username -p password (successful login prompt: mysql>)
  • Create a database: mysql> create database Pomelo;
  • Select the database: mysql> use Pomelo;
  • Import sql file: mysql> source ./game-server/config/schema/Pomelo.sql;

This can also be done in one bash command, like: mysql -u root -p -Bse "create database Pomelo;use Pomelo;source ./lordofpomelo/game-server/config/schema/Pomelo.sql;"

Modify the database configuration

The database configuration file is "./shared/config/mysql.json"

{
  "development": {
   "host" : "127.0.0.1",
    "port" : "3306",
    "database" : "Pomelo",
    "user" : "xy",
    "password" : "dev"
  },
  "production": {
   "host" : "127.0.0.1",
    "port" : "3306",
    "database" : "Pomelo",
    "user" : "xy",
    "password" : "dev"
  }
}

Change the "development" environment database configuration to the actual configuration. This normally means enter the user/password combination.

Run the game

Start the game-server and web-server separately. Game-server's startup method:

  • pomelo start (pomelo installation pomelo quick start guide) Note: If pomelo processes don't exit completely, you can use pomelo kill - force to end all node processes.

Web-server's startup method:

  • cd web-server && node app

Visit the game

You can run servers locally, visit http://localhost:3001 or http://127.0.0.1:3001 directly in the browser.

Your browser must support websocket. We recommend Chrome.

Related problem solution

  1. Port conflicts

Open the ports 3000-3100.

Modify the server configuration file "./game-server/config/servers.json", reads as follows:

{
  "development": {
    "connector": [
      {"id": "connector-server-1", "host": "127.0.0.1", "port": 3150, "clientPort": 3010, "frontend": true},
      {"id": "connector-server-2", "host": "127.0.0.1", "port": 3151, "clientPort":3011, "frontend": true}
    ],
    "area": [
      {"id": "area-server-1", "host": "127.0.0.1", "port": 3250, "area": 1}, 
      {"id": "area-server-2", "host": "127.0.0.1", "port": 3251, "area": 2}, 
      {"id": "area-server-3", "host": "127.0.0.1", "port": 3252, "area": 3}, 
      {"id": "instance-server-1", "host": "127.0.0.1", "port": 3260, "instance": true},
      {"id": "instance-server-2", "host": "127.0.0.1", "port": 3261, "instance": true},
      {"id": "instance-server-3", "host": "127.0.0.1", "port": 3262, "instance": true}
    ],
    "chat": [
      {"id":"chat-server-1","host":"127.0.0.1","port":3450}
    ],
    "path": [
      {"id": "path-server-1", "host": "127.0.0.1", "port": 3550}
    ],
    "auth": [
      {"id": "auth-server-1", "host": "127.0.0.1", "port": 3650}
    ],
    "gate": [
      {"id": "gate-server-1", "host": "127.0.0.1", "clientPort": 3014, "frontend": true}
    ],
    "manager": [
      {"id":"manager-server-1","host":"127.0.0.1","port":3750}
    ]
  },
  "production": {
    // ...
  }
}

The configuration file defines various servers' configuration information in development and production environments, including the server type, address and port number, etc. The parameters of the production environment has a similar structure as the development environment. When the "frontend" parameter is "true", it means that this is a front-end server. You can modify the corresponding port number when it conflicts with others.

You can modify the file "./web-server/public/js/config/config.js" either, reads as follows:

__resources__["/config.js"] = {meta: {mimetype: "application/javascript"}, data: function(exports, require, module, __filename, __dirname) {
  module.exports = { 
    IMAGE_URL:'http://pomelo.netease.com/art/',
    GATE_HOST: window.location.hostname,
    GATE_PORT:3014
  };
}};

This file is the common configuration information used in the web server: IMAGE_URL is the address of the images and other static resources; GATE_HOST is the entrance of a gate-server to accept the websocket connections; Firstly, all the websocket requests must get the connector-server id via the gate-server, and then establish a connection with the connector-server; GATE_PORT is the the port number of the front-end gate-server. Manager-server is mainly responsible for copy and team functions.

Configuration file summary description

  • ./game-server/config/master.json

This is the master server configuration information, including the server address and port number under development and production environments.

The master server is responsible for starting, stopping the servers, and monitoring all servers' status information.

  • ./game-server/config/servers.json

It contains area-server, connector-server's configuration information, including server address and port number under the development and production environments. As the connector-server is the front-end server, used to receive the request and forward players' request, so there will be a clientPort.

  • ./shared/config/mysql.json

This is database configuration information. After the installation of LordOfPomelo, you need to modify the parameters of the development and production environments according to the actual situation of the database installation.

  • ./web-server/public/js/config/config.js

This is a configuration file with the client images and other static resources and HTTP access address.

Login problem description

LordOfPomelo provides a 'new user' registration and is using either local login, or github, google, facebook, twitter and weibo in the authorized manner to login. When using authorized services to login, you need to modify the corresponding OAuth credentials in the configuration file (./web-server/config/oauth.json).

Clone this wiki locally