Skip to content

Commit

Permalink
Merge pull request #2 from slawr/iotdb-doc
Browse files Browse the repository at this point in the history
doc: document use of Apache IoTDB for state storage/data store
  • Loading branch information
UlfBj authored Mar 13, 2024
2 parents 523f94c + cedd242 commit ef5a33b
Show file tree
Hide file tree
Showing 4 changed files with 156 additions and 6 deletions.
6 changes: 5 additions & 1 deletion server/vissv2server/serviceMgr/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,11 +26,13 @@ See the README in the histCtrlSim directory.
The VISSv2 service manager is started with input on which state storage implementation to use:
- SQLite (default)
- Redis
- Apache IoTDB
- None

At startup,<br>
- for SQLite it tries to read a DB file named statestorage.db, located in the same directory.
- for Redis it tries to instantiate a Redis client for the configured Redis DB.
- for Redis it tries to instantiate a Redis client for the configured Redis DB.
- for Apache IoTDB it uses the IoTDB Go client to create a session connection to the configured IoTDB server.
- For None, the server will instead of accessing data from a DB, instead generate a dummy integer value, see below.

Dummy values are always an integer, taken from a counter that is incremented every 37 msec, and wrapping to stay within the values 0 to 999.
Expand All @@ -54,6 +56,8 @@ where VIN is any string representing the desired VIN.<br>
If the state storage is started using the SQLite DB, the following must be prepared before starting the server.<br>
- The SQLite DB file must be created and stored in the directory of the service manager. Creating it can be done using the Statestorage manager found at https://github.com/COVESA/ccs-components/tree/master/statestorage/sqlImpl. It must be generated with an identical copy of the vsspathlist.json file that the VISSv2 server creates at startup (from the vss_vissv2.binary file).

Documentation on using Apache IoTDB as the state storage can be found in the VISSv2 online documentation.


## Curve logging
Geotab has opened up the curve logging patents for public use, see <a href="https://github.com/Geotab/curve">Curve logging library</a>.
Expand Down
4 changes: 2 additions & 2 deletions tutorial/content/datastore/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ title: "WAII Data Storage"
---

