依赖时序数据库服务TDengine安装初始化(可选)
Apache HertzBeat (incubating) 的历史数据存储依赖时序数据库,任选其一安装初始化即可,也可不安装(注意⚠️但强烈建议生产环境配置)
我们推荐使用并长期支持 VictoriaMetrics 作为存储。
TDengine是一款开源物联网时序型数据库,我们用其存储采集到的监控指标历史数据。 注意支持⚠️ 3.x版本。
注意⚠️ 时序数据库安装配置为可选项,但强烈建议生产环境配置,以提供更完善的历史图表功能,高性能和稳定性 ⚠️ 若不配置时序数据库,则只会留最近一小时历史数据
如果您已有TDengine环境,可直接跳到创建数据库实例那一步。
通过Docker方式安装TDengine
下载安装Docker环境 Docker 工具自身的下载请参考 Docker官网文档。 安装完毕后终端查看Docker版本是否正常输出。
$ docker -v
Docker version 20.10.12, build e91ed57Docker安装TDengine
$ docker run -d -p 6030-6049:6030-6049 -p 6030-6049:6030-6049/udp \
-v /opt/taosdata:/var/lib/taos \
--name tdengine -e TZ=Asia/Shanghai \
tdengine/tdengine:3.0.4.0-v /opt/taosdata:/var/lib/taos
为tdengine数据目录本地持久化挂载,需将/opt/taosdata
替换为实际本地存在的目录
-e TZ="Asia/Shanghai"
为tdengine设置时区,这里可选设置对应的时区
使用$ docker ps
查看数据库是否启动成功
创建数据库实例
进入数据库Docker容器
docker exec -it tdengine /bin/bash
修改账户密码
建议您修改密码。TDengine默认的账户密码是 root/taosdata 进入容器后,执行
taos
命令进入TDengine CLI , 如下:root@tdengine-server:~/TDengine-server# taos
Welcome to the TDengine shell from Linux, Client Version
Copyright (c) 2020 by TAOS Data, Inc. All rights reserved.
taos>在 TDengine CLI 中使用 alter user 命令可以修改用户密码,缺省密码为 taosdata
创建名称为hertzbeat的数据库
执行创建数据库命令
taos> show databases;
taos> CREATE DATABASE hertzbeat KEEP 90 DURATION 10 BUFFER 16;上述语句将创建一个名为 hertzbeat 的库,这个库的数据将保留90天(超过90天将被自动删除),每 10 天一个数据文件,每个 VNode 的写入内存池的大小为 16 MB
查看hertzbeat数据库是否成功创建
taos> show databases;
taos> use hertzbeat;退出TDengine CLI
输入 q 或 quit 或 exit 回车
注意⚠️若是安装包安装的TDengine
除了启动server外,还需执行
systemctl start taosadapter
启动 adapter
在hertzbeat的application.yml
配置文件配置此数据库连接
配置HertzBeat的配置文件 修改位于
hertzbeat/config/application.yml
的配置文件 注意⚠️docker容器方式需要将application.yml文件挂载到主机本地,安装包方式解压修改位于hertzbeat/config/application.yml
即可修改里面的
warehouse.store.jpa.enabled
参数为false
, 配置里面的warehouse.store.td-engine
数据源参数,URL账户密码,并启用enabled
为true
warehouse:
store:
# 关闭默认JPA
jpa:
enabled: false
td-engine:
enabled: true
driver-class-name: com.taosdata.jdbc.rs.RestfulDriver
url: jdbc:TAOS-RS://localhost:6041/hertzbeat
username: root
password: taosdata重启 HertzBeat
常见问题
时序数据库IoTDB和TDengine是否都需要配置,能不能都用
不需要都配置,任选其一即可,用enable参数控制其是否使用,也可都不安装配置,只影响历史图表数据。
监控页面历史图表不显示,弹出 [无法提供历史图表数据,请配置依赖时序数据库]
如弹窗所示,历史图表展示的前提是需要安装配置hertzbeat的依赖服务 - IotDB数据库或TDengine数据库
监控详情历史图片不展示或无数据,已经配置了TDengine
请确认是否安装的TDengine版本为3.0以上,版本2.x不支持兼容
安装配置了TDengine数据库,但页面依旧显示弹出 [无法提供历史图表数据,请配置依赖时序数据库]
请检查配置参数是否正确
td-engine enable是否设置为true
注意⚠️若hertzbeat和TDengine都为docker容器在同一主机下启动,容器之间默认不能用127.0.0.1通讯,改为主机IP
可根据logs目录下启动日志排查