Running UniFi Network Server Application v9 + MongoDB v7 on a Raspberry Pi 4 (ARMv8-a)

A tutorial to run the v9.0.108 UniFi Network Application using the latest MongoDB v7.0.14 on low power ARMv8-a devices such as the Raspberry Pi 4.

The UniFi logo is a trademark of Ubiquiti Inc.
The UniFi logo is a trademark of Ubiquiti Inc.

Yes you can run a UniFi Network Server Application (Controller) on a Raspberry Pi 4 and it works very well.

For MongoDB versions 4.4.18 and newer, the ARMv8.2-a instruction set is required. For MongoDB versions 5.0 and newer, the AVX instruction set is required, which is a problem for our low cost low power ARM CPUs. The Raspberry Pi 4 and UXG-Lite are both running older ARM SoCs that are using the ARMv8-a instruction set. Technically, we can run MongoDBv3.6 for this purpose, but this version has been EOL since 2021, and it's never great to run outdated software that is not receiving security patches.

I want to run a version of MongoDB still receiving security updates, so I did a bit of research. I came across this github repo, github user themattman (Matt Kneiser) is compiling MongoDB Server binaries for the ARMv8 architecture, amazing! I created two .deb packages using these binaries, one with just the mongod and mongo binaries as Ubiquiti is only using mongod, and mongo is useful for diagnosing/manually altering the DB, and the second with the required libstdc++6 dependency.

  • SSH into your rPi4
  • Run sudo apt install docker-compose net-tools nano this will install the docker-compose tool, docker, some basic networking tools, and the nano text editor
  • Run mkdir ~/unifi-docker && cd ~/unifi-docker to create a folder in your home directory and navigate to it
  • Run nano docker-compose.yml this will open up the nano text editor, copy the below block of text into this file (ctrl+c to copy & ctrl+v to paste) and once done press ctrl+x to save the file
version: '3.4'

services:
  unifi-network-armv8-a:
    container_name: farfoxachedocker.unifi-network-armv8-a
    image: farfoxachedocker/unifi-network-armv8-a:latest
    volumes:
      - var-lib-unifi:/var/lib/unifi
      - usr-lib-unifi:/usr/lib/unifi
    network_mode: host
    restart: on-failure

volumes:
  var-lib-unifi:
  usr-lib-unifi:

Copy this block of text into the file docker-compose.yml

  • Run sudo docker-compose up -d this tells docker-compose to use the instructions in the docker-compose.yml file to build a docker container using my docker image that is pre-built on my public docker hub repository, when it's completed, you should see output like the following image

Now the docker container has been created, it's running the docker image and it is going to continue to run the docker image even if we restart the rPI4, it will restart this docker container on system start. We should wait about 3 minutes for the UniFi Network Server Application to initialise itself, then we can access it by typing https://<IP address of rPi4>:8443 into a web browser. If the IP address of my rPI4 is 192.168.1.253, I would type https://192.168.1.253:8443

UniFi Network Application setup screen
Success!

It says "Not secure" in the web browser, this is because it's using an untrusted TLS certificate issued by Ubiquiti Inc. I like to put a reverse proxy such as NGINX in front and serve my own TLS certificate from Let's Encrypt, but that is a totally different tutorial for another day 🙂

🦊
Important: in the docker-compose.yml file we specified network_mode: host, this instructs the docker container to use the network of the host (rPI4). Any ports opened in the docker container are opened on the host, and so we should correctly configure UFW or iptables on our host to drop any unwanted traffic accordingly.

To stop the docker container running

  • Run cd ~/unifi-docker && sudo docker-compose down
The docker container is stopped and removed, killing the UniFi Network Server Application in the process
The docker container is stopped and removed, killing the UniFi Network Server Application in the process

To update

The docker container installs the newest available version of the UniFi Network Server Application each time it starts, therefore to update we simply need to stop and start our docker container using the following commands.

  • Run cd ~/unifi-docker && sudo docker-compose down this stops our docker container running.
  • Run sudo docker-compose up -d this starts our docker container up again and in doing so the init script (start.sh) inside the container will install the latest available UniFi Network Server Application.

If you want to update to the latest version of MongoDB, pull the docker image to retrieve an image that is built with the latest MongoDB.

⚠️
Warning: updating to the latest MongoDB version may break your installation so make sure you have a backup saved first!