Skip to content
corb555 edited this page May 25, 2015 · 77 revisions

FAQ about hardware to run the openHAB runtime

Introduction

This page summarizes how to get openHAB server running on specific hardware (it does not cover add-on bindings and modules).

General Hardware Platform Requirements

The openHAB Runtime is a Java application. It requires JVM 1.6 or later.

openHAB is expected to run on all platforms where the required JVM version is available. This includes Windows, Mac OS X, and Linux on x86, x86_64, and ARM architectures.

openHAB can be installed and operated on AMD or Intel powered commodity laptop, a desktop computer, or ARM based single-board computers.

Below are configuration notes for specific hardware.

x86 Linux

1. Install and setup OpenHAB As described in: Linux---OS-X

ARM Single-Board Computers

ARM-based computers are a popular choice due to low cost, small size, low power consumption and typically being fan-less. They are usually extensible with available add-on components and via programmable GPIO.

ONLY use the vendor forums recommended Wifi, SD card and power supply. These systems have NO headroom in any of their specs and may be flaky with other devices. A lot of power supplies don't actually deliver what they claim, so again, go with a recommended model or you will get random flakiness and reboots. If you experience dropped or duplicated packets from a USB device (keyboard, wifi, Z-Wave), search the vendor's forums for "keyboard not working". You may need to upgrade firmware or use specific ports and settings for the USB devices.

System Cost Cores Ghz Model Gb RAM IO Primary OS
ODROID C1 $36 4 1.5 A7 1.0 GPIO Ubuntu
RaspPi 2 $36 4 0.9 A7 1.0 GPIO Raspbian
BananaPi $40 2 1.0 1.0 GPIO SATA Raspbian
BeagleBlk $50 2 1.0 A8 0.5 GPIO Ubuntu
RaspPi B $30 1 0.7 A5 0.5 GPIO Raspbian

Raspberry Pi2

Raspberry PI 2

  • 900MHz quad-core ARM Cortex-A7 CPU
  • 1GB LPDDR2 SDRAM
  • Complete compatibility with Raspberry Pi 1

Raspberry Pi interfaces A proven choice for small residential installations.

NOTE There is an issue with the zwave binding on the RPi and the RPi is NOT RECOMMENDED if you intend on using zwave. Refer to the z-wave binding for more information

Installation

  1. Install Raspbian Wheezy release 2014-01-07 or later. It includes Java 7 JRE that meets openHAB pre-requisite JVM requirements.

  2. Install openHAB.

Optionally, a complete JDK 7 or 8 for Linux ARM v6/v7 Hard Float ABI is available for download from Oracle or from Apt Repository.

Tweaking Performance

Stay up to date with rpi-update (https://github.com/Hexxeh/rpi-update/)

Change GPU memory usage

For headless, reduce memory down to 16, this can be done by using raspi-config

Disabling TV Service

For headless, add these to /etc/rc.local:

# Limit GPU IRQs
fbset -xres 16 -yres 16 -vyres 16 -depth 8
/opt/vc/bin/tvservice -o

Overclocking does not seem to have big influences

CubieBoard, ODroid, BeagleBone Black

Single-Board Computers

These systems have considerably more power than Raspberry Pi 1 and and range from about $35 to $70 and work well with OpenHAB for relatively large installations.

1. Install Linux distro

Recommended Linux distros:

  • ODroid C1: $ 37 1.5 Ghz Quad Core, 1.0 Gb DDR3 RAM
    Use Ubuntu 14.04

  • BeagleBone Black: $ 55 1GHz Cortex-A8 0.5 Gb DDR3 RAM
    Use Ubuntu 14.04

  • CubieBoard2: The CubieBoard2 or CubieTruck The following Linux distros work with OpenHAB Use Cubiuntu

2. Install JAVA - see java installation

3. Install and setup OpenHAB - as described in Linux---OS-X

Synology Diskstation

A package of OpenHAB 1.4.0 for Synology Diskstations is stored at OpenHAB google groups and on the package server https://www.hofrichter.at/sspks.
This package can be installed in DSM via the package manager -> manual installation or by adding https://www.hofrichter.at/sspks/ as package source - there is a tutorial on the Synology support pages about how to do that. This package is tested on DS213+ with oracle's java 7 from PC load letter.
In the Synology package manager you can

  • install
  • start
  • stop
  • uninstall

OpenHAB.
This package comes without any demo files - so the UI will not show much without giving OpenHAB some configurations ;-) It takes some time after the start of OpenHAB before the UI starts responding (less than a minute on a DS213+).

