Difference between revisions of "V2/Integrate/Others"
Elysia.Tan (talk | contribs) (Created page with "<h1 class="main-heading">Connectors for 3rd Party Applications</h1>") |
|||
(5 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
− | <h1 class="main-heading"> | + | <h1 class="main-heading">Implementing a connector</h1> |
+ | |||
+ | Senfi monitors and stores time series data from your existing systems. At the moment, Senfi provides two methods of receiving data from your systems: | ||
+ | * [https://mqtt.org/ MQTT] interface. See [[V2/Integrate/Others/MQTT|Publish to MQTT]]. | ||
+ | * [https://www.senfi.io/docs/api/1/1/ Senfi API] | ||
+ | |||
+ | === Supported Metric Data Types === | ||
+ | Senfi supports the following data types | ||
+ | * Float | ||
+ | * Integer | ||
+ | * Boolean | ||
+ | * String | ||
+ | |||
+ | ;'''Float''' | ||
+ | :Only valid JSON Number is accepted. | ||
+ | :* <tt>0</tt> | ||
+ | :* <tt>0.1</tt> | ||
+ | :* <tt>1.0e+10</tt> | ||
+ | |||
+ | :Invalid examples: | ||
+ | :* <tt>1.0.0</tt> | ||
+ | :* <tt>"1.0"</tt> | ||
+ | |||
+ | ;'''Integer''' | ||
+ | :Only valid JSON Number is accepted. Decimal values are truncated. | ||
+ | :* <tt>0</tt> | ||
+ | :* <tt>-15</tt> | ||
+ | :* <tt>1e10</tt> | ||
+ | |||
+ | :Invalid examples: | ||
+ | :* Same as '''Float''' | ||
+ | |||
+ | ;'''Boolean''' | ||
+ | :Only JSON Boolean is accepted. | ||
+ | :* true | ||
+ | :* false | ||
+ | :Invalid examples: | ||
+ | :* "true" | ||
+ | :* "FALSE" | ||
+ | :* 0 | ||
+ | :* "1" | ||
+ | |||
+ | ;'''String''' | ||
+ | :Any valid JSON String is accepted. | ||
+ | |||
+ | === Publishing Strategy === | ||
+ | You can either choose to publish data to Senfi regularly (eg. every second), or only do so upon a change in the metrics. In practice, it is recommended that you publish regularly. This is so that the system is able to tell when data has stopped coming in. | ||
+ | |||
+ | In addition, you can choose to batch the sending of measurements to Senfi. For example, collect 50 measurements and then publish it in a single message. This may be useful if you have fast changing metrics. However, note that tm_source (see [[V2/Integrate/Others/MQTT#Message Format|Message Format]]) should represent when the measurement is sampled and not when it is sent. |
Latest revision as of 17:50, 9 May 2022
Implementing a connector
Senfi monitors and stores time series data from your existing systems. At the moment, Senfi provides two methods of receiving data from your systems:
- MQTT interface. See Publish to MQTT.
- Senfi API
Supported Metric Data Types
Senfi supports the following data types
- Float
- Integer
- Boolean
- String
- Float
- Only valid JSON Number is accepted.
- 0
- 0.1
- 1.0e+10
- Invalid examples:
- 1.0.0
- "1.0"
- Integer
- Only valid JSON Number is accepted. Decimal values are truncated.
- 0
- -15
- 1e10
- Invalid examples:
- Same as Float
- Boolean
- Only JSON Boolean is accepted.
- true
- false
- Invalid examples:
- "true"
- "FALSE"
- 0
- "1"
- String
- Any valid JSON String is accepted.
Publishing Strategy
You can either choose to publish data to Senfi regularly (eg. every second), or only do so upon a change in the metrics. In practice, it is recommended that you publish regularly. This is so that the system is able to tell when data has stopped coming in.
In addition, you can choose to batch the sending of measurements to Senfi. For example, collect 50 measurements and then publish it in a single message. This may be useful if you have fast changing metrics. However, note that tm_source (see Message Format) should represent when the measurement is sampled and not when it is sent.