Setting up a Minecraft Bedrock Server on Ubuntu

In this tutorial, we will be s showing you how to set up a Minecraft bedrock server on Ubuntu.

Ubuntu Minecraft Bedrock Server

Minecraft comes in two different flavors. One is the Java edition which is purely on PC. The other is the bedrock edition, which runs across multiple consoles, mobile devices, and Windows PCs.

A server for the Java edition of Minecraft on Ubuntu won’t work for those who are using the bedrock edition.

In this guide, we will show you how you can install the official Minecraft Bedrock server on Ubuntu. Having the official server means you will have the best compatibility with the latest versions.

The following steps will by using the terminal to install and set up this server. Don’t worry, as using the terminal is very straightforward. So before proceeding, make sure you open up the terminal on your Ubuntu device.

If you are using a desktop flavor of Ubuntu, open the terminal by pressing CTRL + ALT + T on your keyboard.

Additionally, you will need access to a user with superuser privileges on your system. Alternatively you can use the root user, however, that is unrecommended.

Video

If you prefer a video guide, be sure to check out our embedded video on installing and setting up a Minecraft Bedrock Server below. Of course, if you like our written guides, be sure to continue on reading.

Preparing Ubuntu for your Minecraft Bedrock Server

Before we install the Minecraft bedrock server to the Ubuntu operating system, we need to complete a couple of tasks.

These tasks ensure we have all the packages we need to download and install the server.

1. Our first step is to ensure our package list is up to date. Before installing any packages, it is usually good practice to ensure this is up to date.

To update the package list, you must use the following command in the terminal.

sudo apt update

Since we are using “sudo“, you will be prompted to enter the password for your Ubuntu user. Type in your password and press the “ENTER” key to continue.

2. Once the package list has been updated, we can install all the software we need to install and run the Minecraft Bedrock Server on Ubuntu.

To install all the needed software, run the following command within the console.

sudo apt install curl wget unzip grep screen openssl -y

If you are interested, let us quickly run through what we are using each of these packages for

  • curl – We use CURL to grab the server download page from Minecraft.net. With this page, we can scan it and make sure we are grabbing the latest download link.

    This saves time by ensuring the latest version is always downloaded.
  • wget – The wget package is what we will use to download the Minecraft Bedrock server to Ubuntu.
  • unzip – This package is the simplest package we are installing and is what we need to extract the server from the downloaded archive.
  • grep – We use the grep package to extract the correct download link from the page we grabbed using curl.
  • screen – Screen will make accessing the servers command line easier remotely when we run the server as a service.

    This package allows us to create a detached screen where the Bedrock server will run.
  • openssl – The Minecraft Bedrock server requires the OpenSSL library to run.

3. We also need to install an older version of libssl that, at the time of publishing, the Minecraft Bedrock server requires.

We can download this older version straight from the Ubuntu archive to our device using wget, as shown below.

wget http://archive.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_amd64.deb -O libssl1.1.deb

4. With the “libssl1.1” package downloaded, we need to install the package to our operating system.

Installing the package is as straightforward as running the following command.

sudo dpkg -i libssl1.1.deb

5. Once the required version of the libssl package has been installed, we can safely delete the original “.deb” file we downloaded previously.

You can use the rm command to remove this file from the Ubuntu operating system.

rm libssl1.1.deb

6. We can now create a user that we will run the Minecraft bedrock server under. It is an important step as it is typically good practice to help isolate one program from another.

Using the useradd command, we will create a user called “mcserver“. By using the “-m” option we will create a home directory for this user.

sudo useradd -m mcserver

7. Next, we can use the usermod command to add our new users group to the current user.

This will allow you to easily access and edit files within the new users home directory.

sudo usermod -a -G mcserver $USER

8. As we made changes to our users groups, you will need to log out and log back in to refresh the users privileges.

You can log out of Ubuntu easily by using the following command in the terminal.

logout

9. Our next step is to create a directory where we will be storing the server itself. We will call this directory “minecraft_bedrock” and create it within our new users directory.

Create this directory using the following mkdir command within the terminal.

sudo mkdir -p /home/mcserver/minecraft_bedrock

