Skip to content

Latest commit

 

History

History
313 lines (250 loc) · 11.3 KB

Installation.md

File metadata and controls

313 lines (250 loc) · 11.3 KB

Server Installation

This document describes how to build, install and configure the lorawan-server.

Installation

Using the Debian package

On the Debian Linux and its clones like Raspbian you can use the .deb package.

Unless you have Debian 9 (Stretch) you have to install the Erlang/OTP 19 or later from Erlang Solutions first:

wget https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb
sudo dpkg -i erlang-solutions_1.0_all.deb
sudo apt-get update
sudo apt-get install erlang-base erlang-crypto erlang-syntax-tools erlang-inets \
    erlang-mnesia erlang-runtime-tools erlang-ssl erlang-public-key erlang-asn1 \
    erlang-os-mon erlang-snmp erlang-xmerl

Download the Debian package lorawan-server-*.deb and install it by:

dpkg -i lorawan-server-<VERSION>.deb

If you want the server to start automatically after system reboot, run systemctl enable lorawan-server.

Then start the server by systemctl start lorawan-server.

Using the Binary Release on Linux

You will need the Erlang/OTP 19 or higher. Try typing yum install erlang or apt-get install erlang.

Check your Erlang/OTP version by typing erl. If your Linux distribution includes some older version of Erlang/OTP, install an update from Erlang Solutions.

Then download the latest binary release lorawan-server-*.tar.gz and (on Linux) unpack it by:

mkdir lorawan-server
mv lorawan-server-<VERSION>.tar.gz lorawan-server/
cd lorawan-server
tar -zxvf lorawan-server-<VERSION>.tar.gz

You can run the server by:

bin/lorawan-server

By default the database directory Mnesia.lorawan@* is stored in the lorawan-server directory you created. If you want to store the run-time information to another directory, set the LORAWAN_HOME environment variable.

The log files are by default stored in the same directory. If you want to store the log files elsewhere, set the LORAWAN_LOG_ROOT variable.

The lorawan-server can be started in background as a daemon. On Linux systems with systemd you should:

  • Unpack the binary release to /usr/lib/lorawan-server
  • Copy bin/lorawan-server.service to /lib/systemd/system
  • Create a dedicated user by useradd --home-dir /var/lib/lorawan-server --create-home lorawan
  • Create the /var/log/lorawan-server directory and make sure it is owned by the user lorawan
  • Start the server by systemctl start lorawan-server

This will put the database into /var/lib/lorawan-server and server logs into /var/log/lorawan-server.

Using the Binary Release on Windows

Install the 32-bit or 64-bit Binary File of Erlang/OTP 19 or later.

Unpack the binary release lorawan-server-*.tar.gz using the 7-Zip to a new folder (e.g. lorawan-server) and then run the server by double-clicking lorawan-server.bat in the lorawan-server/bin folder.

You can also run the lorawan-server as a Windows service. The service can be managed from a Command Prompt (cmd) using lorawan-service.bat <command>, where the <command> could be:

  • add to add the service. Once added you can use the standard Windows control panel administrative tools to start/stop or enable/disable the service.
  • remove to remove the previously added service.
  • list to display parameters of a previously added service.

Using the Binary Release on Mac OS

Install Erlang by brew install erlang.

Unpack and run the binary release

mkdir lorawan-server
mv lorawan-server-<VERSION>.tar.gz lorawan-server/
cd lorawan-server
tar -zxvf lorawan-server-<VERSION>.tar.gz
bin/lorawan-server

Upgrade

The server binaries are stored in three subdirectories: bin, lib and releases. These files are either:

  • In /usr/lib/lorawan-server when using the official releases
  • In lorawan-server/_build/default/rel/lorawan-server when you build the server from sources
  • Or wherever you extracted them

The server run-time files are automatically created during the first run. It includes the database in Mnesia.lorawan@* and log files. These files are either:

  • In /var/lib/lorawan-server when using the official releases
  • In the directory specified by the LORAWAN_HOME environment variable
  • Otherwise it is in the same directory as the server binaries

To upgrade your server binaries:

  • Stop the lorawan-server
  • Backup or make sure you don't delete the Mnesia.lorawan@* sub-directory.
  • Delete the existing bin, lib and releases sub-directories and replace them by bin, lib and releases from the new binary release. You can simply unpack the content of the binary release e.g. in /usr/lib/lorawan-server.
  • Copy bin/lorawan-server.service to /lib/systemd/system
  • Reload the services by sudo systemctl daemon-reload
  • Start the lorawan-server

Server Configuration

Review the lorawan-server/releases/<VERSION>/sys.config with the server configuration:

  • To enable/disable applications, modify the plugins section. For more details see the Custom Application Guide.
  • Set {disksup_posix_only, true} when your embedded system uses stripped-down Unix tools

Note that during the manual installation the sys.config is created automatically by the release tool (make release) based on the lorawan_server.config.

For example:

