LEAPS Server
はじめに
LEAPS Serverは、UWBネットワークの中央データハブです。すべてのゲートウェイデバイスを MQTT Broker を介して世界と相互接続します。
主な機能
- アップリンクデータコンセントレータ、ダウンリンクデータルータ、データプロセッサ、位置情報エンジン、デバイス管理、デバイスアクセス制御、およびQoS(Quality of Service)として機能します。 
- コネクタを介して世界と通信します。現在サポートされているコネクタは、AWSを含むMQTTです。 
- LEAPS Server は、Linuxプラットフォーム上でデーモンサービスとして実行されます。 
インストール
システム要件
注釈
Dockerのシステム要件はOSによって異なります。
- Linuxの場合、64ビットアーキテクチャ、互換性のあるカーネルバージョン、および特定のカーネル機能が必要です。 
- Windowsの場合は、仮想化を有効にしたWindows 10でDocker Desktopを使用してください。 
- macOSの場合は、macOS 10.13以降のDocker Desktopを使用してください。ハードウェアに関しては、最低2GBのRAMと十分なCPUとディスク容量を推奨します。 
最新の詳細については Docker 公式ドキュメントを参照してください。
使用方法
- PCにDockerをインストールする 
さらに、以下のコマンドを参考にしてインストールすることもできる:
curl -fsSL https://get.docker.com -o get-docker.sh sudo sh ./get-docker.sh sudo usermod -aG docker $USER
- フォルダ - leaps_server_hubとサブフォルダ- dataを作成します。次に、- leaps_server_hub/dataに- leaps-server.conf設定ファイルを追加します。
####################################################################### # LEAPS Server settings # # ----------------------------------------------------------------- # Logging # ----------------------------------------------------------------- log_level = 0 # Logging level, default is 0 (0=none, 1=fatal, 2=error, 3=warning, 4=info, 5=debug, 6=verbose) # Path to log file. Comment out to disable logging to file (log to stdio instead). # log = leaps-server.log # ----------------------------------------------------------------- # Certificate based SSL/TLS support # ----------------------------------------------------------------- # # cafile - Authority certificates that have signed your server certificate. # certfile - Path to the PEM encoded server certificate. # keyfile - Path to the PEM encoded keyfile. # gw_auth - When using TLS on the interface with the gateways, this parameter configures TLS authentication between server and the gateway (0=server 1=mutual). # # cafile = /etc/leaps-server/cacert.pem # certfile = /etc/leaps-server/servercert.pem # keyfile = /etc/leaps-server/serverkey.pem # gw_auth = 0 # Optional AES 128-bit private key as hexadecimal number. If specified, the key is used to encrypt sensitive data # for example the WiFi password published on the MQTT interface. # aes_128_key = 00112233445566778899aabbccddeeff # ----------------------------------------------------------------- # MQTT Broker # ----------------------------------------------------------------- # MQTT API variant "pans" or "leaps" mqtt_api = pans # include network ID (panid) in the MQTT topics mqtt_with_panid = true # Specifies an alias for particular UWB network that is then used in the MQTT topic instead of the network ID (pan ID) . # Parameter can be used multiple times and there might be multiple definitions separated by spaces which are then added to the list of known aliases. # Alias definitions must follow format <ID>:<ALIAS_STRING>. Multiple definitions must be separated with spaces. # Network ID (PAN ID) can be hexadecimal number (withe prefix \"0x\") or decimal number. # mqtt_panid_alias = [123:NetworkA] [0x0002:Net B] # mqtt_panid_alias = [0XABCD:Network_C] mqtt_clid = 1 mqtt_port = 1883 mqtt_host = localhost # Or your Computer's IP Address # For PANS PRO RTLS mqtt_user = pans mqtt_password = panspass mqtt_topic_prefix = pans # For PANS PRO RTLS # mqtt_user = dwmuser # mqtt_password = dwmpass # mqtt_topic_prefix = dwm # Certificates used on MQTT interface # mqtt_cafile = /etc/leaps-server/cacert.pem # mqtt_certfile = /etc/leaps-server/servercert.pem # mqtt_keyfile = /etc/leaps-server/serverkey.pem # Period in seconds after which all retained topics are published regardless # whether the content has changed or not. Disabled when set to 0. Disabled by default. #mqtt_refresh = 0 # ----------------------------------------------------------------- # Secondary MQTT Broker # ----------------------------------------------------------------- # # mqtt_clid_sec = 2 # mqtt_port_sec = 1883 # mqtt_host_sec = # For PANS PRO RTLS # mqtt_user_sec = dwmuser # mqtt_password_sec = dwmpass # Certificates used on MQTT interface # mqtt_cafile_sec = /etc/leaps-server/cacert.pem # mqtt_certfile_sec = /etc/leaps-server/servercert.pem # mqtt_keyfile_sec = /etc/leaps-server/serverkey.pem # ----------------------------------------------------------------- # TCP # ----------------------------------------------------------------- # tcp_port = 7777 # ----------------------------------------------------------------- # Other # ----------------------------------------------------------------- # maximum number of attempts of configuration and service commands # cmd_att = 3
- PCでコマンドプロンプトまたはターミナルウィンドウを開く。 
設定ファイルを作成したフォルダに移動します。
たとえば、Ubuntu (Linux) の場合:
cd leaps_server_hub/
- LEAPS Server Dockerパッケージをインストールします。 
docker run -d -p 7777:7777/tcp -p 7777:7777/udp --name some_name -v /path/to/data/data/:/app/data/ leapslabs/leaps_server:tag /app/leaps-server --cfg /app/data/leaps-server.conf
some_nameはコンテナに割り当てる名前、tagは必要なleaps-serverのバージョンを指定するタグです。leaps_server インスタンスは、ゲートウェイとの
TCPおよびUDP通信にポート7777を使用しているため、コマンド-p 7777:7777/tcp -p 7777:7777/udpを使用して、これらのポートをホストから leaps_server インスタンスに再マッピングする必要があります。必要がない限り、ポート番号を変更することは推奨されません。変更が必要な場合は、ゲートウェイのポート設定を適宜調整してください。
推奨される走行オプション
--user $(id -u):$(id -g)特定のユーザーとグループの下でインスタンスを実行する。
--restart until-stoppedは、サーバーがクラッシュした場合に備えて、インスタンスを自動的に再起動します。
- LEAPS Serverのインストールプロセスが開始されます。 
たとえば、Ubuntu (Linux) の場合:
docker run -d -p 7777:7777/tcp -p 7777:7777/udp --name leaps_server -v "$(pwd)"/data/:/app/data leapslabs/leaps_server:latest /app/leaps-server --cfg /app/data/leaps-server.conf Unable to find image 'leapslabs/leaps_server:latest' locally latest: Pulling from leapslabs/leaps_server a458657ccc71: Pull complete Digest: sha256:a19b127656d41d8607f043c2c83924e5b9a5cbd4dc23cfbed070be3b9cfc6b9a Status: Downloaded newer image for leapslabs/leaps_server:latest 320d3768289874e063619f75faca7a24dd75a08884df8cd8fb2cc9b54c6f0a46
- インストールが成功したことを確認し、実行する: 
たとえば、Ubuntu (Linux) の場合:
docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES b1145b72db35 leapslabs/leaps_server:latest "sh -c 'cd /app && …" 37 seconds ago 11 seconds ago leaps_server
これで、PC上の LEAPS Server が正常にインストールされ、起動しました。
はじめに
LEAPS Server Docker
- LEAPS Serverを起動するには、 - docker start leaps_serverを実行します。
- LEAPS Serverを停止するには、 - docker stop leaps_serverを実行します。
- LEAPS Serverを再起動します。 - docker restart leaps_serverを実行します。
- LEAPS Serverを削除するには、 - docker rm --force leaps_serverを実行します。
ネットワーク構成
- MQTT APIバリアント "pans" または "leaps" 
- 公開トピックにLEAPS IDを追加します。 - mqtt_with_panid = true mqtt_clid = 1 mqtt_port = 1883 mqtt_host = localhost # Or your Computer's IP Address 
- LEAPS RTLSアカウントの設定 - mqtt_user = pansuser mqtt_password = panspass mqtt_topic_prefix = pans 
- TCPポートは7777です。 
トラブルシューティング
- LEAPS Serverを再起動するには、 - docker restart leaps_serverコマンドを使用します。
- LEAPS Server の実行中にログを確認し、Dockerデスクトップを開いて leaps_server コンテナを選択します。