Difference between revisions of "Setting up a server"
m (→Windows) |
ROllerozxa (talk | contribs) |
||
Line 3: | Line 3: | ||
== Choosing Hardware == | == Choosing Hardware == | ||
− | It's recommended that you use a VPS or dedicated server to host a game server which you want to make publicly available. | + | It's recommended that you use a VPS or dedicated server to host a game server which you want to make publicly available. Residential Internet connections tend to be unreliable and also have less upload speed. You may also not be able to keep a server online 24/7 when hosting from home. |
− | Residential Internet connections tend to be unreliable and also have less upload speed. You may also not be able to keep | ||
− | a server online 24/7 when hosting from home. | ||
− | That being said, hosting from home will work fine if you have some hardware you can keep online, and you have a good | + | That being said, hosting from home will work fine if you have some hardware you can keep online, and you have a good enough Internet connection. Keep in mind that if you are behind CG-NAT, you are unable to host a public server as it won't be accessible to the wider internet. (check with your ISP if unsure) |
− | enough Internet connection. | ||
Whilst you can host a server through the Minetest client - and this is fine for LAN games - you'll want to host | Whilst you can host a server through the Minetest client - and this is fine for LAN games - you'll want to host | ||
Line 16: | Line 13: | ||
=== Linux === | === Linux === | ||
+ | If you are going to be running a Minetest server on a non-headless system, using the regular <code>minetest</code> binary with the <code>--server</code> argument works the same as <code>minetestserver</code>. If you are on a headless Linux system without a graphical environment <code>minetestserver</code> is recommended as it is smaller and does not have dependencies unnecessary for a server. | ||
− | #Open a terminal. | + | # Open a terminal. |
− | #Type in <code>YOUR/MINETEST/DIRECTORY/bin/minetestserver</code> or just drop the minetestserver executable (located in <code>/Minetest/bin/</code>) into the terminal '''(PLEASE READ THE NOTES BELOW!)''' | + | # Type in <code>YOUR/MINETEST/DIRECTORY/bin/minetestserver</code> or just drop the minetestserver executable (located in <code>/Minetest/bin/</code>) into the terminal '''(PLEASE READ THE NOTES BELOW!)''' |
− | #*If you want to specify a specific game ID, the game ID choices are located in <code>/Minetest/games/</code>. Add in <code>--gameid '''thegameid'''</code> to the end of the command. | + | #* If you want to specify a specific game ID, the game ID choices are located in <code>/Minetest/games/</code>. Add in <code>--gameid '''thegameid'''</code> to the end of the command. |
− | #*If you get the error “Multiple worlds are available.”, the world choices are located in <code>/Minetest/worlds/</code>. Add in <code>--worldname '''theWorld'''</code> to the end of the command. | + | #* If you get the error “Multiple worlds are available.”, the world choices are located in <code>/Minetest/worlds/</code>. Add in <code>--worldname '''theWorld'''</code> to the end of the command. |
− | #If your server crashes, then look at the <code>debug.txt</code> in <code>/Minetest/bin/</code> | + | # If your server crashes, then look at the <code>debug.txt</code> in <code>/Minetest/bin/</code> |
− | #Make sure you make your server [[#Protecting your server|safe from damage]]. | + | # Make sure you make your server [[#Protecting your server|safe from damage]]. |
For easy use you can create an file named minetestserver.sh, add the lines below and put it in your /Minetest/bin/ folder. To run the server, just run the file in a terminal. | For easy use you can create an file named minetestserver.sh, add the lines below and put it in your /Minetest/bin/ folder. To run the server, just run the file in a terminal. | ||
Line 31: | Line 29: | ||
do | do | ||
./minetestserver --gameid minetest --worldname world | ./minetestserver --gameid minetest --worldname world | ||
− | sleep | + | sleep 5 |
done | done | ||
=== Windows === | === Windows === | ||
− | + | # Open command prompt by going in the Minetest installation folder. Then in the “bin” folder, click the blue "File" icon in the top left of the screen. In the drop down menu click “Open Windows Powershell here”. | |
− | #Open command prompt by going in the Minetest installation folder. Then in the “bin” folder, click the blue "File" icon in the top left of the screen. In the drop down menu click “Open Windows Powershell here”. | + | # Type this: <code>.\minetest.exe --server</code>. |
− | #Type this: <code>minetest.exe --server</code>. | + | #* If you get the error “Multiple worlds are available.”, use <code>.\minetest.exe --server --worldname '''world_name'''</code> instead, where <code>'''world_name'''</code> is the name of the world. |
− | #*If you get the error “Multiple worlds are available.”, use <code>minetest.exe --server --worldname '''world_name'''</code> instead, where <code>'''world_name'''</code> is the name of the world. | + | # If your server crashes, then look at the <code>debug.txt</code> in <code>/Minetest/bin/</code> |
− | #If your server crashes, then look at the <code>debug.txt</code> in <code>/Minetest/bin/</code> | + | # Make sure you make your server [[#Protecting your server|safe from damage]]. |
− | #Make sure you make your server [[#Protecting your server|safe from damage]]. | ||
If you don't like to start the crashed server, simply start the server out of a batch file which contains the following code: | If you don't like to start the crashed server, simply start the server out of a batch file which contains the following code: | ||
Line 51: | Line 48: | ||
== Allowing external players to connect == | == Allowing external players to connect == | ||
− | + | If you are self-hosting a server you will usually need to port forward the server in your router for it to be accessible to the outside internet. | |
#Choose a port to run the server on. The default of 30000 is recommended | #Choose a port to run the server on. The default of 30000 is recommended |
Revision as of 15:41, 6 December 2022
Language: | English |
---|
Choosing Hardware
It's recommended that you use a VPS or dedicated server to host a game server which you want to make publicly available. Residential Internet connections tend to be unreliable and also have less upload speed. You may also not be able to keep a server online 24/7 when hosting from home.
That being said, hosting from home will work fine if you have some hardware you can keep online, and you have a good enough Internet connection. Keep in mind that if you are behind CG-NAT, you are unable to host a public server as it won't be accessible to the wider internet. (check with your ISP if unsure)
Whilst you can host a server through the Minetest client - and this is fine for LAN games - you'll want to host a public server using the Minetest dedicated server mode.
Running the Server
Linux
If you are going to be running a Minetest server on a non-headless system, using the regular minetest
binary with the --server
argument works the same as minetestserver
. If you are on a headless Linux system without a graphical environment minetestserver
is recommended as it is smaller and does not have dependencies unnecessary for a server.
- Open a terminal.
- Type in
YOUR/MINETEST/DIRECTORY/bin/minetestserver
or just drop the minetestserver executable (located in/Minetest/bin/
) into the terminal (PLEASE READ THE NOTES BELOW!)- If you want to specify a specific game ID, the game ID choices are located in
/Minetest/games/
. Add in--gameid thegameid
to the end of the command. - If you get the error “Multiple worlds are available.”, the world choices are located in
/Minetest/worlds/
. Add in--worldname theWorld
to the end of the command.
- If you want to specify a specific game ID, the game ID choices are located in
- If your server crashes, then look at the
debug.txt
in/Minetest/bin/
- Make sure you make your server safe from damage.
For easy use you can create an file named minetestserver.sh, add the lines below and put it in your /Minetest/bin/ folder. To run the server, just run the file in a terminal.
#!/bin/bash while true do ./minetestserver --gameid minetest --worldname world sleep 5 done
Windows
- Open command prompt by going in the Minetest installation folder. Then in the “bin” folder, click the blue "File" icon in the top left of the screen. In the drop down menu click “Open Windows Powershell here”.
- Type this:
.\minetest.exe --server
.- If you get the error “Multiple worlds are available.”, use
.\minetest.exe --server --worldname world_name
instead, whereworld_name
is the name of the world.
- If you get the error “Multiple worlds are available.”, use
- If your server crashes, then look at the
debug.txt
in/Minetest/bin/
- Make sure you make your server safe from damage.
If you don't like to start the crashed server, simply start the server out of a batch file which contains the following code:
@echo off :crash minetest.exe --server --worldname world_name goto crash
Allowing external players to connect
If you are self-hosting a server you will usually need to port forward the server in your router for it to be accessible to the outside internet.
- Choose a port to run the server on. The default of 30000 is recommended
- Find out your internal IP of the computer you are running the server on
- Linux: open a terminal and type
ifconfig
and hit enter. Look for "inet adr" near "wlan0" or "eth0". - Windows
- Open command prompt: Start → Run …, enter
cmd.exe
and hit enter. - Type
ipconfig
and hit enter. - Look for
IPv4 Address
.
- Open command prompt: Start → Run …, enter
- macOS: Open the command prompt and enter netstat -nr.
- Linux: open a terminal and type
- Login to your router, and port forward UDP on your chosen port to the internal IP you found
- Alter any firewalls you may have to allow traffic to the port you choose
- Make your server listed in the server list by setting the following settings in minetest.conf
server_announce = true
- makes Minetest tell the server list about the server.server_name
- set the value of this to your server's name.server_description
- set the value of this to a longer description describing your server.server_address
- if you have a domain name for your server, then set this to the domain name (how to get a domain name if you want one for your server).server_url
- if you have a website for your server, then set this to the website URL.motd
- a message that is sent to the player when they join. Use this to welcome them.- You should restart the server to make sure any changed settings changed
Protecting your server
Protecting the Minetest world/server
When setting up a new server, you should consider which protections are needed. This is extremely important for public servers, because you cannot predict who will connect or what they will do on your server.
Common problems include:
- Accidental or intentional damage to other players' work (griefing).
- Chat spam (may include swearing or advertisements).
- Aggression, harassment or other unwanted behaviours between players.
- Trouble makers who evade bans.
- Impersonation of well known people within the MT community.
- Bugs, for example caused by mods, which allow a malicious player to execute arbitrary system commands.
Many of these problems can be removed or minimised by advanced planning and awareness:
- Install a protection mod, such as areas or protectors. These allow players to protect areas. Protected areas cannot be changed by other players.
- Enable rollback by adding
enable_rollback = true
to minetest.conf. Rollback can tell you which player placed a node, and allows a player's actions to be reverted. - Install a mod to help you manage bans, such as xban2.
- Create rules for your server and make sure you have enough time (or a team of moderators) to supervise your server and watch for players who breaks your rules.
- Never grant privileges to a player just because they use a name you recognise. Player names are not reserved between servers, so you should always confirm who the player is.
- Install and configure a chat filter mod like filter, to prevent swearing and/or sexual chat. This is useful to inform players of the rules rather than actual enforcement, as working around filters is fairly easy.
Note that tnt and fire spreading, which are both enabled by default in singleplayer, are disabled by default on servers.
See Server Moderation and Tools on ContentDB.
Protecting the host machine
- Standard advice on Linux/Windows server security applies.
- On Linux you can add a dedicated user for running the minetest server.
- Never, ever, disable mod security.
- Make sure you trust mods you add to secure.trusted_mods
Managing your server
Server Configuration
For a detailed explanation of the server configuration file, see the minetest.conf page.
You may also want to consider to use a different database backend for your world.
Server Commands
See the Server commands page for a list of useful commands.
Also see Itemstrings for the itemstrings for use with the /give
and /giveme
commands.
Privilege System
See the privileges page for detailed information on the privilege system.
See also
- Setting up a Debian server page for more Debian (Ubuntu) related information.
- For more possible commands study the Command line page.
- The "Illustrated Server Creation Guide" forum thread contains interesting discussion.
- See this forum thread for more information about "How to create and maintain a server - Windows"
- See this forum thread for "Server performance settings"