10. You should now have everything you need to install the Minecraft bedrock server on Ubuntu, so we can move on to installing it.

Installing the Minecraft Bedrock Server on Ubuntu

Now that we have everything we need, we can download and install the Minecraft Bedrock server to the Ubuntu operating system.

1. Before you continue, you must agree to the Minecraft End User License Agreement and the Microsoft Privacy Policy.

These are the terms and conditions that you must abide by when using any Minecraft product, including the Bedrock server.

2. We start this guide by grabbing the download URL for the Minecraft Bedrock server.

To retrieve this download URL from the official website, use the following command within the terminal.

DOWNLOAD_URL=$(curl -H "Accept-Encoding: identity" -H "Accept-Language: en" -s -L -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; BEDROCK-UPDATER)" https://minecraft.net/en-us/download/server/bedrock/ |  grep -o 'https.*/bin-linux/.*.zip')

This command uses curl to grab the Minecraft Bedrock server download page, which is piped (| pipe symbol) to the grep command, which filters the page for the download URL.

3. Now, we can use the following command to download the Minecraft Bedrock server to our Ubuntu device.

To download this file, we will be using the wget command, followed by the “DOWNLOAD_URL” variable that contains the link to the bedrock server.

sudo wget -U "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; BEDROCK-UPDATER)" $DOWNLOAD_URL -O /home/mcserver/minecraft_bedrock/bedrock-server.zip

Using the “-O” option, we are telling wget to save the file as “bedrock-server.zip” within the directory we created earlier.

4. Once the Bedrock server has been downloaded to Ubuntu, we will need to extract the archive.

Extract this archive by using the following unzip command within the terminal

sudo unzip /home/mcserver/minecraft_bedrock/bedrock-server.zip -d /home/mcserver/minecraft_bedrock/

5. With the server now extracted, our last installation task is to clean up some of our mess.

All you need to do is use the following command to delete the archive we just extracted.

sudo rm /home/mcserver/minecraft_bedrock/bedrock-server.zip

6. Our final task is to make sure our “mcserver” user has ownership over all of these files.

We can achieve this by using the following command.

sudo chown -R mcserver: /home/mcserver/

Configuring your Minecraft Bedrock Server

With the Minecraft Bedrock server now installed on Ubuntu you may want to configure it before starting.

Using the configuration file, you can adjust a variety of settings. This includes setting the seed, game mode, difficulty, and more.

If you want to verify that the server works, skip to the next section.

1. Within the terminal, you will want to run the following command to begin editing the “server.properties” file.

We will be using the nano text editor as it is a fairly simplistic terminal text editor.

sudo nano /home/mcserver/minecraft_bedrock/server.properties

2. Now, within this file, you will find a ton of options. We will only run through a few of the options available to you.

You can find each of these options by using the search shortcut by pressing CTRL + W, followed by the search phrase, then the ENTER key.

server-name=Dedicated server

With this option, you can control the name of your server. For example, we could use this to set our server name to “Pimylifeup Ubuntu Bedrock Server“.

gamemode=survival

Using this option, you can set the game mode your Ubuntu Minecraft Bedrock server will use.

You have three different options that you can use here “survival“, “creative“, or “adventure“.

difficulty=easy

You can also tweak how difficult the world would be. By default, this option is set to easy.

There are four options that you can use here, with those being “peaceful“, “easy“, “normal“, or “hard“.

max-players=10

You can also control the maximum number of players on your Bedrock server at any one time.

allow-list=false

This option allows you to restrict your Ubuntu Bedrock Minecraft server so only allowed users can connect.

A player must be specified within the “allowlist.json” file to connect.

view-distance=32

Using this option you can configure how many chunks the player can see in front of them. Of course, increasing the number of chunks will increase the load on your server.

The view distance has a minimum value of 5.

tick-distance=4

With this option, you can control how far away a chunk can be from a player and still be ticked. Changing this distance can affect how your Redstone circuits work.

You can set this option to any number between 4 and 12.

player-idle-timeout=30

With this option, you can control how long a player can be idle within your Minecraft Bedrock world before being kicked.

If you set this option to 0, players will never be kicked from the server.

level-name=Bedrock level

