This document describes installing and running the server and client parts of the Synchronization GE.
The server part of the Synchronization GE is based on the realXtend Tundra SDK, therefore its hardware requirements are the same as of the Tundra SDK.
Server requirements
- Minimum of 1GB memory
- About 40GB free hard disk space when building Tundra, 1GB free when running
- Intel-compatible CPU with SSE instruction support, minimum processor speed 1.66 GHz
- If running graphics, a GPU with minimum of 256MB memory
Server requirements
- Windows XP or newer
- Mac OS X 10.6 or newer
- Ubuntu Linux 12.04 or newer. Other distributions may work but are not guaranteed.
The client code is operating system independent, as it's JavaScript code running in a browser.
The client part of the Synchronization GE requires a browser that has WebSocket support, such as
- Internet Explorer 10.0+
- Firefox 6.0+
- Chrome 14.0+
- Safari 6.0+
- Opera 12.1+
- iOS Safari 6.0+
- Android Browser 4.4+
- Opera Mobile 12.1+
- Chrome for android 31.0+
- Firefox for Android 25.0+
- Internet Explorer Mobile 10.0+
For serving the synchronization client HTML and JavaScript code, an HTTP server such as Apache can be used. For testing use the browser can also be pointed to local files.
There are two options, to download a prebuilt binary package, or build from source.
A prebuilt binary is provided for Ubuntu 14.04 64bit.
To install a Tundra package and its dependencies, use these commands. You need to have root privileges and an active Internet connection for downloading dependencies.
- apt-get update
- dpkg -i PackageFileName.deb
- apt-get -f install
After successful installation, the Tundra binary and examples scenes are placed in the /opt/realxtend-tundra directory.
Note! "dpkg -i PackageFileName.deb" will print missing dependencies error, but "apt-get -f install" should find & install them.
The server is also available as a Docker image:
32-bit and 64-bit installers are provided. These require an active Internet connection for downloading Microsoft redistributables.
- https://forge.fiware.org/frs/download.php/1692/Synchronization-Server-2.5.4-Windows-x86.exe
- https://forge.fiware.org/frs/download.php/1702/Synchronization-Server-2.5.4-Windows-x64.exe
After successful installation, Tundra can be run from the installation directory using the command prompt. This is the recommended way of running instead of Start Menu shortcuts, to be able to specify the command line parameters. On Windows there are Tundra.exe and TundraConsole.exe executables, where TundraConsole will display a console window and is therefore recommended for server usage.
Clone the Tundra git repository at https://github.com/realXtend/tundra.git, then clone the TundraAddons repository from https://github.com/realXtend/TundraAddons.git into the subdirectory src/TundraAddons of the Tundra clone. Then follow the README.md file in the root directory of the Tundra clone for build instructions. More detailed instructions are also found from the files (use Doxygen to generate html format documentation)
- https://github.com/realXtend/tundra/blob/tundra2/doc/dox/BuildOnMac.dox
- https://github.com/realXtend/tundra/blob/tundra2/doc/dox/BuildOnUbuntu.dox
- https://github.com/realXtend/tundra/blob/tundra2/doc/dox/BuildOnWindows.dox
After a successful build of Tundra, it can be run from the bin subdirectory. On Windows there are Tundra.exe and TundraConsole.exe executables, where TundraConsole will display a console window and is therefore recommended for server usage. On Linux / OS X there is just an executable called Tundra.
Note! There are separate build scripts for Ubuntu 14.04 and 12.04 and both scripts can be found at
- tools/Linux/build-deps-ubuntu14_04.bash
- tools/Linux/build-deps-ubuntu12_04.bash
It is recommended to use Ubuntu 14.04 version, since 12.04 version will cause rendering errors and need to be run in headless mode.
To load an example scene with server mode (both the Real-time Synchronization & SceneAPI services) enabled for testing, run the following command. On Windows, replace Tundra with TundraConsole:
Tundra --config tundra.json --config tundra-addons.json --file scenes/Avatar/scene.txml --server --headless --httpport 2346
If running from prebuilt binaries, the extra configuration file tundra-addons.json is already enabled. Therefore the --config command line options can be omitted.
Tundra --file scenes/Avatar/scene.txml --server --headless --httpport 2346
When running on a Linux server without X11 session, xvfb is required to run:
xvfb-run ./Tundra --file scenes/Avatar/scene.txml --server --headless --httpport 2346
If your using prebuild binaries on Linux, Tundra executable and example scenes can be found at /opt/realxtend-tundra directory
The client part of the Synchronization GE is supplied as part of the WebTundra JavaScript libraries. There are two options for getting it:
- Download a packaged release
- Clone the git repository at https://github.com/realXtend/WebTundra (dev2 branch)
To test connecting to a localhost synchronization server, open the file html/client.html in your browser from the source code clone or extracted package, then click "Connect" in the displayed login screen. You may need to serve the client source directory in a web server such as Apache or node.js server due to permission problems with the local file:// protocol.
For both the server and the client, it is recommended to have at least 1 GB free RAM and 1 GB free hard disk space, a broadband network connection, and to ensure that the system is not unnecessarily loaded with other processes.
When the Tundra server is running using the command line above, and the client HTML page html/client.html is open, you should be able to test connecting to the localhost server by clicking the "Connect" button. At this point the JavaScript synchronization code should connect to the Tundra server. You should see the following in Tundra server console:
[WebSocketServer]: Connection ID 1 login successful
The connection ID may not be exactly the same.
Also, when inspecting the client page using a web developer console, you should see the log message "Server connection established" after clicking "Connect".
Seeing these prints confirms that a WebSocket connection between the Tundra server and the JavaScript client code is functioning, and synchronization can be used.
When the Tundra server is running using the command line above, point a web browser to the following local address to confirm that the SceneAPI is operational:
http://localhost:2346/entities
This should display a dump of the scene loaded on the Tundra server as XML data.
Server: Tundra or TundraConsole
Port 2345, both TCP & UDP. This is the default Tundra port for serving scenes using the real-time synchronization and can be changed with the --port startup parameter.
Port 2346, TCP (HTTP). SceneAPI REST service. This was specified on the Tundra server command line (parameter --httpport 2346). There is no default value; if this parameter is not specified the SceneAPI service will not start up.
N/A
If connection fails between the server and the client, verify the following:
- that the server was started with the --server command line parameter
- that the WebSocketServerModule is loaded on the server; the row "Loading plugin WebSocketServerModule" should be printed to the server console during server startup, with no error messages following it
- that firewall is not blocking port 2345
- if the client and server are not on the same machine, or the server port is not the default 2345, make sure that you supply the correct address and port number in the client login screen.
If connection to the SceneAPI service fails, verify the following:
- that the http server port was specified on the server command line parameter, eg. --httpport 2346
- that the HttpServerModule is loaded on the server; the row "Loading plugin HttpServerModule" should be printed to the server console during server startup, with no error messages following it. The loading of this module is controlled by the configuration file tundra-addons.json, which is enabled by the parameter --config tundra-addons.json on the server command line. This should have been copied to the Tundra executable directory as part of the TundraAddons build process
- that firewall is not blocking port 2346
The server memory consumption should be around 50 MB when running a simple scene without rendering. With rendering enabled, it may be between 100 MB and 200 MB. A typical desktop web browser typically uses around 100 MB of memory when showing a Synchronization client application. CPU usage depends on the amount of activity in the networked scene, but should be when there is nothing happening.
N/A
As resource consumption is dependent on the scene complexity, the scripts that are running in it, the amount of client connections to the server and their activity, it is hard to give directions to what kind of eg. a memory consumption on the server would be considered abnormal. One guideline would be to note the amount of memory in use once a server has started up and loaded the scene: if memory use for example rapidly doubles from that figure and continues to grow unbounded, then it's likely that an application script is misbehaving and leaking memory.
In a demanding application or scene that uses physics and heavy scripting, it is not uncommon to see high CPU use figures by the server (up to full utilization of one processor core) with high numbers of active clients. For an example, consider a high number (50-100) of clients connected to a scene running an "avatar application": each client gets an avatar to move around, which is physically simulated and uses scripts for movement, collision response etc. Rectifying high CPU utilization in such case will require either using more powerful hardware, simplifying the application (for example not using actual physics simulation, or simplifying the scripts) or limiting the amount of users that can simultaneously connect.
Note that this is considering the processing on the Tundra server process as a whole. The network synchronization itself is fairly lightweight in its processing requirements.
The Synchronization GE will by default use TCP (WebSocket) traffic on the port 2345. Additionally native (Tundra) clients will use UDP traffic on the same port. The SceneAPI REST service will use TCP (HTTP) traffic on the chosen port. The amount of traffic on the server will depend the scene being served and the amount of connected clients; typical would be in the order of tens to hundred kilobytes per second.