Spring boot使用influxDB总结
程序员文章站
2022-07-09 21:20:11
项目中需要存放 ,且需要对其进行简单的数据分析,信息提取工作. 结合众多考量因素,项目决定使用 中的领头羊 . 引入依赖 项目中使用 ,在 文件中添加如下依赖( 地址: ): 文件配置如下所示(请按照实际情况填写): 配置 (1) 创建配置类 构建实体类 中, 对应于传统关系型数据库中的 (`dat ......
项目中需要存放大量设备日志
,且需要对其进行简单的数据分析,信息提取工作.
结合众多考量因素,项目决定使用时序数据库
中的领头羊influxdb
.
引入依赖
项目中使用influxdb-java
,在pom
文件中添加如下依赖(github
地址:https://github.com/influxdata/influxdb-java
):
<dependency> <groupid>org.influxdb</groupid> <artifactid>influxdb-java</artifactid> <version>2.15</version> </dependency>
application.yaml
文件配置如下所示(请按照实际情况填写):
spring: influx: url: * password: admin user: 123 database: log_management
配置
(1) 创建配置类
@configuration public class influxdbconfig { @value("${spring.influx.url:''}") private string influxdburl; @value("${spring.influx.user:''}") private string username; @value("${spring.influx.password:''}") private string password; @value("${spring.influx.database:''}") private string database; @bean public influxdbutils influxdbutils() { return new influxdbutils(username, password, influxdburl, database, ""); } }
@data public class influxdbutils { private string username; private string password; private string url; public string database; private string retentionpolicy; // influxdb实例 private influxdb influxdb; // 数据保存策略 public static string policynamepix = "logretentionpolicy_"; public influxdbutils(string username, string password, string url, string database, string retentionpolicy) { this.username = username; this.password = password; this.url = url; this.database = database; this.retentionpolicy = retentionpolicy == null || "".equals(retentionpolicy) ? "autogen" : retentionpolicy; this.influxdb = influxdbbuild(); } /** * 连接数据库 ,若不存在则创建 * * @return influxdb实例 */ private influxdb influxdbbuild() { if (influxdb == null) { influxdb = influxdbfactory.connect(url, username, password); } try { createdb(database); influxdb.setdatabase(database); } catch (exception e) { log.error("create influx db failed, error: {}", e.getmessage()); } finally { influxdb.setretentionpolicy(retentionpolicy); } influxdb.setloglevel(influxdb.loglevel.basic); return influxdb; } }
构建实体类
influxdb
中,measurement
对应于传统关系型数据库中的table
(database
为配置文件中的log_management
).influxdb
里存储的数据称为时间序列数据
,时序数据有零个
或多个
数据点.数据点
包括time
(一个时间戳),measurement
(例如loginfo
),零个或多个tag
,其对应于level
,module
,device_id
),至少一个field
(即日志内容,msg=something error
).influxdb
会根据tag
数值建立时间序列
(因此tag
数值不能选取诸如uuid
作为特征值,易导致时间序列过多,导致influxdb
崩溃),并建立相应索引,以便优化
诸如查询速度
.
@builder @data @measurement(name = "loginfo") public class loginfo { // column中的name为measurement中的列名 // 此外,需要注意influxdb中时间戳均是以utc时保存,在保存以及提取过程中需要注意时区转换 @column(name = "time") private string time; // 注解中添加tag = true,表示当前字段内容为tag内容 @column(name = "module", tag = true) private string module; @column(name = "level", tag = true) private string level; @column(name = "device_id", tag = true) private string deviceid; @column(name = "msg") private string msg; }
保存数据
以下代码为单条日志保存,influxdb-java
亦支持批量保存
(因为与influxdb
通讯均是通过http
,因此建议批量保存以减少性能损耗).
loginfo loginfo = loginfo.builder() .level(jsonobject.getstring("level")) .module(module) .deviceid(deviceid) .msg(jsonobject.getstring("msg")) .build(); point point = point.measurementbypojo(loginfo.getclass()) .addfieldsfrompojo(loginfo) .time(jsonobject.getlong("time"), timeunit.milliseconds) .build(); // 出于业务考量,设备可以设置不同的保存策略(策略名为固定前缀+设备id) influxdb.write(influxdbutils.database, influxdbutils.policynamepix + deviceid, point);
查询数据
因为代码与业务耦合比较厉害,因此此处仅截选做概要示范
.
// influxdb支持分页查询,因此可以设置分页查询条件 string pagequery = " limit " + request.getpagesize() + " offset " + ((request.getpagenum() - 1) * request.getpagesize()); // 此处查询所有内容,如果 string querycmd = "select * from " // 查询指定设备下的日志信息 // 要指定从 retentionpolicyname(保存策略前缀+设备id).measurement(loginfo) 中查询指定数据) + influxdbutils.policynamepix + request.getdeviceid() + "." + "loginfo" // 添加查询条件(注意查询条件选择tag值,选择field数值会严重拖慢查询速度) + querycondition // 查询结果需要按照时间排序 + " order by time desc" // 添加分页查询条件 + pagequery;
选择时序数据库,不建议使用删除
以及更新
操作,因此不做介绍.
可以通过创建或者
retentionpolicy
,来添加
或者更新
数据的删除时间.
ps:
如果您觉得我的文章对您有帮助,可以扫码领取下红包或扫码支持(随意多少,一分钱都是爱),谢谢!
支付宝红包 | 支付宝 | 微信 |
---|---|---|
推荐阅读
-
使用Spring boot + jQuery上传文件(kotlin)功能实例详解
-
springboot 使用Spring Boot Actuator监控应用小结
-
Spring Boot中使用LDAP来统一管理用户信息的示例
-
Spring boot 总结之跨域处理cors的方法
-
spring boot 使用Aop通知打印控制器请求报文和返回报文问题
-
[Spring Boot]使用自定义注解统一请求返回值
-
Spring Boot 入门之消息中间件的使用
-
Spring Boot使用AOP防止重复提交的方法示例
-
在Spring Boot中使用swagger-bootstrap-ui的方法
-
干货分享:ASP.NET CORE(C#)与Spring Boot MVC(JAVA)异曲同工的编程方式总结