You can use the above option to control the name for your level. You can set this name to any string as long as it doesn’t contain a semicolon symbol, or any invalid filename symbol.

level-seed=

The final option we will show you here is the level seed. The level seed is what helps control the way the world is generated.

You can set the level seed to any string. If a string isn’t set, the server will generate a random seed when it first starts up.

3. Over the last step, we ran through several options you can use to control your Ubuntu Minecraft Bedrock server.

There are plenty of other options within this file you may want to explore. Most options come with an explanation of how it affects the server.

4. Once you are happy with your changes, you can quit and save by pressing CTRL + X, followed by Y, then ENTER.

Starting up your Minecraft Bedrock Server on Ubuntu

Now that we have installed the Minecraft Bedrock Server to Ubuntu and configured it, we can finally run it.

Starting the server is straightforward and requires a single command once you are in the correct directory.

1. First, let us use the cd command to change into the directory where we extracted the server.

cd /home/mcserver/minecraft_bedrock/

2. Now that we are in the correct directory, you can use the following command to start the server.

This command sets the “LD_LIBRARY_PATHenvironment variable to the current directory before launching the Minecraft Bedrock server.

sudo LD_LIBRARY_PATH=. ./bedrock_server

3. If you have successfully set up the server on your device, you should see something like the following within the terminal.

This message tells you that the server has started and gives you additional information, such as the ports the server is running on.

Additionally, you can also use the terminal now to control the server. For example, you can use the “op” command to give a player operator status.

[2022-07-01 22:16:32:813 INFO] Starting Server
[2022-07-01 22:16:32:813 INFO] Version 1.19.2.02
[2022-07-01 22:16:32:813 INFO] Session ID XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
[2022-07-01 22:16:32:813 INFO] Level Name: Bedrock level
[2022-07-01 22:16:32:815 INFO] Game mode: 0 Survival
[2022-07-01 22:16:32:815 INFO] Difficulty: 1 EASY
[2022-07-01 22:16:32:839 INFO] opening worlds/Bedrock level/db
[2022-07-01 22:16:33:225 INFO] IPv4 supported, port: 19132
[2022-07-01 22:16:33:225 INFO] IPv6 supported, port: 19133
[2022-07-01 22:16:33:393 INFO] Server started.
[2022-07-01 22:16:33:420 INFO] IPv4 supported, port: 35034
[2022-07-01 22:16:33:420 INFO] IPv6 supported, port: 35782
[2022-07-01 22:16:33:444 INFO] ================ TELEMETRY MESSAGE ===================
[2022-07-01 22:16:33:444 INFO] Server Telemetry is currently not enabled.
[2022-07-01 22:16:33:444 INFO] Enabling this telemetry helps us improve the game.
[2022-07-01 22:16:33:444 INFO]
[2022-07-01 22:16:33:444 INFO] To enable this feature, add the line 'emit-server-telemetry=true'
[2022-07-01 22:16:33:444 INFO] to the server.properties file in the handheld/src-server directory
[2022-07-01 22:16:33:444 INFO] ======================================================

4. To safely stop the server you should use the following command within the Minecraft Bedrock terminal.

stop

Alternatively, you can press CTRL + C while the server is active. However, this may cause an unclean shut down.

Connecting to the Server

While your Ubuntu Minecraft Bedrock server is running, you will be able to connect to it. In the following steps, we will show you a couple of ways to connect to the server.

You may need to port forward if you are trying to connect to this server outside of your home network,. By default, this will be ports 19132 and 19133.

Before proceeding, you may also want to get your IP Address on Ubuntu.

1. When you launch the bedrock edition of Minecraft, you will want to click/tap/select the play button.

The steps will differ if you are trying to connect remotely or locally. Connecting locally is made super easy. However, to connect remotely you will need to provide details about your server.

Select Play Option on Main Menu

Connecting on a Local Network to the Bedrock Server

2. To connect to the Minecraft Bedrock server running on Ubuntu from the local network, you will want to change to the “Friends” tab (1.).

Once on the “Friends” tab, your new server should appear under the “LAN Games” heading (2.). Select the server to load into it.

Connect to Ubuntu Minecraft Bedrock Server locally

