A Raspberry Pi Minecraft server is a cost-effective way to have your very own private server with your friends or just for stuffing around on.
I have had mine running for quite some time now and haven’t come across too many problems. It is very important to know that this server will not be able to hold many people.
From my experience, anything over five people and the server will start to get a bit wonky. I found the optimal amount of people is only two to three, but this can be improved upon by tweaking the server.
We are also going to be using the spigot version of Minecraft as the default install didn’t work for me. I found that it will crash a lot, be laggy, and is very unstable. The official Java version may improve over time.
If you are looking for the Bedrock server, be sure to check out our Minecraft Bedrock server tutorial. It will take you through all the steps to setting it up correctly.
In this project, we will utilize Java, which should already be installed on Raspberry Pi OS. We will make a few changes to optimize the server for the Raspberry Pi 2, 3, 4, or 5. We will also set it up so you can access it on the web, and have it reboot if the Pi goes offline for any reason.
Equipment
Please find the equipment that I used for making this Raspberry Pi Minecraft server below.
Recommended
- Raspberry Pi ( Amazon | SunFounder )
- Micro SD Card ( Amazon | SunFounder )
- Ethernet Cable ( Amazon ) or Wi-Fi ( Amazon | SunFounder ) (I recommend using an ethernet for the best network performance)
- Power Supply ( Amazon | SunFounder )
- USB Keyboard ( Amazon | SunFounder )
- USB Mouse ( Amazon | SunFounder )
Optional
- HDMI Cable ( Amazon | SunFounder )
- Raspberry Pi Case ( Amazon | SunFounder )
Video Tutorial
If you want to see how to set up the server, then check out my video below. Otherwise, I have a detailed text explanation immediately below the video.
If you like the video, please make sure you subscribe or follow us on social media, so you are kept up to date.
Setting up the Raspberry Pi Minecraft Server
Firstly, we must install an operating system onto the Raspberry Pi. If you haven’t already done this, check out our awesome guide on installing Raspberry Pi OS. It will take you through all the steps that you will need to do.
In this tutorial, we will work entirely in the terminal. It is probably best we boot straight into the terminal so we can save on resources by not loading the GUI.
1. First, update operating system packages to the latest version by entering the following commands.
sudo apt update
sudo apt upgrade
2. Now, we will need to make a couple of changes in the config tool. Let’s bring the tool up by entering the following line.
sudo raspi-config
If you need more information regarding the raspi-config tool, please check out our guide.
3. Also, it is unlikely you want to boot into the desktop, so ensure the boot option is set to the CLI (Command Line Interface). This change will help give the server as much processing power as possible.
To change the boot option, select 1 System Options, and select Boot / Auto Login.
Select Console or Console Autologin.
4. Finally, enable SSH so we can access the Pi remotely if required, unless you already have it enabled.
To enable SSH, go to Interface Options. Next, Select I1 SSH. Lastly, answer <YES> to enable the SSH server.
5. Now go to <Finish> on the main screen and answer <YES> to the reboot question.
6. We will now want the IP address of our Pi for when we try to connect to our server. To get the Raspberry Pi IP address, enter the hostname command.
sudo hostname -I
To ensure the IP doesn’t change, you should set up setup a static IP address on the Raspberry Pi and your router.
7. Next, we need to make sure that Git and jq is installed. Otherwise, we will not be able to build the server.
Enter the following command to install the Git software as well as jq. jq allows us to easily interpret JSON data within the terminal.
sudo apt install git jq
8. By default, Java (17) should already be available on Raspberry Pi OS (Bookworm). However, if you wish to use the latest version of the Minecraft server, you will need to use a newer version than what is available.
To install a version of Java compatible with Minecraft 1.20.6 + (Java 21 or 22), please follow our installing Java guide.
9. Now, we will need the Minecraft server file, which we will create using a builder tool that Spigot supplies.
To get the tools, enter the following commands.
mkdir ~/minecraft
cd ~/minecraft
wget https://hub.spigotmc.org/jenkins/job/BuildTools/lastSuccessfulBuild/artifact/target/BuildTools.jar
10. Now we will want to run the build tools file, so it creates our Spigot server. It will take about 15 minutes to finish.
Change --rev latest
at the end of the command to get a different version. Don’t forget to change latest in the command to the version number you wish to download. For example, --rev 1.20.6
will download version 1.20.6.
java -Xmx1024M -jar BuildTools.jar --final-name server.jar --rev latest
Important: If you have a Raspberry Pi B+, B, or any variation before the Raspberry Pi 2, the build tools will likely fail. You will need to generate the spigot.jar on a more powerful computer instead.
11. To ensure the Spigot server successfully downloaded and saved, simply type ls
. You should see spigot-1.20.6.jar
. The filename may be different depending on the version you downloaded.
ls
Make sure you remain in the ~/minecraft
folder as we want all the server files to be created in here. If you start the server in a different folder, it will create the files there.
12. Now we are ready to launch the server. To do this, enter the following command. You may need to change the version number depending on what version you’re using e.g. spigot-1.20.6.jar
.
Raspberry Pi 1
java -Xms256M -Xmx496M -jar ~/minecraft/server.jar nogui
Raspberry Pi 2, 3, 4, or 5
java -Xms512M -Xmx1008M -jar ~/minecraft/server.jar nogui
With the 2GB and 4GB variants of the Raspberry Pi 4 or 5, you can increase the Xmx value even higher.
The server will stop straight away as we will need to agree to the Eula. You can do this by opening the Eula by typing the following command.
nano eula.txt
13. In here, change “false
” to “TRUE
“. Once done, save and exit by pressing CTRL + X, then Y.
14. Now relaunch the server. It will take a while to create a map, so give it about three to five minutes. If you ever reboot again, it will only take thirty seconds to load if the map has already been created.
15. The server should be running and accessible over the local network.
16. You might want to mod your user now so that you can use all the server commands when you log in. If we have it auto-boot on startup, accessing the server backend is slightly more difficult.
To mod your user, simply run the following command when the server has launched (Replacing username with your username).
op username
17. The Minecraft server on the Raspberry Pi will now be up and running fine, but you may want to do some optimizations to the server to make it run even better.
Connecting to the Minecraft Server
If you are on a local network, it should be pretty easy to connect to the Minecraft server running on the Raspberry Pi. To test it out, follow the steps below.
1. Load the Minecraft Java client on a computer within the same local network as the Pi. Ensure the version of the client matches the version of the server.
2. Go to multiplayer, and your server might appear in the local list. If it doesn’t, simply go to direct connect and enter the IP address we got earlier on the Pi using the hostname command.
hostname -I
3. If you want to allow access to the Minecraft server via the internet, you will need to set up port forwarding.
Assuming you want to learn how to do this, head over to my guide on setting up Raspberry Pi port forwarding. You will need to port forward the port 25565 (unless you change it in the server properties) to the IP of your Pi.
Configuring the Server
Here are a few tips for configuring the server and getting it up and running.
Optimizing the Minecraft Server
To get the most out of our Minecraft server on the Raspberry Pi, you can install a plugin to help optimize the performance.
There are many plugins that can help with performance or extend the server’s functionality. Simply use the wget command to download them to the Pi. Below is an example.
cd ~/minecraft/plugins
wget -O example.jar <example_plugin_url>
Editing the Minecraft Properties
You will probably want to know how to edit the server properties. This ability to edit is very important for optimizing the server and customizing it to how you want the server to be.
If you want more information for each of the server settings, you can find a good page on all the server properties here.
To enter the server properties, enter the following line.
sudo nano ~/minecraft/server.properties
Now, we will want to change a few settings to help optimize the performance of the server.
You can change these and other settings to whatever you like however you want, but keep in mind the Pi can’t handle too much processing.
view-distance=04
max-player=5
Boot on Startup
To have the server start on boot, we will need to do a few extra steps.
1. We will need to create a service for the Minecraft server so let’s start writing the service file by entering the command below.
sudo nano /lib/systemd/system/minecraftserver.service
2. In this file you will need to enter the following text.
This file defines the service, so the service manager knows how and what to run. Don’t forget to update the spigot version number whenever you upgrade.
Update “<USER>
” with the username you plan on using to run the server. You can see the username of your user by entering the whoami command into the terminal.
[Unit]
Description=Minecraft Spigot Server
[Service]
User=<USER>
Group=<USER>
Restart=on-abort
WorkingDirectory=/home/<USER>/minecraft/
ExecStart=/usr/bin/java -Xms512M -Xmx1008M -jar /home/<USER>/minecraft/server.jar nogui
[Install]
WantedBy=multi-user.target
Once done, save the file by pressing CTRL + X then Y followed by ENTER.
3. Now, we will need to enable the service. You can enable the service by running the command below.
sudo systemctl enable minecraftserver.service
4. You should now be able to start the Minecraft server by simply using the following command.
sudo systemctl start minecraftserver.service
5. Using a similar command, you can check on the status of the service. Checking the status is great for debugging.
sudo systemctl status minecraftserver.service
5. You can stop the server by using the following command.
sudo systemctl stop minecraftserver.service
Your server should now start on boot. You can test it by restarting the Raspberry Pi. It will take a few minutes to startup.
sudo reboot
If you want to get access to the server on the command line, then you will need to shut down the server and load it using the normal command.
Updating your Minecraft Server on the Raspberry Pi
In this section, we will be showing you how to update to the latest version of the Minecraft server on your Raspberry Pi.
1. Before we can begin to update the Minecraft server, we will need to change to the directory where the server is stored.
If you have followed our tutorial, this means you should be able to change to the correct place by running the command below.
cd ~/minecraft/
2. The first thing we will want to do now that we are in the right place is ensure we have the latest version of the Spigot build tools.
We can use the wget command to download the latest release by using the following in the terminal.
wget https://hub.spigotmc.org/jenkins/job/BuildTools/lastSuccessfulBuild/artifact/target/BuildTools.jar
3. With the build tools updated, we can now grab the version number for the latest version of the Minecraft server by using the following command.
If you have a particular version of the Minecraft server, you want to use on your Raspberry Pi replace the command with that here. Otherwise, we can use a bit of curl and jq magic to get the version number we are after.
MINECRAFT_VERSION=$(curl -sS https://launchermeta.mojang.com/mc/game/version_manifest.json | jq -r '{latest: .latest.release} | .[]')
4. Once you have got your version number saved to the environment variable we can proceed.
Before we can update the Minecraft server on our Raspberry Pi, we will need to stop the current one from running. You can stop the running server by running the command below.
sudo systemctl stop minecraftserver
5. Now use the Spigot build tools to download and update you Minecraft server to the latest version.
Please note that this process can take a couple of minutes to complete.
java -Xmx1024M -jar BuildTools.jar --final-name server.jar --rev $MINECRAFT_VERSION
6. Once the update process completes, you can start the server up by using the following command.
sudo systemctl start minecraftserver
Conclusion
I hope this tutorial has helped you in setting up a stable version of a Raspberry Pi Minecraft server. If you like this tutorial, then be sure to check out our many other Raspberry Pi Projects.
Also, feel free to drop us a comment below if you have better optimization settings, plugins, or ideas. If you’re having trouble, let us know below.
I used this guide a while ago and it worked really well, but for chirstmas my mom finally got Minecraft. She set up a single player world and made a lot of progress, but wants me to join. Is there any way to take single-player save data and have my server run that? The goal is to pick up where she left off in the pi server, not just use the seed. Thank you!
Hey Diana,
Here are some steps to get to the folder that contains the world data that you are after.
1. Firstly open up the Minecraft Launcher on your computer.
2. Launch the latest version of Minecraft.
3. Press the “Options” button.
4. In the bottom left press the “Resource Packs” button.
5. Press “Open resource pack folder”
6. A folder should open. Go up one folder, if you are on windows pressing ALT + Up arrow key, should do the trick.
7. This is the “.minecraft” folder
8. Open the “saves” folder.
9. Here are all your Minecraft world folders, you can then get her to zip that folder up and send it over to you.
Hopefully that helps you get your Raspberry Pi Minecraft server up and running with her world data.
Cheers
Thank you, Gus! But I guess I was not clear-cut I don’t know how to put the current save data into the pi server. I had no problem finding it, thanks to your instruction, but I don’t know how to run it on the pi. Using FileZilla I found the location the original pi server world was in, but since new save data is not labeled “world/world nether/world the end” the way a world is when you make it on the pi server, I don’t know if a simple drag-and-drop would work.
Hi Diana,
Do you mind showing us the structure of new save data? As far as I know they should be cross compatible.
Cheers
Hi,
Can someone please leave a step by step tutorial how to update java, (if necessary) buildtools and spigot after this general tutorial, please? I try to this myself somehow, but I’m neither Linux user nor nerdy enough to fix this problem myself, but installed the MC server on my son’s RPI and he asks me every couple of months if there’s anything new on MC and if it’s already implemented on the server version.
Next is: I will move with the server within the next couple of weeks to an Mini ATX PC I want to run on linux. How to get the world from the RPI server moved to the ATX, what should I have to take care of about the ATX in general for a MC server base?
Lots of questions, I know. Sorry.
Hey The Dirkness,
Running
sudo apt-get update
andsudo apt-get upgrade
on Raspbian will ensure that you are running the latest version of Java on your Raspberry Pi.Updating Spigot should be simple as running through Step 9 and Step 10 of this tutorial again. You should rename the existing file to something else to keep it as a backup just in case.
If you intend on moving your Minecraft server across the main files you will want to ensure is copied over is the “world” folder as that contains the player data and the world block data.
Cheers
Hello,
How could I change the map to a pre-made one for the server?
Hey, first of all can I just say I love all the tutorials and all the lines of code to copy and paste incredibly helpful. I was wondering how to run the server with my own custom map?
Hi! You will find a “World” folder. Sometimes it is in /home/pi, or /home/minecraft. Replace the files in “World” with the files of the map that you would like to put onto your server. Just make sure to keep the name the same!
I am stuck on running Buildtools.jar. Keep getting out of memory error (heap space), e.g., Exception in thread “main”
java.lang.OutOfMemoryError: Java heap space
at org.objectweb.asm.tree.MethodNode.visitFrame(MethodNode.java:416)
Googling helped me increase the heap size as much as I could (before getting an invalid parameter error). I ran the command:
sudo java -Xms500m -Xmx2900m -jar BuildTools.jar
I’m running on a model B with 16GB SD card. How can I get past this memory issue? Is anyone successfully running on a model B?
TIA.
Followed the instructions, no errors what-so-ever. Server is starting, without warnings / errors, but i cannot connect to it from my iPhone (where minecraft is installed).
It seems i cannot reach port 25565. Any suggestions?
Thank you for this tutorial!
I have some problems with step 10. After using the following command “sudo java -jar BuildTools.jar” I get a lot of messages and the last message I get is “Final mapped jar: work/mapped.1ea8a6ae.jar does not exist, creating!” and it seems to be stuck at this point.
Does someone know how to fix this problem?
Problem might be solved.
After waiting for a few hours it is not stuck anymore.
This is an amazing way to use your raspbery pi.
Worked, all good, no problems.
Nice job dude:)
Hi Gus, thanks for the awesome tutorial. I’ve had a server up and running for a couple of months now with no problems. I was wondering how I can upgrade the mc version to 1.12 without overwriting my existing world? Is that possible?
Thanks in advance for any suggestions.
Hi so my pi is outputting an error when i attempt to start the server
Exception in thread “main” java.lang.UnsupportedClassVersionError: org/bukkit/craftbukkit/Main : Unsupported major.minor version 52.0
and i’m attempting to start it from a .sh file and the contents of that is
sudo java -Xms256M -Xmx496M -jar spigot.jar nogui
i’m on a raspberry pi zero running jessie lite with pixel installed. help is very appreciated
Sounds like an issue with java, have you tried running
sudo apt-get update
and thensudo apt-get upgrade
Sorry i meant to comment earlier; i figured it out and it turns out that installing java8 did not update the default java path from openjdk7 to oraclejava8.
When I try Step 9, it ends with a message saying ERROR 503: service unavailable, how do I avoid this problem, It also doesn’t allow further steps to be completed.
It appears java.net is no longer available, I have removed these steps. You should be able to continue the tutorial unless you’re on Raspbian Wheezy, if so I highly recommend updating to Jessie.
I am running a raspberry pi 3, and it appears the server is running, but, when i try to connect to it with a minecraft client i get
“Failed to connect to server”
“Outdated server, I’m still on 1.9”
Back to server list
how do i update the spigot to match my client version, and how to tell what version my client is running?
Now i get
java.net.ConnectException: Connection refused: No further information
Run the build tools with the following line to get the latest:
java -jar BuildTools.jar --rev 1.12
or you can download the latest build here:
https://pimylifeup.com/out/spigotlatestbuild
Are you still getting connection refused, I tested the latest and it appears to be working fine on my copy.
io.netty.channel.abstractchannel$annotatedconnectexception: Connection refused: no further information
i get this now
Thank You So Much Gus, This server tutorial was by far the easiest thing to do.
I only have one problem-I can’t download the add-on, nospawnchunks, or any other add-on. I used the code you used, but it gives me an error 404-not found
If you could help me on this, I would really appreciate it
~Thanks!
Hi Joseph,
I have fixed the 404 issue, should be able to download it again. The download URL is different now so make sure you copy and paste the new command.
How do I add people to the whitelist?
Hi Gus,
I noticed if I unplug power from my Pi the world doesn’t save. If I attach a USB or hard drive to it will it save my world?
Is there any command i can run to update the whole server to the latest without losing data?
Understand if this isn’t possible.
Thanks
Hello everyone. If you don’t want to port forward then I recommend you guys try ngrok you can use it on the pi by downloading linux version enjoy and good luck trying to fix it.
Hey Gus,
My son and I did the 1.9 install, but MC is up to 1.11.2 now and it won’t connect to the server. How do we go about updating the server from 1.9 to 1.11.2.
Thanks! This has been a lot of fun.
Hi Chris,
The upgrade process is as followed.
1) Stop/Shutdown the server.
2) Backup the server folder, something like this should do the trick.
sudo tar -cpvzf /home/minecraft.tar.gz /home/minecraft/
It will add everything within the minecraft into a tar file that you can untar later if required.
3) You can now run the build tools with 1.11.2 as a parameter. eg.
sudo java -jar BuildTools.jar --rev 1.11.2
Alternatively you can also find the latest version for download at:
https://pimylifeup.com/out/spigotlatestbuild
4) Once you have downloaded the new version, simply run the new server file and it should now be running on the latest version. You might want to double check any extra scripts you have to ensure they point to the new server file.
Thank you, Gus. We had trouble with errors trying to upgrade the server so we just blew it away and did a fresh install with the new version. I sat back and let my son fight it out from loading Raspbian on the SD card to installing the server , forcing him to learn a ton in the process. The look on his face when I was able to connect to the server the first time was PRICELESS!! He’s 13 and I’m trying to gently push him into IT. Hopefully this will help. Thanks again for all you do.
Ok so i get the java installed then i got the build tools and i don’t know what command I use to run the build tools. i tried your way and this is what it said: pi@raspberrypi:/home/minecraft $ sudo java -jar BuildTools.jar
sudo: java: command not found
what do i do.
I am using a raspberry pi 3 model B.
please help
If you installed java manually you will need to place
/opt/jdk1.8.8_60/bin/
beforejava
in the command for it to work correctly. Eg.sudo /opt/jdk1.8.8_60/bin/java -jar BuildTools.jar
Hope that helps, let me know if you’re still having trouble.
Sooo it says the command is not found. Please help.
This is what it says when i try the command:
pi@raspberrypi:~ $ sudo /opt/jdk1.8.8_60/bin/java -jar BuildTools.jar
sudo: /opt/jdk1.8.8_60/bin/java: command not found
I got a “java.io.FileNotFoundException” when launching the spigot server. If anybody else is having this problem, know that running it with sudo seemed to solve this issue.