How to install

A short video explaining how to install Kerberos.io on Raspbian.


Install package

Update system and install libav-tools.

sudo apt-get update
sudo apt-get update && sudo apt-get install libav-tools

Download the debian file from the machinery repository; Please download the correct version for your Raspberry Pi, replace X by the version.

sudo wget https://github.com/kerberos-io/machinery/releases/download/v2.3.1/rpiX-machinery-kerberosio-armhf-2.3.1.deb

Unpackage the file

sudo dpkg -i rpiX-machinery-kerberosio-armhf-2.3.1.deb

Enable Raspberry Pi camera (if needed)

sudo raspi-config

Start the machinery on start-up, and reboot the system.

 sudo systemctl enable kerberosio && sudo reboot


The configuration files can be found at /etc/opt/kerberosio/config. By default the Raspberry Pi Camera module is set as capture device. You can update the config.xml file to change it to USBCamera or IPCamera. Images are stored in the /etc/opt/kerberosio/capture directory by default; this location can be changed by editing the io.xml file.


After kerberos is installed a binary is available at /usr/bin/kerberosio. Just run following command in your terminal to start kerberosio



Install Nginx + PHP

Before you can run the web interface, you'll need to download and configure a webserver. Kerberos.io recommends to use Nginx, as it is a light-weight and fast webserver. The web interface is written in PHP, so we also need to download PHP and some packages.

Update the packages and kernel.

echo "deb http://mirrordirector.raspbian.org/raspbian/ stretch main contrib non-free rpi" | sudo tee --append /etc/apt/sources.list
sudo apt-get update && sudo apt-get upgrade

Install Nginx and PHP (+extension).

sudo apt-get install -t stretch nginx php7.0 php7.0-curl php7.0-gd php7.0-fpm php7.0-cli php7.0-opcache php7.0-mbstring php7.0-xml php7.0-zip php7.0-mcrypt

Creating a Nginx config.

sudo rm -f /etc/nginx/sites-enabled/default
sudo nano /etc/nginx/sites-enabled/default

Copy and paste following config file; this file tells nginx where the web will be installed and that it requires PHP.

    listen 80 default_server;
    listen [::]:80 default_server;
    root /var/www/web/public;
    index index.html index.htm index.nginx-debian.html;
    server_name kerberos.rpi kerberos.rpi;
    index index.php index.html index.htm;
    location /
            autoindex on;
            try_files $uri $uri/ /index.php?$query_string;
    location ~ \.php$
            fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;

Restart nginx and reboot system

sudo service nginx restart && sudo reboot

Install source

Create a www location.

sudo mkdir -p /var/www/web && cd /var/www/web

Get the source code from Github.

sudo wget https://github.com/kerberos-io/web/releases/download/v2.3.2/web.tar.gz


sudo tar xvf web.tar.gz .

Change write permission on the storage directory.

sudo chmod -R 777 storage
sudo chmod -R 777 bootstrap/cache
sudo chmod 777 config/kerberos.php


sudo reboot

Auto removal

By default images or videos aren't removed automatically. This means that Kerberos.io will keep writing to disk, even if there is no more space available on your SD card. When your SD card is full you'll be experiencing strange errors: a corrupt web interface, blank images or corrupt videos.

To resolve this your should install a simple bash script and initiate a cronjob which continuously poll your filesystem, and start removing media when your disk is getting full.

Create a bash script and copy following script.

nano /home/pi/autoremoval.sh

Copy following script (make sure the partition is correct, this is the default one for a Raspberry Pi).

if [[ $(df -h | grep $partition | head -1 | awk -F' ' '{ print $5/1 }' | tr ['%'] ["0"]) -gt 90 ]];
    echo "Cleaning disk"
    find $imagedir -type f | sort | head -n 100 | xargs -r rm -rf;

Make the script executable.

chmod +x /home/pi/autoremoval.sh

Initiate a cronjob, and select the nano editor.

crontab -e

Append following line, to execute the autoremoval.sh script every 5min.

*/5 * * * * /bin/bash /home/pi/autoremoval.sh