3. Above is all you need to do to connect to a bedrock server while running on the local network.

The connection process should now begin. You can skip down to “Completing your connection“.

Connecting Remotely to your Ubuntu Minecraft Bedrock Server

2. If you want to connect to your Ubuntu Minecraft Bedrock server remotely, you must follow some extra steps.

First, you must change to the “Servers” tab (1.).

Once on the servers tab, scroll down to the bottom of the list and select the “Add Server” button (2.).

Adding a New Server

3. To add an external server, you must fill out a few details about your server.

  1. First, set a name for this server to something you will easily remember (1.).
  2. Second, you need to provide the IP address of your server (2.).

    If you are connecting externally remember this needs to be your network’s external IP address.
  3. Third, you need to set the port your server is using (3.). The default setting should work fine unless you changed it in the “server.properties” file.
  4. Finally, once you are ready to connect, you will need to click the “Play” button (4.).
Enter Ubuntu Minecraft Bedrock Server Details

Completing your Connection

4. If you have never connected to a server before, you will get the following message when you connect.

If you don’t want to see this message again, tick the “Do not show this screen again” checkbox.

You will need to click the “Proceed” button to continue with the connection.

Online play is not rated

5. Your Minecraft client should now be connecting to your server.

This process can take a few seconds, especially if you are spawning into a new world, as the server has to generate the starting chunks, then send them to you.

Connecting to Server

6. Finally, if everything has worked correctly, you should now be connected to your Ubuntu Minecraft Bedrock server.

With any luck, your experience should remain smooth. There are options you can tweak within the “server.properties” file if you are experiencing poor performance from your server.

Connected to Ubuntu Minecraft Bedrock Server

Start the Minecraft Bedrock Server at Boot on Ubuntu

This section will show you how you can run the Minecraft Bedrock server when Ubuntu boots up.

The easiest way to achieve this is to create a service file. Beyond allowing the server to start at boot, a service will allow you to quickly start, stop and restart the server from the command line.

To cleanly start and stop the server we will also have to write two very short bash scripts.

Writing a Start Script for the Server

1. For our first task, we will write a simple bash script that will start the Minecraft Bedrock server when the system powers on.

We write this as a script so we can do some additional actions like placing the process into a detached screen.

sudo nano /home/mcserver/minecraft_bedrock/start_server.sh

2. Now, type the following lines into this bash script.

#!/usr/bin/env bash

SERVER_PATH=/home/mcserver/minecraft_bedrock/

/usr/bin/screen -dmS mcbedrock /bin/bash -c "LD_LIBRARY_PATH=$SERVER_PATH ${SERVER_PATH}bedrock_server"
/usr/bin/screen -rD mcbedrock -X multiuser on
/usr/bin/screen -rD mcbedrock -X acladd root

This script is reasonably straightforward to understand.

We use the “screen” application we installed earlier to launch the Minecraft Bedrock Server on Ubuntu. Doing this allows us to easily access the server command line interface while it is running.

3. Once you have finished adding these lines to the file, save and quit by pressing CTRL + X, then Y, followed by ENTER.

4. With the script created, we should now give it execution privileges using the chmod command.

sudo chmod +x /home/mcserver/minecraft_bedrock/start_server.sh

Writing a Script to Stop the Bedrock Minecraft Server Safely

1. Our next task is to write a script that will safely stop the Minecraft Bedrock Server on Ubuntu.

If we were to terminate the process, there is a chance you would lose data in the process. This is where we can utilize the screen we create during the server startup script.

Begin writing the script to stop the server by running the following command.

sudo nano /home/mcserver/minecraft_bedrock/stop_server.sh

2. Now, within this script, you will want to type in the following lines.

#!/usr/bin/env bash

/usr/bin/screen -Rd mcbedrock -X stuff "stop \r"

With this we use the “screen” tool to restore the “mcbedrock” screen created during server start up. It then sends a stop message to the server with the “stop” command before detaching the screen session again.

The advantage of doing this is that we are giving Ubuntu the chance to shut down the Minecraft Bedrock server cleanly.

3. Once you are finished writing the stop script, save and quit out of the file by pressing CTRL + X, then Y, followed by the ENTER key.

