需求说明
编写背景
此手册的基础在于对《jmxtrans + influxdb + granafa 监控套件使用手册》的熟悉和使用。本手册仅介绍以下几项:
- OpenTSDB 的配置安装
- 对 json 文件的配置使其可以将数据导入OpenTSDB
- grafana 对OpenTSDB 数据源的看板配置
适用人群
- 管理层人员
- 数据部门人员
- 运维部门人员
- 其他想要学习此类知识的人员
配置安装 OpenTSDB
简介
OpenTSDB ,可以认为是一个时系列数据(库),它基于HBase存储数据,充分发挥了HBase的分布式列存储特性,支持数百万每秒的读写,它的特点就是容易扩展,灵活的tag机制。
下载安装包
下载安装包并上传到服务器中
编译安装
-
解压
tar -zxvf opentsdb-2.3.0.tar.gz -C /opt/others
-
第一步编译
cd /opt/others mv opentsdb-2.3.0 opentsdb cd opentsdb sudo ./build.sh
编译中会出现以下错误:
...... javac: file not found: ./src/net/opentsdb/query/expression/parser/*.java Usage: javac <options> <source files> use -help for a list of possible options Makefile:1695: recipe for target '.javac-stamp' failed make[1]: *** [.javac-stamp] Error 2 make[1]: Leaving directory '/home/bischoff_s/opentsdb-2.3.0/build' Makefile:1282: recipe for target 'all' failed make: *** [all] Error 2
解决方法:
cd opentsdb mkdir build #这个文件夹有可能会已经存在 cp -r third_party ./build sudo ./build.sh
-
第二步编译
cd build sudo make install #普通用户必须sudo权限运行,否则会报权限错误
-
运行建表脚本,建立 hbase 表
sudo env HBASE_HOME=/opt/bigdata/hbase /opt/others/opentsdb/src/create_table.sh
-
修改配置文件
vim /opt/others/opentsdb/src/opentsdb.conf tsd.network.port = 4242 tsd.http.staticroot = build/staticroot #相对目录,取决于opentsdb.conf所在目录, tsd.http.cachedir = //opt/tmp/opentsdb #缓存目录 tsd.core.auto_create_metrics = true tsd.storage.hbase.zk_quorum = dev01:2181,dev02:2181,dev03:2181 #zookeeper地址
-
启动 会一直有输出,可以将其后台运行并无输出
tsdb tsd --config=src/opentsdb.conf
测试运行
查看版本号
dev@dev01:/var/lib/jmxtrans$ tsdb version
net.opentsdb.tools 2.3.0 built at revision (MODIFIED)
Built on 2018/11/05 07:55:18 +0000 by dev@dev01:/opt/others/opentsdb
按照官网的 metrics 进行测试
-
创建一个sys.cpu.user
tsdb mkmetric sys.cpu.user
-
使用4242端口进行数据输入
# telnet localhost 4242 Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. put sys.cpu.user 1356998400 42.5 host=webserver01 cpu=0 put sys.cpu.user 1356999400 42.7 host=webserver01 cpu=0
-
读取数据
3.1 命令行获取
# tsdb query 1356998400 1356999400 sum sys.cpu.user sys.cpu.user 1356998400000 42.500000 {host=webserver01, cpu=0} sys.cpu.user 1356999400000 42.700001 {host=webserver01, cpu=0}
3.2 web api获取
http://dev01:4242/api/query?start=1356998400&m=sum:sys.cpu.user
[{"metric":"sys.cpu.user","tags":{"cpu":"0"},"aggregateTags":["host"],"dps":{"1356998400":42.5,"1356999400":42.70000076293945,"1541406000":40,"1541406060":50}}]
jmxtrans配置OpenTSDB
示例json
{
"servers" : [ {
"port" : "10101",
"host" : "192.168.20.10",
"queries" : [ {
"outputWriters" : [ {
"@class" : "com.googlecode.jmxtrans.model.output.OpenTSDBWriterFactory",
"port" : 4242,
"host" : "192.168.20.10",
"mergeTypeNamesTags" : true,
"addHostnameTag" : true,
"flushStrategy" : "always",
"typeNames": []
} ],
"obj" : "java.lang:type=OperatingSystem",
"resultAlias": "OperatingSystem",
"attr" : [
"FreePhysicalMemorySize",
"TotalPhysicalMemorySize",
"SystemCpuLoad",
"TotalSwapSpaceSize",
"FreeSwapSpaceSize",
"ProcessCpuLoad"
]
}],
"numQueryThreads" : 6
} ]
}
数据项说明:2.2版本以后的OpenTSDB中一定要配置tag
名称 | 描述 | 类型 |
---|---|---|
servers | 数据源配置 | 数组 |
port | 接收jmx的json数据的端口 | 字符串 |
host | 接收jmx的json数据的IP地址 | 字符串 |
queries | 解析json的规则 | 数组 |
outputWriters | 数据目的地( OpenTSDB) | 数组 |
@class | 数据目的地( OpenTSDB)的类 | 字符串 |
port | OpenTSDB 的 opentsdb.conf 文件中的端口号 | 数值 |
host | 安装 OpenTSDB 的机器IP | 字符串 |
mergeTypeNamesTags | 将即将要存储的字段名存储为tag(?猜测?) | boolean值 |
addHostnameTag | 如果没有指定标签,put到hbase的api将无法正常工作 | boolean值 |
flushStrategy | 默认是“never”,所以metrics实际上不会发送到opentsdb | 字符串 |
numQueryThreads | 总共对6个指标项进行监控 | 数值 |