- Description
- Installation
- Requirements
- Examples of installation
- Add or disable mods
- Start/Stop the server
- Update the server
Description
The files to install the Minetest NALC server.
Installation
Start the install.sh script and follow instructions.
  Help: ./install.sh --help
Requirements
- Official Minetest server must already be installed on your GNU/Linux system. If it is not the case, please refers to the https://minetest.net website for the installation instructions.
- You'll also need 'git', and optionaly 'cmake' and 'make' programs installed.
Examples of installation
For a production server intended to be publicly available
We suppose that you have already installed Minetest server from your package manager.
   The home of the 'minetest' user is located to /var/lib/minetest and you have the write access to it.
- Create the dir /var/lib/minetest/.minetestif not exist.
- cd /var/lib/minetest
- git clone --depth 1 https://sys4.fr/gitea/nalc/nalc-server.git
- cd nalc-server
- ./install.sh -d /var/lib/minetest/.minetest
- Follow the instructions
For a test server
We suppose you have already installed a production server that is actually in use and stable. But now you want to install another server in parallel on the same system in order to test the development version of NALC.
For the next steps we will be logged in as a normal user:
- cd
- Create the dir ~/.minetestif it not exist.
- No need to download the server files again because they are already downloaded in the dir /var/lib/minetest/nalc-server. So you can just do amkdir ~/nalc-dev. But you can always do agit clone https://sys4.fr/gitea/nalc/nalc-server.git ~/nalc-devif you prefer. Whatever your choice and for the next steps we will refer to the install dir as$SCRIPT_DIR.
- $SCRIPT_DIR/install.sh -d ~/.minetest -w test -P 30001 --branch dev ~/nalc-dev
- Follow the instructions
Case of a custom Minetest installation
We suppose you have compiled Minetest from sources with the CMAKE option RUN_IN_PLACE=TRUE. The location of your installation is ~/games/minetest.
- cd ~/games
- git clone https://sys4.fr/gitea/nalc/nalc-server.git
- cd nalc-server
- ./install.sh -b ~/games/minetest/bin/minetestserver -d ~/games/minetest
- Follow the instructions
Other cases
Other combinations are possible and I cannot describe all of them. Don't hesitate to read the help of the script with --help option and do your own tests :)
Add or disable mods
- If you want to add mods you can do it easily.
For that you can create the dir $DESTINATION/custom/mods where $DESTINATION is the dir where you have installed the server (the one containing the nalc.conf file).
  Then copy your mods and modpacks in $DESTINATION/custom/mods and you need to execute $INSTALL/upgrade.sh -s $DESTINATION -w <world> -b <version> -f worldmt for regenerating the world.mt file of your world.
  Replace <world> by your world name.
  Replace <version> by the branch name specified during the installation, either 'stable', 'dev' or 'exp'.
- If you want to disable mods you need to edit the file $DESTINATION/mods_disabled.txtand add one mod name per line.
Then execute again $INSTALL/upgrade.sh -s $DESTINATION -w <world> -b <version> -f worldmt.
  Note: Depending on how you have installed NALC server, but $INSTALL and $DESTINATION can point to the same directory. If it's the case you can ommit the -s option.
Start/Stop the server
Use provided scripts
You can rename the $SCRIPT_DIR/start.sh.example file to start.sh and give it exe permissions.
   Then launch the server with the command $SCRIPT_DIR/start.sh -s $DESTINATION.
   Note: -s option can be ommited if you launch the script from the dir $DESTINATION.
   For shutting down the server press CTRL-C.
   You can edit the start.sh script for your needs.
Use openrc to start/stop NALC as a daemon
We suppose minetest is installed from portage with the +server USE flag and NALC server is installed in the home of the minetest user /var/lib/minetest/nalc-server. If you would use your Gentoo/Calculate Linux system run init to start/stop NALC server as a service then you can follow theses steps:
- 
Edit your /etc/conf.d/minetest-serverfile like that:# /etc/conf.d/minetest-server: config file for /etc/init.d/minetest-server # user USER="minetest" # group GROUP="minetest" # pidfile PIDFILE="/run/minetest-server.pid" # executable MINETESTBIN="/usr/bin/minetestserver" # additional arguments for the server ARGS="--logfile /var/log/minetest/minetest-server.log"
- 
Edit or create the file /etc/init.d/minetest-server:#!/sbin/openrc-run # Copyright 1999-2019 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 supervisor="supervise-daemon" description="Minetest dedicated server" depend() { need net postgresql-13 # Remove postgresql-13 if you don't use it as a Minetest backend. } start() { ebegin "starting Minetest server" ${supervisor} ${RC_SVCNAME} \ --pidfile "${PIDFILE}" \ --user ${USER} \ --group ${GROUP} \ --start "${MINETESTBIN}" -- ${ARGS} eend $? } stop() { ebegin "stopping Minetest server" ${supervisor} ${RC_SVCNAME} \ --stop \ --signal 15 \ --pidfile "${PIDFILE}" \ --user ${USER} \ --group ${GROUP} eend $? }
- Add the service to your default init run level: rc-update add minetest-server default.
- Start the service: rc-service minetest-server start.
- Stop the service: rc-service minetest-server stop.
TODO Use systemd to start/stop NALC as a daemon
Update the server
You can execute the install.sh script again. If a nalc.conf file is detected in the specified destination, all the settings specified during the previous installation will be loaded.
Then you have to follow the instructions of the script and you will be able to update your server.