This document describes how to build, install and configure the lorawan-server.
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
.
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 userlorawan
- 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
.
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.
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
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
andreleases
sub-directories and replace them bybin
,lib
andreleases
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
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}]}
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
.
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.
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
.