####Paths OpenHAB is installed at /var/packages/OpenHAB/target/ (which is linked to /volume1/@appstore/OpenHAB).
If the directory /volume1/public/OpenHAB/configurations exists, this directory will be used for all OpenHAB configuration files. This should make it easier to work with the OpenHAB designer installed on your PC.

If the directory /volume1/public/OpenHAB/addons exists, this directory will be used for all OpenHAB addons (bindings) files.

####Ports The UI is on port 8081, the console (via telnet) is on port 5555.

####Demo files In the OpenHAB google groups and on the package server https://www.hofrichter.at/sspks is an install-able package of the OpenHAB 1.4.0 demo files (only the demo files!) for Synology NAS. Prerequisite is that the OpenHAB package is installed.

After the installation of OpenHAB and the demo files http://your.synology.URL:8081/openhab.app?sitemap=demo should show the UI with the demo configuration.

"Text to speech" is disabled in configurations/rules/demo.rules otherwise the demo files are unchanged. This change was necessary (at leased on a DS213+) else OpenHAB stops responding. Give OpenHAB a minute or so after the start of OpenHAB before you expect any response in the UI ;-) ####Kernel drivers Some bindings (e.g. EnOcean) work with USB-sticks that require some kernel drivers. For qoric CPU Diskstations (e.g. DS213+) there is a short guide how to install those drivers at Samples-Tricks.

QNAP Turbo Station

There is a QPGK package to install openHAB v1.5 on a QNAP Turbo Station NAS. http://forum.qnap.com/viewtopic.php?f=320&t=95315&p=423268

Banana Pi (bPi) $ 40

Banana Pi

As a variant of the original Raspberry Pi the Banana Pi is equipped with

  • A dual core Allwinner A20 CPU at 1GHz
  • 1 GByte RAM
  • One SATA Port

There are various system images available for the bPi but for the use with openHAB I found the "classical" Raspbian quite stable. All about performance tweaking form above is applicable for the bPi too but the most important thing is the SATA Port which enables users to work around the poor I/O performance of the SD card subsystem.

The SATA connection is the key if you want to run an openhab server (also a not-so-small installation) on such board. You can switch from SD card to SATA disks like described here.

Performance impact

The following data is taken from the monitoring of my openhab server which has about 75 items, 50 rules and 80 sitemap-items.

Without changing anything else but the mass storage from SD card (Transcend SDHC UHC-I X600) to SSD (Crucial M500) overall cpu load dropped from 2.x to about 0.8.

CPU load

Key to this was the reduction of I/O wait (writing to SD card) from 25% to below 5% in cpu utilization.

CPU utilization

So far the combination of Banana Pi and SATA SSD can be highly recommended.

Power supply of SATA devices

Be aware of power issues if you plan to use a normal (mechanical) hard disk. The bPi is only able to supply the 5V part of SATA power. Mechanical 3.5'' hard disks usually utilize 12V for the mechanical parts (disk spin motor, head control) and 5V for the electronical part. SATA SSD's and most 2.5'' HD's only use 5V and in general they do not require the 12V supply power to be present. For running an bPi with SATA SSD or 2.5'' HD the bPi-specific SATA/Power cable is sufficient in most cases.

Installation

###Linux / OS X

###Windows


##Configuration

User Interfaces


Community

(link to openHAB forum)

Development



Misc


Samples

A good source of inspiration and tips from users gathered over the years. Be aware that things may have changed since they were written and some examples might not work correctly.

Please update the wiki if you do come across any out of date information.

Collections of Rules on a single page

Single Rules

Scripts


Release Notes

Clone this wiki locally