4. Now that you have written the stop script, we should give it execution privileges.

You can give the file this permission by running the following command.

sudo chmod +x /home/mcserver/minecraft_bedrock/stop_server.sh

Correcting Permissions

1. Before continuing any further we do need to make sure our “mcserver “user owns both of the scripts we just created.

The reason we need to do this is because files tend to inherit their ownership from the user that created them.

Utilize the following command in the terminal to take ownership of all the files within the directory.

sudo chown -R mcserver: /home/mcserver/

Creating the Service

1. Let us begin by creating a new service file on our Ubuntu system. We will call this new service “mcbedrock“.

Begin writing this new file by running the following command within the terminal.

sudo nano /etc/systemd/system/mcbedrock.service

2. Within this file, you must type in the following lines.

[Unit]
Description=Minecraft Bedrock Server
Wants=network-online.target
After=network-online.target

[Service]
Type=forking
User=mcserver
Group=mcserver
ExecStart=/usr/bin/bash /home/mcserver/minecraft_bedrock/start_server.sh
ExecStop=/usr/bin/bash /home/mcserver/minecraft_bedrock/stop_server.sh
WorkingDirectory=/home/mcserver/minecraft_bedrock/
Restart=always
TimeoutStartSec=600

[Install]
WantedBy=multi-user.target

3. You can save and quit out of this file by pressing CTRL + X, then Y, and finally the ENTER key.

4. With the service created we can now enable it. By enabling a service, systemctl will manage this service and start it when the system boots..

You can enable our Minecraft Bedrock Server service on Ubuntu by running the following command.

sudo systemctl enable mcbedrock

5. Even though we just enabled the service, it won’t start the server itself until Ubuntu is restarted.

We can speed up this process by just starting the service now by using the command below.

sudo systemctl start mcbedrock

If everything is working correctly, your server should now be up and running, and you will be able to connect to it.

Controlling your Ubuntu Minecraft Bedrock Server Service

Now that we have created the service let us show you how you can use it to control the Ubuntu Minecraft Bedrock server.

Controlling the server through the service is a straightforward process and revolves around us using the “systemctl” command.

Starting the Ubuntu Minecraft Bedrock Server

You can start the service by running the following command within the terminal. Of course, if the service is already running, then this command won’t do anything.

When starting the service, systemctl will execute the “start_server.sh” script.

sudo systemctl start mcbedrock

Stopping the Server While it is Running

If your Minecraft Bedrock server is running, you can stop it by using the following command.

This will execute the “stop_server.sh” script we wrote earlier in this guide.

sudo systemctl stop mcbedrock

Enabling the Bedrock Server to Start at Boot

When you enable the service, it will allow the service manager to start the service at boot.

sudo systemctl enable mcbedrock

Disabling the Minecraft Bedrock Server

You can utilize the following command, if you want to stop the Ubuntu Minecraft Server from starting at boot.

sudo systemctl disable mcbedrock

Getting the Status of your Ubuntu Minecraft Bedrock Server

By using the following command you can get the status of the Bedrock service. The status will show you whether the service is currently running

sudo systemctl status mcbedrock

Accessing the Ubuntu Minecraft Bedrock Server Command Line

One of the most significant advantages of placing the Minecraft Bedrock Server within a detached “screen” on Ubuntu is that you can access it anytime.

If the service launched the server directly without using “screen“, you wouldn’t be able to access the command line interface easily.

1. To enter the command line interface for the Bedrock server, you will need to use the following command.

This command surfaces our “mcbedrock” screen to the current session.

sudo screen -r mcserver/mcbedrock

2. Once you are done interacting with the server, you will need to detach the screen again.

Make sure you press CTRL + A, then CTRL + D to detach the “mcbedrock” screen.

Updating the Minecraft Bedrock Server

Updating the Minecraft Bedrock server on Ubuntu is a fairly straightforward process. However, it requires us to retrace some of our earlier steps.

1. Before updating your server, you need to stop it. If you are using the service, you can stop the Minecraft Bedrock server by running the following command

sudo systemctl stop mcbedrock

2. Our first step is to make a copy of our “server.properties” file. This stops you from losing your settings when you extract the new version.

