Passer au contenu principal
Version: bleeding-edge 🩸

Configuration du serveur

Tout ce que vous devez savoir pour configurer votre serveur !

Fichier de configuration du serveur​

Le fichier de configuration du serveur Config.toml est généré automatiquement lorsque le serveur est lancé pour la première fois. Ce fichier sera toujours remplacé par le bon modèle après le chargement du serveur.

tip

nanos world Config files use TOML (Tom’s Obvious, Minimal Language), please refer to https://github.com/toml-lang/toml for more information and syntax.

Config.toml
# discover configurations
[discover]
# server name
name = "nanos world server"
# server description (max 127 characters)
description = ""
# server IP. we recommend leaving it 0.0.0.0 for default
ip = "0.0.0.0"
# server port (TCP and UDP)
port = 7777
# query port (UDP)
query_port = 7778
# announce server in the master server list
announce = true
# true if should run as dedicated server or false to run as P2P - dedicated server requires port forwarding - P2P will provide a fake IP to be used to connect
dedicated_server = true

# general configurations
[general]
# max players
max_players = 64
# leave it blank for no password
password = ""
# nanos world server authentication token
token = ""
# banned nanos account IDs
banned_ids = [

]

# game configurations
[game]
# default startup map
map = "default-blank-map"
# game-mode package to load (set the main game-mode package to load - you can load only one 'game-mode' package type at once)
game_mode = ""
# packages list (set the packages you want to load)
packages = [
"",
]
# asset packs list (additionally loads the asset packs you define here)
assets = [

]
# loading-screen package to load (the loading screen will be displayed when players join your server)
loading_screen = ""

# custom settings values
# those values can be accessed through Server.GetCustomSettings() method from any package
[custom_settings]
# my_setting_01 = "value"
# my_setting_02 = 123

# debug configurations
[debug]
# log Level - (1) normal, (2) debug or (3) verbose
log_level = 1
# if to use async or sync logs (async provides better performance, disabling async logs can help debugging crashes)
async_log = true
# enables performance profiling logs for debugging
profiling = false

# optimization configurations
[optimization]
# server tick rate in milliseconds (dangerous! server will tick at each [tick_rate] ms, affecting both server and client performance. 33 ms means 30 ticks per second and is the default and recommended value)
tick_rate = 33
# sets the compression level to use in some networking operations (0 - 9) - (0) disables it, (1) is the fastest and (9) is the slowest but has the highest compression ratio
compression = 0

Paramètres détaillés​

ParamètreDescription
nameNom du serveur
descriptionDescription du serveur
max_playersMax amount of players allowed to join
passwordPassword to be able to connect
ipServer IP. We recommend leaving it blank
portServer main Port and HTTP Port (UDP/TCP)
query_portServer query Port (UDP)
announceWhether to announce or not in the Server List
tick_rateServer Tick in ms. We recommend leaving it 33
log_levelWhich Log level to output
game_modegame-mode package to load - you can only load one game-mode at once.
loading_screenloading-screen package to load - you can only load one loading-screen at once.
packagesscript packages to load
mapmap package to load
assetsAdditional assets to force to load
tokenServer Token used for authorize downloads through CLI
banned_idsList of banned nanos account IDs

Logo Image​

It is possible to have a custom image to be displayed in the server list. For that, add a file called Server.jpg besides the server executable with the logo you wish. The recommended size is 300x150.

tip

You can pass a JPG image URL to --logo parameter to download and use a image from the web instead of placing it physically in the folder.

Map & Level​

The Map (or Level) is defined in the Server's config file, this map will be loaded when the player joins the server in the client side.

To configure a map, please refer to Packages Guide to create a Map Package pointing to the correct Asset.

nanos world counts on (for now) 4 built-in maps: default-blank-map, default-empty-map, default-ocean-map and default-testing-map which can be used in your server without needing to download any Package/Asset Pack.

Server Console​

Commandes intégrées​

CommandeDescription
chat <message>Envoie un message dans le chat
kick <player_id> <reason>Kicks a player by it's ID
map <map_path>Reloads all Packages and reconnect the Players in new Map
restartRestarts the server, reloading all Packages and reconnecting the Players
stopStops the server
playersLists all Players connected
password <new_password>Changes the server password
package run <package_name> <lua_code>Runs a code in a Package
package reload allReloads all Packages and restarts the Lua Virtual Machine
package reload <package_names...>Reloads Packages
package unload <package_names...>Unloads Packages
package load <package_names...>Loads Packages
package hotreload <package_names...>Reloads all files but keeps the memory as is

Commandes personnalisées​

