内容简介:IBM Db2 Event Store 是一种内存数据库,旨在快速读取和分析事件驱动应用程序中的流数据。它提供了一种快速数据结构,能够实时处理大量事件,并优化流数据性能,以便获得高级分析和可操作的洞察。在本教程中,我们将运行一个基于 IBM Db2 Event Store 的端到端应用程序。该应用程序代表一个简化的 IoT 用例,其中传感器数据被传输到 Event Store 并可视化。除了运行 IBM Db2 Event Store 之外,您还将完成以下任务:
IBM Db2 Event Store 是一种内存数据库,旨在快速读取和分析事件驱动应用程序中的流数据。它提供了一种快速数据结构,能够实时处理大量事件,并优化流数据性能,以便获得高级分析和可操作的洞察。
在本教程中,我们将运行一个基于 IBM Db2 Event Store 的端到端应用程序。该应用程序代表一个简化的 IoT 用例,其中传感器数据被传输到 Event Store 并可视化。
您将学到的知识
除了运行 IBM Db2 Event Store 之外,您还将完成以下任务:
- 使用 sbt 运行一个 Scala 应用程序
- 创建一个 Kafka 集群
- 了解 IBM Db2 Event Store Scala API
- 安装并使用 Grafana
前提条件
在本教程中,我们将利用可在各种平台上(比如 Windows、MacOS 或 Linux)使用的 Docker。尽管本教程是基于 MacOS 而构建的,但可以轻松调整本教程,以适应 IBM Db2 Event Store Developer Editor 所支持的其他平台,无论是 Windows 还是 Linux。
具体来讲,需要满足以下要求:
- IBM Db2 Event Store Developer Edition 1.1.4
- sbt 0.13.16
- Docker Version 18.06.1-ce-mac73 (26764)
- 运行 Docker 的足够 CPU 和内存,具体来讲至少需要 6 个 CPU 和 8 GB 内存。
- Grafana 5.3.2
预估时间
完成本教程大约需要 1 小时。
步骤
安装 IBM Db2 Event Store Developer Edition
第一步是安装 IBM Db2 Event Store。Event Store 可作为 Desktop Electron App 在 Docker 上运行。
- 根据平台下载最新安装程序
- 备注:对于 MacOS,可在以下地方获取该文件:https://github.com/IBMProjectEventStore/EventStore-DeveloperEdition/releases/download/1.1.4/IBM.Db2.Event.Store.-.Developer.Edition-1.1.4.dmg
- MacOS 或 Windows
- 启动安装程序(dmg 或 exe 格式)并遵循所有默认设置
- 根据您的带宽,此操作可能会花一些时间
安装依赖项
在运行该应用程序之前,让我们首先安装 Kafka 和 Grafana 的流连接器。
克隆适用于 Kafka 的 IBM Db2 Event Store 流连接器
- 安装 sbt V0.13.16
- 通过修改 '/etc/paths’,可以选择将 sbt 添加到 'PATH',以验证 SBT 是否与 0.13.16 版本一致。
./bin/sbt sbt-version
- 克隆适用于 Kafka 的 IBM Db2 Event Store 流连接器
git clone git@github.com:IBMProjectEventStore/db2eventstore-kafka.git cd db2eventstore-kafka
安装 Grafana - 安装 Grafana 5.3.2
brew update brew install grafana brew services restart grafana
- 安装适用于 Grafana 的 IBM Db2 Event Store 数据源
wget https://github.com/IBMProjectEventStore/db2eventstore-grafana/releases/download/ReactiveSummit2018/db2-event-store-grafana-1.1.tar mkdir -p /usr/local/var/lib/grafana/plugins/db2-event-store mv db2-event-store-grafana-1.1.tar /usr/local/var/lib/grafana/plugins/db2-event-store cd /usr/local/var/lib/grafana/plugins/db2-event-store tar -zxvf db2-event-store-grafana-1.1.tar brew services restart grafana
编译适用于 Kafka 的 IBM Db2 Event Store 流连接器cd db2eventstore-kafka sbt clean sbt compile
初始化 IBM Db2 Event Store Developer Edition - 打开 IBM Db2 Event Store Developer Edition
- 打开 Scala notebook“Introduction to IBM Db2 Event Store Scala API”
- 选择图标“Copy to Notebooks”
- 运行前两个单元来创建 TESTDB 数据库
- 通过 Grafana 仪表板对 REST Server 进行初始化
这一步将初始化 Event Store 来支持 Grafana 数据源。它使得 IBM Db2 REST Server 能够接受外部请求。
curl -X POST -H "Content-Type: application/json" -H "authorization: Bearer token" 'http://0.0.0.0:9991/com/ibm/event/api/v1/init/engine?engine=173.19.0.1:1100&rContext=Desktop'
终端将返回 {"code":"ES100","message":"Engine initialization succeeded"}
Grafana 仪表板
- 登录到 Grafana
- 使用默认凭证“admin”和“admin”
- 向 IBM Db2 Event Store 添加一个新数据源
- 添加一个 Db2 Event Store 数据源
- 将主机端口更改为 9991
- 选择“Refresh”和“Save & Test”
向 IBM Db2 Event Store 添加一个新数据源
打开提供的 JSON 仪表板 ./Db2 Event Store Visualization.json
并将其内容复制到您的粘贴板。
通过粘贴该 JSON 来导入仪表板
运行样本代码
为了将数据读取到 Event Store 中,我们首先将 JSON 有效负载分批发布到一个 Kafka 集群的主题中。流连接器 Event Store 扩展可以创建自己的本地 Kafka 集群,或者可以针对一个外部集群进行配置。
为了运行样本代码,我们将执行两个应用程序:
- 使用
dataLoad/run
运行 JSON 生成器。该生成器模拟一个受传感器驱动的最小有效负载,并将每批有效负载发布到一个 Kakfa 主题上 - 使用
eventStream/run
运行主要的流连接器组件。该连接器利用 Spark 流和 Kakfa 集成库来处理 Kafka 消息,并使用可配置的批次大小将它们读取到 Event Store 中。 - 运行适用于 Kafka 的 IBM Db2 Event Store 流连接器
- localBroker [Boolean]- true 表示使用一个内部的单节点 Kafka 代理。False 表示使用一个外部配置的代理
- kafkaBroker [String]- Kafka 代理的位置,为本地设置传入“localhost:9092”,为外部设置传入 ip:port 位置
- topic [String]- 将用于流的 Kafka 主题
- eventStore [String]- IBM Db2 Event Store 的 IP 配置
- database [String]- 将创建或使用的 Db2 Event Store 数据库
- user [String]- 将使用的 Db2 Event Store 用户名
- password [String]- 将使用的 Db2 Event Store 密码
- metadata [String]- 此 IoT 设备的元数据类型,例如“sensor”、“appliance”或“weatherstation”
- streamingInterval [Long]- Long 值定义了 Apache Spark 传输窗口的长度(以毫秒为单位)
- batchSize [Int] - 将发送到 IBM Db2 Event Store 的批次大小
- 运行 JSON 生成器
- localBroker [Boolean]- true 表示使用一个内部的单节点 Kafka 代理。False 表示使用一个外部配置的代理
- kafkaBroker [String]- Kafka 代理的位置,为本地设置传入“localhost:9092”,为外部设置传入 ip:port 位置
- tableName [String] - 将在 IBM Db2 Event Store 内创建的表名
- topic [String]- 将用于流的 Kafka 主题
- group [String]- 将用于流的 Kafka 组
- metadata [String]- 此模拟 IoT 设备的元数据类型,例如“sensor”、“appliance”或“car”等
- metadataId [Long]- 可标识此 IoT 设备的 Long 值,例如“238”或“002”等
- batchSize [Int]- 将发送给 Kafka 队列的批次大小。它最小可以为 1。
sbt "eventStream/run -localBroker true -kafkaBroker localhost:9092 -topic estopic -eventStore localhost:1100 -database TESTDB -user admin -metadata sensor -password password -metadata ReviewTable -streamingInterval 5000 -batchSize 10" sbt "dataLoad/run -localBroker true -kafkaBroker localhost:9092 -tableName ReviewTable -topic estopic -group group -metadata sensor -metadataId 238 -batchSize 10"
可视化数据
应用程序启动时,grafana 仪表板会开始可视化传入的传感器数据。
传感器数据
后续行动:了解 IBM Fast Data Platform
IBM Db2 Event Store 支持存储库中提供了一个更完整的教程,包括一个可使用 IBM Fast Data Platform 部署的完整的端到端应用程序( 点击了解此高级教程 )。
停止 IBM Db2 Event Store 并删除数据库
要删除 IBM Db2 Event Store 数据库,请关闭 IBM Db2 Event Store Developer Edition 并发出以下命令:
docker stop $(docker ps -aq) docker rm $(docker ps -aq) cd ~/Library/Application\ Support/ibm-es-desktop rm -rf zookeeper alluxio ibm
结束语
在本教程中,我们首先安装了 IBM Db2 Event Store Developer Edition。接下来,我们生成了代表传感器有效负载的 JSON 有效负载,并在 Apache Kafka 集群上分批发布。在 Kafka 中提供这些有效负载后,我们使用了 Apache Spark Streaming 和 Kafka 集成来访问各批有效负载,并将它们摄入到 IBM Db2 Event Store 中。读取到 IBM Db2 Event Store 中后,我们将 Grafana 连接到 IBM Db2 Event Store 的 REST 服务器,以便运行一些简单的谓词并将结果可视化。
参考资料
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 东进量子加密传输网关:为数据传输套上“金钟罩”
- 大规模数据传输,知易行难 — 数据传输与 ETL 平台的架构演进 原 荐
- Koa 中实现 chunked 数据传输
- MySQL数据库字符编码总结--数据传输编码
- Debug Tensorflow PS的数据传输
- 中央企业“三重一大”数据传输安全的重要步骤
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。