-
Notifications
You must be signed in to change notification settings - Fork 252
ACE Hosting
ACE consists of two main components. The database, and the server (executable).
ACE is very demanding on the database. This load increases with player count. For this reason, it is highly recommended your database be installed on the same instance as your server.
- 1-10 Players
- 2 Threads
- 4 GB RAM
- 11-49 Players
- 4 Threads
- 8 GB RAM
- 50-499 Players
- 6 Threads
- 16 GB RAM
- 500+ Players
- 8 Threads
- 32 GB RAM
- 2 Mbps incoming network traffic
- 12 Mbps outgoing network traffic
-
Install MySQL or MariaDB
-
MySQL minimum required version - 5.7.17+
- When installing on the same instance the ACE server will run on (recommended), select "Server Machine" as the server type.
- The optional "MySQL Workbench" application can be used to interface with the database to apply new and updated .sql files.
- If you would like to add automated DB backups to your Windows-MYSQL DB (https://github.com/KT053374/MySQL_Auto_Backup_Windows)
- MariaDB minimum required version - 10.2+
- Optionally install SQLYog editor on Github for the following steps
-
MySQL minimum required version - 5.7.17+
-
Create three databases named
ace_auth
,ace_shard
, andace_world
E.g. using the command line. Replace variables inside the " " to your liking but make sure that they are also present inside the config as well. They have to match up. You can call the database whatever you want.
DROP USER IF EXISTS 'trinity'@'localhost'; CREATE USER 'acore'@'localhost' IDENTIFIED BY 'acore' WITH MAX_QUERIES_PER_HOUR 0 MAX_CONNECTIONS_PER_HOUR 0 MAX_UPDATES_PER_HOUR 0;
GRANT ALL PRIVILEGES ON * . * TO 'acore'@'localhost' WITH GRANT OPTION;
CREATE DATABASE auth
DEFAULT CHARACTER SET UTF8MB4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE characters
DEFAULT CHARACTER SET UTF8MB4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE world
DEFAULT CHARACTER SET UTF8MB4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE hotfixes
DEFAULT CHARACTER SET UTF8MB4 COLLATE utf8mb4_unicode_ci;
GRANT ALL PRIVILEGES ON auth
. * TO 'trinity'@'localhost' WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON characters
. * TO 'trinity'@'localhost' WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON world
. * TO 'trinity'@'localhost' WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON hotfixes
. * TO 'trinity'@'localhost' WITH GRANT OPTION;
-
Load AuthenticationBase.sql and ShardBase.sql for their respective databases. These can be found in the Database\Base directory.
-
Load all incremental SQL updates found in the Database\Updates\Authentication sub directory in the order of oldest to newest. Skip this step if there are no updates in this directory.
-
Load all incremental SQL updates found in the Database\Updates\Shard sub directory in the order of oldest to newest. Skip this step if there are no updates in this directory.
-
Download the latest release of world data, extract and load into your ace_world database.
-
SKIP THIS STEP IF USING DOWNLOADED WORLD DATA FROM PREVIOUS STEP.
- If using a custom database, you may need to update the schema for the emulator to operate correctly. If you're using the official release data, this step is not recommended.
- Load WorldBase.sql from Database\Base into your
ace_world
database - Load all incremental SQL updates found in the Database\Updates\World sub directory in the order of oldest to newest. Skip this step if there are no updates in this directory.
- inno_db_buffer_pool_size This setting can have a significant impact on your database performance. The minimum size recommended for a public server is 2G. As the server approaches 500+ active players, the recommended buffer pool size will grow to over 5G. You will need to manage the memory consumed by your database and the ACE server vs the total system memory available. The buffer pool size should not exceed more than half of your total system memory. Using about 25% of your system memory for the buffer pool is a likely safe number for a common ACE configuration, assuming your system is provisioned at or greater than the recommended system requirements described above.
Host specific information can be found in both the Windows and Linux Specific Instructions.
The Config.js already has documentation. However, we have found the following settings pair well with typical servers of the given player counts:
- 1-10 Players
- WorldThreadCountMultiplier: 0.34
- MultiThreadedLandblockGroupPhysicsTicking: false
- MultiThreadedLandblockGroupTicking: false
- 11-49 Players
- WorldThreadCountMultiplier: 0.5
- MultiThreadedLandblockGroupPhysicsTicking: true
- MultiThreadedLandblockGroupTicking: false
- 50-499 Players
- WorldThreadCountMultiplier: 0.5
- MultiThreadedLandblockGroupPhysicsTicking: true
- MultiThreadedLandblockGroupTicking: true
- 500+ Players
- WorldThreadCountMultiplier: 0.5
- MultiThreadedLandblockGroupPhysicsTicking: true
- MultiThreadedLandblockGroupTicking: true
Shard specific configurations are done in game, or on the console, using ACE commands.
- Create your first account as an admin at the ACE prompt:
accountcreate testaccount testpassword 5
- Launch ACClient directly with this command:
acclient.exe -a testaccount -v testpassword -h 127.0.0.1:9000
ACE provides help for server operators. The ACE Discord can be a great resource with advice available from other server operators as well as developers