It is possible to define custom commands as well, for that please refer to Console.RegisterCommand().

Command Line Parameters​

It is possible to override the Server Configuration with Command Line Parameters.

ParamètreType de valeurDescription
--namestringNom du serveur
--descriptionstringDescription du serveur
--logostringServer Logo (downloads the image in-memory)
--passwordstringMot de passe du serveur
--ipstringIP du serveur
--mapstringMap Ă  charger
--portnumber--http_port
--query_portnumberServer Query port
--announce0 or 1Si afficher le serveur dans la liste des serveurs
--game_modestringMode de jeu du serveur
--loading_screenstringÉcran de chargement du serveur
--packagesstring listPackages du serveur
--assetsstring listAssets du serveur
--tokenstringServer authorization token
--max_playersnumberNombre de joueurs autorisés
--dedicated_server0 or 1If to start as a Dedicated Server or P2P
--async_log0 or 1If to use async or sync logs (async provides better performance) - default is 1
--log_level1, 2 or 3If to use Normal, Debug or Verbose logs
--custom_settingstoml stringA list of Custom Settings to be passed to scripting in toml format
--compression0-9Définit le niveau de compression à utiliser dans certaines opérations de réseau - 0 le désactive, 1 est le plus rapide et 9 est le plus lent mais fournit le ratio de compression le plus élevé
--saveflagIf to save the passed parameters in Config.toml
--profilingflagActiver les logs de profilage pour le débogage
--auto_downloadflagTélécharger automatiquement les Packages et les Assets depuis le Vault si nécessaire
--use_vault_assets_leanflagOnly downloads the Asset Pack's .toml configuration files from Vault
--log_show_threadflagShows the current running thread of each outputted log
--enable_unsafe_libsflagEnables executing the methods os.execute, os.rename, os.remove, os.exit, os.getenv, os.tmpname, os.setlocale, dofile, loadfile and all io.* on server side (Caution: those methods may allow malicious operations to run on your server, make sure you know what you are doing)
tip

Flag Value Types don't require any argument, just pass the parameter like --parameter.

One-liner Server Configuration​

With Command Line Parameters and Command Line Interface (CLI), it is also possible to automate the full server installation, here's an example:

Shell/Linux
# Installs/Updates the server through SteamCMD
steamcmd +force_install_dir /home/nanos-world-server +login anonymous +app_update "1936830 -beta bleeding-edge" validate +quit

# Installs all needed Packages (this will install needed Assets as well)
./NanosWorldServer.sh --cli install package sandbox battlefield-kill-ui ts-fireworks-tools

# Starts the server with all configs set
./NanosWorldServer.sh --name "nanos world Amazing Sandbox" --description "Awesome Sandbox Server" --map "nanos-world::TestingMap" --game_mode "sandbox" --packages "battlefield-kill-ui,ts-fireworks-tools" --port 7777 --query_port 7778 --max_players 32 --logo "https://i.imgur.com/vnB8CB5.jpg"

Another shorter example:

Shell/Linux
# Starts the server with all configs set and auto downloads the packages and assets if needed
./NanosWorldServer.sh --name "nanos world Amazing Sandbox" --description "Awesome Sandbox Server" --map "nanos-world::TestingMap" --game_mode "sandbox" --packages "battlefield-kill-ui,ts-fireworks-tools" --port 7777 --query_port 7778 --max_players 32 --auto_download 1 --logo "https://i.imgur.com/vnB8CB5.jpg"

Messages et erreurs communs de la console​

Server Tick too/extreme high! Verify the server performance! Server got stuck for Xms...​

It means the server got stuck for X milliseconds. The warning (yellow) is not something to worry about, but too many messages in red could mean your server infrastructure is not that good or your scripting code is not that optimized.

Usually the server runs at 33 ticks per second (or the value configured at Config.toml), the server runs in an infinite loop in that frequency, and inside that loop all server operations are executed, such as receiving and sending network packets, triggering lua events, executing functions or callbacks, and so on.

If a single tick takes more than 33 milliseconds, this warning will appear up.

tip

In some shared VPS, this warning may appear up more frequently due how the VPS handles the scaling of it's machines, sometimes the provider may think your VPS is "idle" (due nanos world server using extremely low CPU) and may decrease your processing power, causing this warning show up as well.

Lua Stack Error: Should be X, is Y...​

This is an internal error and should not supposed to happen. Those are guards set around our Lua Scripting implementation to prevent bad things from happening. If this error appears it means a implementation bug happened. Please communicate immediately with the devs, and if possible how to reproduce that!

...Was it supposed to happen?​

Those FATAL errors usually shouldn't happen, if you experience any, please let us know.