If you do not have have a Raspberry Pi, please go to Prepare a virtual device.
In this tutorial we will prepare a Raspberry Pi with a custom Raspberry Pi OS (previously called Raspbian) image. The only difference from the official Raspberry Pi OS image is that it has been converted to support robust system updates with Mender.
Completing this tutorial normally takes less than one hour.
To follow this tutorial, you will need the following:
Download the Raspberry Pi OS image ready for Mender:
Follow the steps outlined in the Raspberry Pi OS documentation to flash the OS image to the device.
We recommended to use the Raspberry Pi Imager tool, choose "Use custom" and browse to the downloaded Mender Raspberry Pi OS image.
Do not use the options to pre-configure the written image, such as SSH, WiFi or user credentials. This is known to be buggy, causing an infinite reboot loop.
Writing the SD card takes 5-25 minutes, mainly depending on your SD card and writer speed.
You can take advantage of the headless configuration options of Raspberry Pi to enable SSH or to configure the wireless network. This saves you the hassle of connecting a monitor and keyboard after your device has booted, as it will come up with WiFi and SSH already working and you can just SSH into it from your workstation.
First off, insert the SD card you flashed above and find the boot
partition inside it.
Open a terminal on your workstation and verify that it can be accessed in the
default location:
RPI_BOOT="$(find /media/$(whoami)/ -name boot -or -name bootfs)"
[ ! -d "$RPI_BOOT" ] && echo "ERROR: RPI boot directory not found"
RPI_BOOT="$(find /Volumes/ -name boot -or -name bootfs)"
[ ! -d "$RPI_BOOT" ] && echo "ERROR: RPI boot directory not found"
If this outputs nothing you can continue. If you get the ERROR, find out where
the SD card's boot partition is accessible and change the RPI_BOOT
variable accordingly.
With the path to the boot directory set up, we first configure the default user and password:
USERNAME='' # CHANGE: your desired username
PASSWORD='' # CHANGE: your desired password
cat << EOF > "$RPI_BOOT"/userconf.txt
${USERNAME}:$(openssl passwd "$PASSWORD")
EOF
We then configure networking. Assuming you have a typical WiFi setup, change the initial three variables and run this code block:
WIFI_SSID='' # CHANGE: your WiFi name
WIFI_PASS='' # CHANGE: your WiFi password
COUNTRY='US' # CHANGE: two-letter country code, see https://en.wikipedia.org/wiki/ISO_3166-1
cat << EOF > "$RPI_BOOT"/wpa_supplicant.conf
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev
update_config=1
country=$COUNTRY
network={
ssid="$WIFI_SSID"
psk="$WIFI_PASS"
}
EOF
Finally, enable SSH by creating an empty file:
touch "$RPI_BOOT"/ssh
Now disconnect the SD card, insert it into your Raspberry Pi and boot it.
If you have a different network setup or encounter any issues, please see the official Raspberry Pi documentation on headless setups.
If you did headless (Option #1 above) skip to Step 2 below.
Boot the Raspberry Pi with the newly flashed SD card. Attach a keyboard and monitor.
Follow the start-up wizard to:
Then, log in with your new user and password and do the following steps to set up WiFi:
sudo raspi-config
Localisation Options
, then WLAN Country
. Select the correct country code.System Options
, then Wireless LAN
. Set the SSID and passphrase for the networkFinish
Check that your Raspberry Pi is connected to the Internet (e.g. ping www.google.com
).
If this does not work, please see the official Raspberry Pi documentation on network configuration.
Now do the following steps to set up SSH:
sudo raspi-config
Interface Options
and Select SSH
Yes
, OK
and Finish
If you encounter any issues, see Enable local SSH access in the official Raspberry Pi documentation for more information.
Your Raspberry Pi should now be booted, connected to the network and have the SSH daemon running, regardless if you followed the headless approach (Option 1) or connected a keyboard and monitor directly (Option 2).
If you do not know the IP address of your Raspberry Pi device, there are some great resources in the Raspberry Pi OS documentation on different ways of looking this up.
SSH into your device:
ssh <your-login>@<DEVICE-IP-ADDRESS>
You should now see a command prompt similar to the following:
<your-login>@raspberrypi:~ $
Keep this terminal open as we will shortly use it to install the Mender Client.
Hosted Mender is available in multiple regions to connect to. Make sure you select your desired one before proceeding.
Login to hosted Mender. On the main page for the first time new users will get a tutorial in the Mender web GUI.
Go to the Dashboard tab and click on Connect a device.
Select PREPARE AND CONNECT MY RASPBERRY PI.
You need to specify one of the following:
Next we will install the Mender Client on the device and connect it to the Mender server.
In the dialog box from above, click Copy to clipboard to copy the code to install the Mender Client. Now go to the command line on your device, and paste the code e.g. by right-clicking in the terminal and selecting Paste, followed by Enter.
This downloads the Mender Client on the device, configures and starts it.
Once the client has started, the Mender Client will attempt to connect to the server and it will appear in your Pending devices tab in the server. Go ahead and Accept the pending device in the server. After accepting the device, it will appear on the Device groups tab on the left of Pending.
Proceed to Deploy an application update.
© 2025 Northern.tech AS