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 install libav-tools

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

Raspberry Pi Zero/Zero W

wget https://github.com/kerberos-io/machinery/releases/download/v2.6.2/rpi0-machinery-kerberosio-armhf-2.6.2.deb
sudo dpkg -i rpi0-machinery-kerberosio-armhf-2.6.2.deb

Raspberry Pi A/B/B+

wget https://github.com/kerberos-io/machinery/releases/download/v2.6.2/rpi1-machinery-kerberosio-armhf-2.6.2.deb
sudo dpkg -i rpi1-machinery-kerberosio-armhf-2.6.2.deb

Raspberry Pi 2

wget https://github.com/kerberos-io/machinery/releases/download/v2.6.2/rpi2-machinery-kerberosio-armhf-2.6.2.deb
sudo dpkg -i rpi2-machinery-kerberosio-armhf-2.6.2.deb

Raspberry Pi 3

wget https://github.com/kerberos-io/machinery/releases/download/v2.6.2/rpi3-machinery-kerberosio-armhf-2.6.2.deb
sudo dpkg -i rpi3-machinery-kerberosio-armhf-2.6.2.deb

Enable Raspberry Pi camera (if needed).

sudo raspi-config

Set machinery to start on boot, and start it now. A reboot is required if you have changed the options in raspi-config in the previous step.

sudo systemctl enable kerberosio
sudo service kerberosio start


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/kerberosio.conf

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;
    server_name 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

sudo service nginx restart

Install source

Create a www location.

sudo mkdir -p /var/www/web && sudo chown www-data:www-data /var/www/web
cd /var/www/web

Get the source code from Github.

sudo -u www-data wget https://github.com/kerberos-io/web/releases/download/v2.5.1/web.tar.gz


sudo -u www-data tar xvf web.tar.gz .

Change write permission on the storage directory.

sudo chown www-data -R storage bootstrap/cache config/kerberos.php
sudo chmod -R 775 storage bootstrap/cache
sudo chmod 0600 config/kerberos.php

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