Two realizations of data storage are available on the [COVESA/CCS-components Github](https://github.com/COVESA/ccs-components),
one using an SQLite database, and the other a Redis database.
one using an SQLite database, and the other a Redis database. In addition WAII also supports connection to an Apache IoTDB server.

The server implements the APIs to both of these databases, which to use is selected by its command line configuration.
The server implements the APIs to these databases, which to use is selected by its command line configuration.

The same support should be available on the other SwC that accesses the data storage,
however the current feeder implementation only implements Redis support, hence it is not merged into the master branch but resides on the feeder branch.
Expand Down
146 changes: 146 additions & 0 deletions tutorial/content/datastore/apache-iotdb/_index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
---
title: "WAII Apache IoTDB"
---

## Introduction
Description of Apache IoTDB from https://iotdb.apache.org/:

*"Apache IoTDB (Database for Internet of Things) is an IoT native database with high performance for data management and analysis, deployable on the edge and the cloud. Due to its light-weight architecture, high performance and rich feature set together with its deep integration with Apache Hadoop, Spark and Flink, Apache IoTDB can meet the requirements of massive data storage, high-speed data ingestion and complex data analysis in the IoT industrial fields."*

## Scope
Support for Apache IoTDB as the WAII data store is implemented by connector code in the WAII service manager, which connects WAII to an external Apache IoTDB server. This code uses the IoTDB Go client to maintain a connection session to the IoTDB server, which is then used to get/set vehicle data from the database.

As WAII and the IoTDB server are separate processes WAII needs to be told where to find the IoTDB server and which storage prefix to use to access the data. The administration of the Apache IoTDB server itself, including startup and shutdown, is out of scope and is handled externally to WAII.

## Runtime notes

### Assumptions
Runtime assumptions:
1. IoTDB server lifecycle (e.g. startup and shutdown) is handled externally to WAII
2. Management (e.g. creation/deletion) of the IoTDB timeseries containing VSS data is handled externally to WAII.
3. Configuration of the connector code is specified in the config file iotdb-config.json. If the config file is not found then build-time defaults are used.

Handling of IoTDB server and timeseries management is placed outside of WAII to allow flexible deployment through loosely coupled connections.
### Database schema
The connector assumes a simple key/value pair schema for accessing VSS data in an IoTDB timeseries:

1. VSS node names (keys) are backtick quoted when stored as measurement keys in the database e.g. `` `Vehicle.CurrentLocation.Longitude` ``. This avoids IoTDB interpreting the VSS tree path, here `Vehicle.CurrentLocation.`, as part of its storage path which also uses a dot notation.

2. VSS data is stored using native (IoTDB) data types rather than strings.

3. That the timeseries containing VSS nodes can be found using the prefix path specified in the config file.

Example timeseries:
```
+------------------------+-----------------------------------------------------+--------+--------+
| Time| Timeseries| Value|DataType|
+------------------------+-----------------------------------------------------+--------+--------+
|2024-03-07T17:55:24.514Z| root.test2.dev1.`Vehicle.CurrentLocation.Longitude`|-42.4567| FLOAT|
+------------------------+-----------------------------------------------------+--------+--------+
```

### Configuration
The connection code reads its runtime configuration from the JSON formatted file `iotdb-config.json` located in the vissv2server directory. All values should be specified.

#### Configuration file format

| Key name | Type | Description |
| --- | --- | ---
|`host`|String|Hostname or IP address of the IoTDB server|
|`port`|String|RPC port of the server. Default is 6667|
|`username`|String|Username to access the server. Default is root|
|`password`|String|Password to access the server. Default is root|
|`queryPrefixPath`|String|Timeseries prefix path of VSS data in the database|
|`queryTimeout(ms)`|Int| Query timeout in milliseconds|


Example `iotdb-config.json`:
```
{
"host": "127.0.0.1",
"port": "6667",
"username": "root",
"password": "root",
"queryPrefixPath": "root.test2.dev1",
"queryTimeout(ms)": 5000
}
```
### Logging
The connector writes information, warning and error messages to the WAII server log with the prefix ``IoTDB``. Grepping in the log for that prefix string can help you quickly identify connector messages.

## Quick start notes
The following notes are intended to help you quickly try out using Apache IoTDB as a data store.

The Apache IoTDB project [website](https://iotdb.apache.org/) has extensive documentation on the IoTDB server.

### Apache IoTDB images
The Apache IoTDB community maintains pre-built server images upstream to [download](https://iotdb.apache.org/Download/). Including containerised Docker images in [Docker Hub](https://hub.docker.com/r/apache/iotdb). IoTDB is available in both standalone (edge) and cluster (cloud) versions. Standalone is suggested as a starting point.

The [COVESA Central Data Service Playground](https://github.com/COVESA/cdsp) provides a Docker deployment that combines an Apache IoTDB server (data store) with the WAII VISS data server.

### Seeding the database with VSS data
To seed the database with VSS data the typical steps are:
1. Create the database in the server
2. Create a timeseries in the database populated with the VSS nodes (keys) you are interested in.
3. Add some example data so the VISS Data Server can successfully get data.

IoTDB has a very extensive collection of integrations, tools, clients and APIs that could be used to achieve this.

#### Example using IoTDB CLI client
The following tutorial shows an example using the [IoTDB CLI client](https://iotdb.apache.org/UserGuide/latest/Tools-System/CLI.html), using two methods. Firstly, in interactive mode where you type the commands and then sending the same commands in batch command mode.


1. Connect to the CLI client from your host:
```
$ bash <iotdb path>/sbin/start-cli.sh -h <server hostname/ip>
```
2. Create database from CLI command line:
```
IoTDB > create database root.test2.dev1
```
3. Create timeseries from CLI command line:
```
IoTDB > CREATE ALIGNED TIMESERIES root.test2.dev1(`Vehicle.CurrentLocation.Longitude` FLOAT, `Vehicle.CurrentLocation.Latitude` FLOAT, `Vehicle.Cabin.Infotainment.HMI.DistanceUnit` TEXT)
```
4 Add some data into the timeseries:
```
IoTDB> insert into root.test2.dev1(`Vehicle.CurrentLocation.Longitude`, `Vehicle.CurrentLocation.Latitude`, `Vehicle.Cabin.Infotainment.HMI.DistanceUnit`) values(-42.4567, 22.1234, 'MILES')
```
5. Display the data just added as a sanity check:
```
IoTDB> select last * from root.test2.dev1
+------------------------+-------------------------------------------------------------+--------+--------+
| Time| Timeseries| Value|DataType|
+------------------------+-------------------------------------------------------------+--------+--------+
|2024-03-07T17:55:24.514Z| root.test2.dev1.`Vehicle.CurrentLocation.Longitude`|-42.4567| FLOAT|
|2024-03-07T17:55:24.514Z|root.test2.dev1.`Vehicle.Cabin.Infotainment.HMI.DistanceUnit`| MILES| TEXT|
|2024-03-07T17:55:24.514Z| root.test2.dev1.`Vehicle.CurrentLocation.Latitude`| 22.1234| FLOAT|
+------------------------+-------------------------------------------------------------+--------+--------+
```
You have now seeded the database with some initial VSS data and can use WAII to query it.

The CLI client startup script accepts SQL commands using the `-e` parameter. We can therefore use this to codify the above in a bash script. So the VSS node names (keys) are passed correctly on the command line the backticks must be escaped.

For example:
```
# !/bin/bash
host=127.0.0.1
rpcPort=6667
user=root
pass=root
bash ./sbin/start-cli.sh -h ${host} -p ${rpcPort} -u ${user} -pw ${pass} -e "create database root.test2.dev1"
bash ./sbin/start-cli.sh -h ${host} -p ${rpcPort} -u ${user} -pw ${pass} -e "CREATE ALIGNED TIMESERIES root.test2.dev1(\`Vehicle.CurrentLocation.Longitude\` FLOAT, \`Vehicle.CurrentLocation.Latitude\` FLOAT, \`Vehicle.Cabin.Infotainment.HMI.DistanceUnit\` TEXT)"
bash ./sbin/start-cli.sh -h ${host} -p ${rpcPort} -u ${user} -pw ${pass} -e "insert into root.test2.dev1(\`Vehicle.CurrentLocation.Longitude\`, \`Vehicle.CurrentLocation.Latitude\`, \`Vehicle.Cabin.Infotainment.HMI.DistanceUnit\`) values(-42.4567, 22.1234, 'MILES')"
bash ./sbin/start-cli.sh -h ${host} -p ${rpcPort} -u ${user} -pw ${pass} -e "select last * from root.test2.dev1"
```

Of course any of the programming language clients provided by IoTDB, e.g. go, python, C++, Rust, can also be used to achieve the same result.

## Development notes
Please see the notes in the source commit messages and related Github pull requests for the history of the development of the Apache IoTDB connection code and its integration into the WAII Service Manager component.

Development followed the patterns set by the existing support for Redis and SQLite.

The connection code was first developed with Apache IoTDB v1.2.2, using the upstream standalone pre-built image and Apache IoTDB Go Client v1.1.7.
6 changes: 3 additions & 3 deletions tutorial/content/server/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ This can either be done by editing vspec files directly, or using the [VSS-Tools

#### Command line configuration
The server has the following command line configurations:
* Data storage implementation. Select either to use an SQLite implementation (-s sqlite) or a Redis implementation (-s redis). Default is SQLite.
* Data storage implementation. Select one of the following options: SQLite (-s sqlite), Redis (-s redis) or Apache IoTDB (-s apache-iotdb). Default is SQLite.
* Data storage file name (--dbfile 'file-name'). Only relevant for SQLite configuration. Default is "serviceMgr/statestorage.db".
* Request the server to generate a pathlist file, then terminate (--dryrun). Default is not to terminate after generating it.
* Pathlist file name (--vssjson 'file-name'. Default is "../vsspathlist.json".
Expand All @@ -40,8 +40,8 @@ The server has the following command line configurations:
* Whether logging should end up in standard output (false) or in a log file (true) (--logfile false/true). The default is 'false'.

#### Data storage configuration
Currently the server supports two different databases, SQLite and Redis, which one to use is selected in the command line configuration.
However, to get it up and running there are other preparations lso needed, please see the [VISSv2 Data Storage](/automotive-viss2/datastore) chapter.
Currently the server supports three different databases, SQLite, Redis and Apache IoTDB, which one to use is selected in the command line configuration.
However, to get it up and running there are other preparations also needed, please see the [VISSv2 Data Storage](/automotive-viss2/datastore) chapter.

#### Protocol support configuration

Expand Down

0 comments on commit ef5a33b

Please sign in to comment.