[{lorawan_server, [
    % update this list to add/remove applications
    {applications, [
        {<<"semtech-mote">>, lorawan_application_semtech_mote}]},
    % UDP port listening for packets from the packet_forwarder Gateway
    {packet_forwarder_listen, [{port, 1680}]},
    % HTTP port for web-administration and REST API
    {http_admin_listen, [{port, 8080}]},
    % default username and password for the admin interface
    {http_admin_credentials, {<<"admin">>, <<"admin">>}},
    % amount of rxframes retained for each device/node
    {retained_rxframes, 50},
    % websocket expiration if client sends no data
    {websocket_timeout, 3600000} % ms
]},
{os_mon, [
    % Setting this parameter to true can be necessary on embedded systems with
    % stripped-down versions of Unix tools like df.
    {disksup_posix_only, false}
]}].

To disable the plain HTTP web-admin, set {http_admin_listen, undefined}.

Review the lorawan-server/lib/lorawan_server-<VERSION>/priv/admin/admin.js with the admin configuration:

  • You may need to obtain a Google API key for the Google Maps and enter it in GoogleMapsKey. For deployments on a local network this is not needed.

You may need to enable communication channels from LoRaWAN gateways in your firewall. If you use the firewalld (Fedora, RHEL, CentOS) do:

cp lorawan-forwarder.xml /usr/lib/firewalld/services
firewall-cmd --permanent --add-service=lorawan-forwarder
firewall-cmd --reload

The lager system is used to create and rotate logs. By default two logs will be created: debug and error. Lager will rotate each log file at midnight or when it reaches 10MB, whichever comes first, and keep 5 rotated logs in addition to the current one.

To reduce the amount of storage utilized by the logs and have only 3 files <5MB modify the lager handlers configuration in your sys.config:

{lager_file_backend, [{file, "debug.log"}, {level, debug}, {size, 5242880}, {count, 3}]}

Configuration of the packet_forwarder

Edit the global_conf.json in your Gateway and update the server_address, serv_port_up and serv_port_down as necessary.

For example:

{
    "gateway_conf": {
        "gateway_ID": "AA555A0000000000",
        "server_address": "server.example.com",
        "serv_port_up": 1680,
        "serv_port_down": 1680,
        "keepalive_interval": 10,
        "stat_interval": 30,
        "push_timeout_ms": 100,
        "forward_crc_valid": true,
        "forward_crc_error": false,
        "forward_crc_disabled": false
    }
}

When both packet_forwarder and lorawan-server are running on the same machine use localhost or 127.0.0.1 as the server_address.

Build Instructions

Manual Installation

You will need the following prerequisites:

  • Rebar3, the Erlang build tool.
    • On Linux it will download automatically.
    • On Windows follow the installation instructions.
    • On Mac OS, run brew install rebar.
  • npm, the JavaScript package manager.
    • On Linux follow the instructions bellow.
    • On Windows, install the Node.js.
    • On Mac OS, run brew install node.

Make sure you have the run-time prerequisites:

sudo apt-get update
sudo apt-get install erlang-base erlang-crypto erlang-syntax-tools erlang-inets \
    erlang-mnesia erlang-runtime-tools erlang-ssl erlang-public-key erlang-asn1 \
    erlang-os-mon erlang-snmp erlang-xmerl

Required nodejs can be installed from here. On Debian, add the following to your /etc/apt/sources.list and run apt-get update before installation:

deb http://deb.nodesource.com/node_6.x stretch main
deb-src http://deb.nodesource.com/node_6.x stretch main

Then, obtain the build prerequisites:

sudo apt-get install git erlang-dev erlang-parsetools erlang-src erlang-eunit nodejs

Get the latest lorawan-server sources by:

git clone https://github.com/gotthardp/lorawan-server.git
cd lorawan-server

If you already obtained the sources you can upgrade to the latest version by:

cd lorawan-server
git pull
make upgrade

Then build and release the lorawan-server by:

make release

The release will be created in lorawan-server/_build/default/rel/lorawan-server.

If you encounter issues with npm, please try to:

  • Update your npm with sudo npm install -g npm
  • Make sure github.com is listed in the list of known hosts by running ssh github.com, which will fail but will also add github.com to your .ssh/known_hosts:
    The authenticity of host 'github.com (192.30.253.113)' can't be established.
    RSA key fingerprint is SHA256:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.
    Are you sure you want to continue connecting (yes/no)? yes
    Warning: Permanently added 'github.com,192.30.253.113' (RSA) to the list of known hosts.
    Permission denied (publickey).
    

According to the above installation instructions the server binaries are under /usr/lib/lorawan-server. To upgrade your installation you shall replace the content of the bin, lib and releases sub-directories with the newly created content.

Creating the Debian package

On the Debian Linux and its clones like Raspbian you can use the .deb package.

Build the Debian package bu running make release dpkg. This will create lorawan-server/_build/default/rel/lorawan-server/lorawan-server_<VERSION>.deb.

You can then install the package by:

dpkg -i lorawan-server_*.deb

You can start the server by systemctl start lorawan-server.