sudo cp /home/mcserver/minecraft_bedrock/server.properties /home/mcserver/server.properties.bkup

3. You have to obtain the latest download URL for the Minecraft Bedrock Server before we can continue.

To get this URL use the following command within the terminal.

DOWNLOAD_URL=$(curl -H "Accept-Encoding: identity" -H "Accept-Language: en" -s -L -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; BEDROCK-UPDATER)" https://minecraft.net/en-us/download/server/bedrock/ |  grep -o 'https.*/bin-linux/.*.zip')

4. With the download URL now stored within a variable, we can use the following command to download the archive.

This archive should contain the latest version of the Minecraft Bedrock server for Ubuntu.

sudo wget -U "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; BEDROCK-UPDATER)" $DOWNLOAD_URL -O /home/mcserver/minecraft_bedrock/bedrock-server.zip

5. Now that we have downloaded the archive, our next step is to extract it.

When extracting the archive using the following command, unzip will overwrite all files since we are using the "-o” option.

sudo unzip -o /home/mcserver/minecraft_bedrock/bedrock-server.zip -d /home/mcserver/minecraft_bedrock/

5. After extracting the server archives contents, we can safely delete the leftover archive.

Use the command below in your terminal to delete the archive.

sudo rm /home/mcserver/minecraft_bedrock/bedrock-server.zip

6. Now that we have updated all of the server files, we can use the mv command to move back over our “server.properties” file.

This will ensure that your configuration changes aren’t lost during the upgrade process

sudo mv /home/mcserver/server.properties.bkup /home/mcserver/minecraft_bedrock/server.properties

7. Let us ensure that unzipping didn’t ruin our users ownership by using the following command. This command will replace ownership of all the files with our “mcserver” user.

sudo chown -R mcserver:mcserver /home/mcserver/

8. Your Ubuntu Minecraft Bedrock Server has now been updated. You should now be able to start the server back up safely.

Using our service file, you can start the server back up by using the following command.

sudo systemctl start mcbedrock

Conclusion

Throughout this tutorial, we have shown you how to install and set up the Minecraft Bedrock server on Ubuntu.

We walked you through several steps of setting up the server, showing you numerous options as well as how to set the server up as a service.

Please comment below if you have questions about running a Minecraft Bedrock server on Ubuntu.

We have numerous other Ubuntu guides if you want to do more with the operating system. We have a wealth of general Linux tutorials available as well.

Leave a Reply

Your email address will not be published. Required fields are marked *

38 Comments

  1. Avatar for muhammed
    muhammed on

    service to start server was failing, solution was to replace /usr/bin/bash with just /bin/bash for my distro

  2. Avatar for Frank
    Frank on

    Great work, it was super easy to install and update the bedrock server just fo my family. Maybe you should add a further step to backup the permissions.json and smiliar files prior an update.

  3. Avatar for Rexcellent
    Rexcellent on

    Awesome guide. Worked great last week.
    It looks like there have been some changes after BDS 1.21.30.03:

    The download URL has changed. One solution is to use a “more fuzzy” grep search.
    old: https://minecraft.azureedge.net/
    new: https://www.minecraft.net/bedrockdedicatedserver/

    The new server URL is “awaiting response” from the wget command. One solution is to pass the browser string in the user switch of the wget command.

    The following two changes to the “Updating the Minecraft Bedrock Server” section worked for me:

    Change Step 3:

    DOWNLOAD_URL=$(curl -H "Accept-Encoding: identity" -H "Accept-Language: en" -s -L -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; BEDROCK-UPDATER)" https://minecraft.net/en-us/download/server/bedrock/ |  grep -o 'https.*/bin-linux/.*.zip')

    Change Step 4

    wget -U "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; BEDROCK-UPDATER)" $DOWNLOAD_URL -O ./bedrock-server.zip
    1. Avatar for Emmet
      Emmet on
      Editor

      Hi Rexcellent,

      Thank you very much for your contribution! It is very much appreciated by us when someone points out an issue, let alone provides the fix for it as well.

      I have verified it all works with the new method and updated the guide accordingly.

      Kind regards,
      Emmet