- Introduction
- Signal K Platform
- Community & support
- How to get Signal K Server
- Configuration and use
- Supported PGNs, Sentences and more
- Environment variables
- Command line options
- Development
- Sponsoring Signal K
- License
Signal K Server is a server application that runs on a central hub in a boat. If you use or develop marine electronics, Signal K Server has something to offer for you.
For boaters, Signal K Server runs in the background and makes functionality and data available to other apps and devices. One of its most used features is to be a wireless AIS and navigation server for popular apps like Navionics, iSailor, iNavX, Aqua Map and WilhelmSK on your phones and tablets.
Signal K Server can also take care of the anchor watch, be a weather station or an automatic logbook for you. A different example, it can turn your boat into a MarineTraffic station which may give free access to the MarineTraffic professional plans. These are all just examples: there is far more to Signal K Server.
If you are a boat owner, you can easily run Signal K Server on a Victron Cerbo GX, RaspberryPi or similar hardware. To take full advantage, you will probably want to connect it to your boat network via NMEA 0183 or NMEA 2000 but it is not a requirement.
For Marine vendors who build marine hardware and software, for example those developing navigation, monitoring and tracking systems, Signal K Server is an opportunity to accelerate development and decrease time to market, by taking advantage of a proven, modern and extensible software platform that is open source and available with a permissive Apache 2.0 license. Signal K Server is implemented in Node.js and is easy to integrate into modern systems that run Linux derivatives.
Signal K Server is already running inside products developed by Victron Energy, Airmar Technology and others.
There are many boaters who happen to be highly skilled software developers and engineers, who want to build software for themselves and share with others. If you are one of them, Signal K offers you a free, modern and open platform developed by boaters for other boaters like you. Signal K Server features an extensible plugin framework, web applications as well as a rich set of REST and Streaming APIs.
Signal K Server takes care of all the complicated parts of protocol decode, and conversions to and from NMEA2000, NMEA0183 and many more protocols. It can also act as data hub for additional sensors, see the Signal K SensESP project for ESP32.
Signal K Server makes the data available in JSON format according to the Signal K standard specification. This allows developers to bypass all the hurdles typically encountered when wanting to implement something for a boat. Getting started with a plugin is surprisingly easy.
Signal K is more than just the Signal K Server, it is a comprehensive platform that encompasses three major components:
- The Signal K Data Standard: an open marine data standard. It is a modern data format for marine use, suitable for WiFi, cellphones, tablets and the internet. It is built on standard web technologies including JSON, WebSockets and HTTP. More information on https://signalk.org.
- Signal K Server: Software in this GitHub repository and described in this document. Signal K server is a full stack application developed in Node.js. Its back-end multiplexes data from and to NMEA0183, NMEA 2000, Signal K and other marine protocols, as well as WiFi, LAN and Internet, and provides APIs and websockets for access and control. Its front-end provides an extensible web-based application allowing easy configuration and management of server functions and capabilities.
- Signal K Plugins and Webapps: Built using the extensibility of Signal K Server with a plugin framework, allows developers to develop applications that easily integrate with Signal K server, extend its capabilities and publish them through npm. All published plugins become available in all existing Signal K server installations, which provides an easy distribution mechanism.
See Github Discussions and Slack (chat). New to Signal K Slack? Then click here for an invite.
There is a Signal K Server FAQ Frequently Asked Questions on the Wiki, including How do I integrate with NMEA2000 (CAN bus).
For the typical boater, not being a software developer nor electrical engineer, the best option is to get a (commercially available) product that already has Signal K Server inside. These are the currently available devices:
- SmartBoat module by Airmar
- Cerbo GX and other GX Devices by Victron Energy (see Venus OS Large manual)
For a more technical DIY oriented boater, a RaspberryPi based setup offers a very cost-attractive alternative. Read this FAQ entry to learn how to connect a RaspberryPi to an NMEA2000 network.
These prebuilt images for RaspberryPis take away most of the complexity involved from the software side:
- BBN Marine OS
- OpenPlotter by OpenMarine
- Venus OS for RaspberryPis by Victron Energy
You can run Signal K Server in Docker:
And an installer for Windows:
Another level up, this document explains how to install Signal K Server, as well as its dependencies, on a RaspberryPi that is already running Raspberry Pi OS:
Last, here is how to install the Signal K Server application from NPM:
Prerequisites:
-
Node.js version 18 with latest npm installed (the server works for the time being on Node version >=16)
$ sudo npm install -g signalk-server
Now you can start the server with sample data:
- NMEA0183 sample data:
signalk-server --sample-nmea0183-data
- NMEA2000 sample data:
signalk-server --sample-n2k-data
To generate your own vessel settings file and configure the server to start automatically, run:
$ sudo signalk-server-setup
For all described options of running Signal K Server, ie. on an Airmar Smartboat, a Victron Cerbo GX or a RaspberryPi, the way to configure it is via the Admin UI. Open the Admin UI by navigating to http://[ipaddress]:3000/. Here is what it will look like when opened up on a Victron Cerbo GX:
The top of the screen shows some actual stats. Below that is a pane showing all configured Connections & Plugins. These are the plugins shown in above screenshot:
sk-to-nmea0183
is the plugin that makes navigation data available on WiFi and/or LAN (TCP); typically used by apps on phones and tablets.signalk-n2kais-nmea0183
is another plugin, does the same, but then for AIS datavenus
is a plugin that connects to the data bus inside the Victron GX devicen2k-on-ve.can-socket
is not a plugin but a data connection. This one defines the Signal K Server connection to the NMEA2000 CAN-bus port.
The first thing to do is create an admin account. This is done in the Settings -> Users page:
Besides recommended from a security point of view, setting an admin account also enables the Restart button.
After creating the account, the server needs to be restarted. How to do that depends on how you are using Signal K Server: self installed from NPM, embedded on a commercial device or otherwise. Power cycling the device that Signal K Server is running on will always work.
This screenshot shows how to setup an NMEA0183 connection:
The Appstore menu is where to add, update and remove Plugins and Webapps:
The entries with the blue icons are Webapps. The entries with the green icons are Plugins. An internet connection is required for Signal K Server to fetch information about availble Plugins and webapps.
Typically, plugins make for functionality such as protocol conversion. And Webapps provide a user interface, up to a fully featured Chartplotter that runs in a web browser:
To install Plugins and Webapps, click the "Available" menu on the left. It will show a categorised list of all available Plugins:
It is also possible to search for and browse Plugins and Webapps in the NPM registry:
Most configuration changes and installing add-ons from the App store require a server restart to take effect. See Restart button at the top right or restart the server manually (details depend on your setup). If the restart button is not showing, that is usually because security is not activate and there is no Admin user.
After the restart, the new Plugin needs to be enabled and configured. See the Server -> Plugin Config menu:
You can change the admin application's top left logo by placing a SVG file named logo.svg
in the settings directory (default: $HOME/.signalk/).
If the Admin UI is available, go to Server -> Server Log to see the server's log. Different errors are logged there, so in case of trouble make sure to check not only the Admin UI but also the server log.
To activate more details debug logging enter the the names of the components you want to debug. Some of the debug keys are listed with toggles to activate them.
With the Remember debug setting enabled, the configured debug keys parameter is stored in a settings file, ie. survives a server restart.
To enable debugging without going through the Admin UI, see the file ~/.signalk/debug
and add the required debug keys there. For example: @signalk/aisreporter,signalk-server:udp-provider
.
- NMEA2000 PGNs: Reading NMEA2000 data is done by n2k-signalk via canboatjs. Canboat PGN database
- NMEA0183 sentences: nmea0183-signalk
- TODO ADD OTHER SUPPORTED PROTOCOLS
PORT
override the port for http/ws service (default is 3000).SSLPORT
override the port for https/wss service. If defined activates ssl as forced, default protocol (default is 3443).PROTOCOL
override http/https where the server is accessed via https but the server sees http (for example when Heroku handles https termination)EXTERNALPORT
the port used in /signalk response and Bonjour advertisement. Has precedence over configuration file.EXTERNALHOST
the host used in /signalk response and Bonjour advertisement. Has precedence over configuration file.FILEUPLOADSIZELIMIT
override the file upload size limit (default is '10mb').NMEA0183PORT
override the port for the NMEA 0183 over tcp service (default is 10110).TCPSTREAMPORT
override the port for the Signal K Streaming (deltas) over TCP.TCPSTREAMADDRESS
override the address the Signal K Stream (deltas) over TCP is listening on.DISABLEPLUGINS
disable all plugins so that they can not be enabled (default is false).DEFAULTENABLEDPLUGINS
a comma separated list of plugin ids that are overridden to be enabled by default if no setttings exist. lower preference thanDISABLEPLUGINS
.PLUGINS_WITH_UPDATE_DISABLED
a comma separated list of plugin that will not be updated.SECURITYSTRATEGY
override the security strategy module name.WSCOMPRESSION
compress websocket messages (default is false).MAXSENDBUFFERSIZE
the maximum number of bytes allowed in the server's send buffer of a WebSocket connection. The connection will be terminated if this is exceeded. Guards against slow or dysfunctional clients that can not cope with the message volume (default is 512 * 1024 bytes).SIGNALK_SERVER_IS_UPDATABLE
allows the server to be updated through the GUI even if it is not installed in the standard paths (default is false). if set to true, the server must have been installed withnpm install -g signalk-server
.SIGNALK_DISABLE_SERVER_UPDATES
disables server updates in the GUI (default is false).DEBUG
a comma-separated list of tags for debugging the specified module (For example: signalk-server*,signalk-provider-tcp). Can now be defined directly in the graphical interface. More help on how to use the debug here: https://www.npmjs.com/package/debug#wildcardsIS_IN_DOCKER
used to tell the server it is in Docker and not normally updateable (default is false).NPMREGISTRYTIMEOUT
how long to wait for the registry when retrieving the App Store listing (default is 20s).SECRETKEY
a secret string used to generate an authentication token (the internal default autogenerated is a string of 512 hex chars like 'ef8307a4c7a4bd7...309d947bca3')ALLOW_DEVICE_ACCESS_REQUESTS
used when a device needs to gain access to a secured Signal K server (default is true) (https://signalk.org/specification/1.4.0/doc/access_requests.html).ALLOW_NEW_USER_REGISTRATION
(default is true).ADMINUSER
force a account for admin user (username:password format).PRESERIALCOMMAND
command to run before opening a serial port.MFD_ADDRESS_SCRIPT
command to run to provide a comma separate list of server addresses to advertise to (Navico) MFDs.SIGNALK_NODE_SETTINGS
override the path to the settings file.SIGNALK_NODE_CONFIG_DIR
override the path to find server configuration. Includes all run-time changing content: configuration files, plugins, plugin configuration files, webapps, and so forth.
-c
: same as env variableSIGNALK_NODE_SETTINGS
-s
: same as env variableSIGNALK_NODE_CONFIG_DIR
--sample-nmea0183-data
: starts signalk-server with sample NMEA0183 data.--sample-n2k-data
: starts signalk-server with sample NMEA2000 data.--override-timestamps
: overrides timestamps in the sample NMEA2000 data with current date and time. Doesn't apply nor makes a difference to NMEA0183 sample data.--securityenabled
: one of the ways to enable security. For a fresh install this makes the Admin UI force the user to create an admin account before he/she can continue further into the UI. See SECURITY.md#enabling-security for further details.
The documents provide more details about developing Webapps or Plugings for Signal K Server, as well as working on the server itself:
- Contributing to this repo
- Server Plugins
- Webapps
- Working with the Course API
- Working with the Resources API
- Resource Provider Plugins
- Security
git clone https://github.com/SignalK/signalk-server.git
cd signalk-server
npm install
npm run build:all
Start the server with sample data:
- NMEA0183 sample data:
bin/nmea-from-file
- NMEA2000 sample data:
bin/n2k-from-file
This will start the server with a sample configuration file and the server will start playing back data from a sample file under samples/
. The data is available immediately via the REST interface at https://localhost:3000/signalk/v1/api/.
This small demo shows how to connect the Signal K Server WebSocket interface from the command line:
npm install -g wscat2
wscat 'ws://localhost:3000/signalk/v1/stream?subscribe=all'
See Signal K on Open Collective.
Copyright [2015] [Fabian Tollenaar, Teppo Kurki and Signal K committers]
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.