hmf-tsdb 快速入门

2023-12-14 22:30
文章标签 入门 快速 tsdb hmf

本文主要是介绍hmf-tsdb 快速入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境要求

  1. jdk8 或以上版本
  2. mongodb3.4 或以上版本
  3. kafka2.2.0 或以上版本

上述软件 如果没有的话,请先安装。其中kafka 和 mongodb 均可以安装在别的机器上,也可以安装在本机。

下载

下载 hmf-tsdb 到本地,然后解压缩。

修改配置文件

打开hmf-tsdb的解压目录,用文本编辑器打开文件application.properties。找到下面两行:

mongo.connStr = mongodb://127.0.0.1:27017

mongo.dbName = tsdb2

然后根据自己安装的mongodb来修改mongo.connStr。mongo.dbName可以不改,程序运行后会自动根据mongo.dbName的值在mongodb中创建相应的数据库。

找到下面这几行:

#kafka consumer

kafka.consumer.bootstrap-servers = 127.0.0.1:9092

kafka.consumer.topic = tsdb-dps

kafka.consumer.group-id = tsdb-store

kafka.consumer.thread.size = 2

根据您安装的kafka服务器,对此处配置进行修改。假如你完全按照默认参数在本地部署的kafka,则无需修改。

运行

  1. 启动Mongodb,略
  2. 启动Kafka自带的zookeeper,略
  3. 启动Kafka,略
  4. 启动hmf-tsdb: 在hmf-tsdb目录,执行 start.cmd(windows)或者start.sh(linux),便可启动hmf-tsdb。然后打开浏览器,访问 http://localhost:8080/query.html , 如果浏览器能顺利打开下面的界面,说明我们运行成功。 查询界面

产生模拟数据

虽然我们已经运行了hmf-tsdb,但我们看不到任何有趣的效果。接下来,我们需要一个模拟器,向kafka推送数据。hmf-tsdb会主动从kafka服务器pull数据,并保存到mongodb中。hmf-tsdb通过内存缓存、磁盘快照存储、磁盘归档存储等各种策略,提供了单机50万 时序数据的写入能力,并可以实时查询各个测点的趋势图。

下载 dps-producer-demo(该模拟器默认每秒钟生成1万时序数据),修改配置文件:

  1. 指定kafka地址: bootstrap.servers = 127.0.0.1:9092

  2. 指定模拟的区域数量、每个区域设备数量、每个设备测点(在有些行业成为指标)量。

area.amount = 10

device.amount = 50

metric.amount = 20

默认情况下 区域数量 设备数量 测点数据=10000。当你不甚了解hmf-tsdb的时候,暂且不要修改这些参数。当测点总量增加的时候,对运行环境会有各种要求:内存、cpu、mongodb的配置等

然后 运行dps-producer-demo目录中的start.cmd或者start.sh。

查询时序数据

现在我们还不了解hmf-tsdb的表达式语法,你暂且直接在query.html的界面中输入:

current{area='area_1',device='device_1'} last[1h]

然后点击“查询”按钮。浏览器就能显示出 最近 1小时内,位置在 ‘area_1’,且设备编号为'device_1'的电流采样值的历史曲线。如下图所示: 查询

如何向hmf-tsdb写入你自己的时序数据

假如你熟悉kafka的这,向hmf-tsdb写入实时数据是一件非常简单的事情:

创建一个kafka producer,然后用producer向kafka服务器 推送时序数据即可。时序数据 以 json格式的字符串来表示,通常是这个样子的:

{"metric":"current","tags":{"area":"area_1","device":"device_1"},"time":1555137083702,"value":50.47901}

其中metric属性是测点名称,tags是其他一些查询和分析需要用到的标签,time是采样时间,value是采样值。tags的内容可以根据应用的需要定制各种不同的tag,而metric,time,value这三个属性是必须的,不可以改动属性名称。

接下来,启动你的hmf-tsdb,就能够从kafka接收并存储时序数据了。

备注:hmf-tsdb提供了直接写入时序数据的api,你的应用 可以不经kafka直接写入hmf-tsdb。但是,我强烈地不建议你这么做。

  1. 因为这种强耦合的架构和部署,会给后来的架构调整或者运维带来诸多不便。假如:你运行hmf-tsdb的服务器磁盘不够 ,需要停机增加磁盘,那么直接写入的这种架构就会在hmf-tsdb停机期间丢失一部分数据。但假如你是经过Kafka写入hmf-tsdb的话,暂停hmf-tsdb不会导致你时序数据的丢失。

  2. 经由kafka写入hmf-tsdb的架构下,kafka还能起到一个削峰填谷的作用,使系统运行更加平滑流畅,不会因为瞬时的使用高峰(比如突然很多人来查询历史数据),导致系统卡顿甚至数据丢失。

这篇关于hmf-tsdb 快速入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/494119

相关文章

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

Redis 配置文件使用建议redis.conf 从入门到实战

《Redis配置文件使用建议redis.conf从入门到实战》Redis配置方式包括配置文件、命令行参数、运行时CONFIG命令,支持动态修改参数及持久化,常用项涉及端口、绑定、内存策略等,版本8... 目录一、Redis.conf 是什么?二、命令行方式传参(适用于测试)三、运行时动态修改配置(不重启服务

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2