Controllers play an important role in Draco. This component is in charge of managing all the functions needed for using different external data storage. In our case, we use controllers for establishing and configure the connection between Draco and third-party storage.
As we state at the beginning of the document, Draco is intended to be used for ingesting NGSI events to some sinks using the NGSI standard for managing context information. The current version of Draco is able to persist data in the following DB's:
- MySQL (using the DBCPConnectionPoll controller).
- PostgreSQL (using the DBCPConnectionPoll controller).
- MongoDB (configured directly into the Processor).
As you can notice MySQL and PostgreSQL needs to use the DBCPConnectionPoll controller. Thus, in this section, we will explain how to configure that controller.
First, follow the steps in Draco GUI for adding a new controller. Then, in the add controller page, select the DBCPConnectionPoll controller.
Now, click on the configuration button of the DBCPConnectionPool controller and go the properties Tab.
Note: This version of Draco, includes a drivers folder with the drivers for MySQL and PostgreSQL and also a templates folder with preconfigured values for each controller.
The next figure shows the values needed for configuring the DBCPConnectionPoll controller for storing NGSI events to MySQL.
Database Connection URL jdbc:mysql://: jdbc:mysql://127.0.0.1:3306
Database Driver Class Name
com.mysql.jdbc.Driver
Database Driver Location(s)
./drivers/mysql-connector-java-5.1.38.jar
Database User (full grant user)
root
Password Max Wait Time
500 millis
Max Total Connections
8
The next figure shows the values needed for configuring the DBCPConnectionPoll controller for storing NGSI events to PostgreSQL.
Database Connection URL
jdbc:postgresql://<postgresql-host-ip>:<postgresql-port>
jdbc:postgresql://127.0.0.1:5432/
Database Driver Class Name
org.postgresql.Driver
Database Driver Location(s)
./drivers/postgresql-42.2.4.jar
Database User (full grant user)
postgres
Password
<your-password>
Max Wait Time
500 millis
Max Total Connections
8
For the DBCPConnectionPoll controller, a list with all the parameters and his description is provided below, the names of required properties appear in bold. Any other properties (not in bold) are considered optional. The table also indicates any default values, whether a property supports the NiFi Expression Language, and whether a property is considered "sensitive", meaning that its value will be encrypted. Before entering a value in a sensitive property, ensure that the nifi.properties file has an entry for the property nifi.sensitive.props.key.
Name | Default Value | Allowable Values | Description |
---|---|---|---|
Database Connection URL | A database connection URL used to connect to a database. May contain database system name, host, port, database name and some parameters. The exact syntax of a database connection URL is specified by your DBMS.Supports Expression Language: true (will be evaluated using variable registry only) | ||
Database Driver Class Name | Database driver class nameSupports Expression Language: true (will be evaluated using variable registry only) | ||
Database Driver Location(s) | Comma-separated list of files/folders and/or URLs containing the driver JAR and its dependencies (if any). For example '/var/tmp/mariadb-java-client-1.1.7.jar'Supports Expression Language: true (will be evaluated using variable registry only) | ||
Database User | Database user nameSupports Expression Language: true (will be evaluated using variable registry only) | ||
Password | The password for the database userSensitive Property: trueSupports Expression Language: true (will be evaluated using variable registry only) | ||
Max Wait Time | 500 millis | The maximum amount of time that the pool will wait (when there are no available connections) for a connection to be returned before failing, or -1 to wait indefinitely. | |
Max Total Connections | 8 | The maximum number of active connections that can be allocated from this pool at the same time, or negative for no limit. | |
Validation query | Validation query used to validate connections before returning them. When connection is invalid, it get's dropped and new valid connection will be returned. Note!! Using validation might have some performance penalty.Supports Expression Language: true (will be evaluated using variable registry only) |
MongoDB doesn't need a controller configuration, instead, all of that configuration is done directly in the processor NGSIToMongo.