本篇內容主要講解“如何通過InfluxDB來存儲相關的信息”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何通過InfluxDB來存儲相關的信息”吧!
成都創(chuàng)新互聯(lián)專業(yè)提供服務器托管服務,為用戶提供五星數據中心、電信、雙線接入解決方案,用戶可自行在線購買服務器托管服務,并享受7*24小時金牌售后服務。
InfluxDB 是一個由 InfluxData 開發(fā)的開源時序型數據庫。 它由 Go 寫成,著力于高性能地查詢與存儲時序型數據,相比上一期中介紹的 OpenTSDB 數據庫 InfluxDB 較為輕量,在 InfluxData 官方給出的各項指標基準測試用 InfluxDB 都強于 OpenTSDB。
面對大規(guī)??焖僭鲩L的物聯(lián)網傳感器采集、交易記錄等數據,時間序列數據累計速度非???,時序數據庫通過提高效率來處理這種大規(guī)模數據,并帶來性能的提升,包括:更高的容納率(Ingest Rates)、更快的大規(guī)模查詢(盡管有一些比其他數據庫支持更多的查詢)以及更好的數據壓縮。
下載安裝 InfluxDB 服務器,本文使用 InfluxDB 1.7 版本。
通過 RPM 方式安裝的 EMQ X,InfluxDB 相關的配置文件位于 /etc/emqx/plugins/emqx_backend_influxdb.conf
,考慮到功能定位,InfluxDB 插件僅支持消息存儲功能。
配置連接地址與連接池大?。?/strong>
## InfluxDB UDP Server ## 僅使用 UDP 接入 backend.influxdb.pool1.server = 127.0.0.1:8089 ## InfluxDB Pool Size backend.influxdb.pool1.pool_size = 5 ## Whether or not set timestamp when encoding InfluxDB line backend.influxdb.pool1.set_timestamp = trues
**InfluxDB Backend 消息存儲規(guī)則參數: **
通過 topic 過濾器,設置需要存儲消息的主題,pool 參數區(qū)別多個數據源:
## Store Publish Message backend.influxdb.hook.message.publish.1 = {"topic": "#", "action": {"function": "on_message_publish"}, "pool": "pool1"}
啟動該插件,啟動插件的方式有 命令行
和 控制臺
兩種方式,用戶可以任選其一。
由于 MQTT Message 無法直接寫入 InfluxDB, InfluxDB Backend 提供了 emqx_backend_influxdb.tmpl 模板文件將 MQTT Message 轉換為可寫入 InfluxDB 的 DataPoint。
消息模板功能需要重啟 EMQ X 才能應用更改。
tmpl 文件位于 data/templates/emqx_backend_influxdb_example.tmpl
,使用 json 格式, 用戶可以為不同 Topic 定義不同的 Template, 類似:
{ "timestamp":"measurement": , "tags": { : }, "fields": { : } }
其中, measurement 與 fields 為必選項, tags 與 timestamp 為可選項。$key
提取變量名為 key
的變量,支持的變量如下:
qos: 消息 QoS
form: 發(fā)布者信息
topic: 發(fā)布主題
timestamp: 時間戳
payload.*: JSON 消息體內任意變量,如 { "data": [{ "temp": 1 }] }
使用 ["$payload", "data", "temp"]
可以提取出 1
來
本示例設定模板如下:
{ "sample": { "measurement": "$topic", "tags": { "host": ["$payload", "data", "$0", "host"], "region": ["$payload", "data", "$0", "region"], "qos": "$qos", "from": "$from" }, "fields": { "temperature": ["$payload", "data", "$0", "temp"] }, "timestamp": "$timestamp" } }
當 Topic 為 "sample" 的 MQTT Message 擁有以下 Payload 時:
{ "data": [ { "temp": 1, "host": "serverA", "region": "hangzhou" }, { "temp": 2, "host": "serverB", "region": "ningbo" } ] }
Backend 會將 MQTT Message 轉換為:
[ { "measurement": "sample", "tags": { "from": "mqttjs_ebcc36079a", "host": "serverA", "qos": "0", "region": "hangzhou" }, "fields": { "temperature": "1" }, "timestamp": "1560743513626681000" }, { "measurement": "sample", "tags": { "from": "mqttjs_ebcc36079a", "host": "serverB", "qos": "0", "region": "ningbo" }, "fields": { "temperature": "2" }, "timestamp": "1560743513626681000" } ]
EMQ X 管理控制臺 WebSocket頁面中,向 sample
主題發(fā)布如上格式消息消息,消息將解析存儲到 InfluxDB udp
數據庫對應的 measurement
中。
到此,相信大家對“如何通過InfluxDB來存儲相關的信息”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!