JAVA操作Influxdb

2024-04-24 22:12
文章标签 java 操作 influxdb

本文主要是介绍JAVA操作Influxdb,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、安装influxdb

本文采用Influxdb2,版本为influxdb:2.7.6。安装方式为docker。

执行安装命令

 docker pull influxdb:2.7.6

创建服务

docker run --name=influxdb2 -p 8086:8086 -v $PWD:/var/lib/influxdb -d influxdb:2.7.6

其中 $PWD 指定为当前目录。可以根据需求进行更换

2、访问 http://ip:8086/进入influxdb系统进行配置,需要配置org和bucket。

3、创建访问API。访问API创建成功后,一定要保存下来,否则,下次将无法查看。

4、开始编码,导入JAR包。需要导入 influxdb-client-java包

	<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency>		<dependency><groupId>org.influxdb</groupId><artifactId>influxdb-java</artifactId></dependency><dependency><groupId>com.influxdb</groupId><artifactId>influxdb-client-java</artifactId><version>3.2.0</version></dependency></dependencies>

5、创建连接并进行写入数据

InfluxDBClientOptions options = InfluxDBClientOptions.builder().url("http://192.168.10.123:8086").authenticateToken("KHRmELvLVlof-iJu-t6EdZmotertANGJlq6BpLFV5Ezi9dvKBeYWe2eU8JzFt3PwhYb2YvIcXBLiACIITZ5hZw==".toCharArray()).org("szyk").bucket("szyk").build();InfluxDBClient client = InfluxDBClientFactory.create(options);OrganizationsApi organizationsApi = client.getOrganizationsApi();System.out.println(organizationsApi.findOrganizations());Instant now = Instant.now(); // 当前时间Point dataPoint = Point.measurement("temperature").addTag("location", "New York").addField("value", "123").time(now.toEpochMilli(), WritePrecision.MS); // 使用毫秒精度List<Bucket> list =  client.getBucketsApi().findBuckets();for (Bucket bucket : list) {System.out.println(bucket.getName());}client.getWriteApiBlocking().writePoint(dataPoint);System.out.println();}

6、注意事项

influxdb中measurement类似于关系形数据库中的表,tag为列,有索引,可以进行快速查询,field列没有索引不能进行快速查询,但field可以进行运算。

。以下是这三个概念的区别:
1. Measurement(测量)
定义: measurement是InfluxDB中存储时间序列数据的顶级容器。它代表了您想要收集和分析的某一类特定数据。每个measurement对应于关系型数据库中的一个表或消息队列中的一个主题。
作用: measurement将具有相同特性和目的的数据点集合在一起。它们定义了所存储数据的上下文,并作为查询InfluxDB中数据的主要入口点。
特点:
命名:measurement通过一个唯一的字符串名称来标识,通常反映其所代表的数据(如 cpu_usage、temperature、server_metrics)。
关系:多个measurement可以存在于同一个数据库(或InfluxDB 2.x中的“bucket”),但每个数据点只属于一个measurement。
无预定义结构:与关系型数据库中的表不同,measurement没有固定的模式。一个measurement关联的tag和field集可以在不同的数据点之间变化。
2. Tag(标签)
定义: tags是以键值对形式存在的,用于对measurement内数据点进行分类并提供上下文信息。它们用于查询时的数据过滤、分组和索引。
作用: tags使您能够基于元数据或分类信息高效地筛选和聚合数据。设计上,tag值被索引,使得基于tag条件的大规模数据查询变得快速。
特点:
键值对:每个tag由一个字符串键和一个字符串值组成(如 host="server-01" 或 region="us-west-2")。
不可变:一旦写入,tag值无法更新。要更改tag值,必须写入一个带有更新后tag的新数据点。
查询性能:tag值被索引,有利于快速查找和高效过滤查询结果。然而,过度使用tags可能会影响写入性能并因索引开销增加存储需求。
不参与数值计算:tag值不适合用于数学运算或聚合函数。它们主要用于过滤和分组结果。
3. Field(字段)
定义: fields存储了时间序列数据的实际数值或字符串值。它们代表了measurement内数据点可测量的量或属性。
作用: fields包含了您希望随时间记录和分析的定量或定性数据。它们是InfluxDB中聚合、统计计算和可视化的主要目标。
特点:
类型:fields可以具有数值类型(整数、浮点数、布尔型)或字符串类型。数值类型的fields适合进行数学运算。
非索引:与tags不同,field值未被索引。涉及field值的查询可能需要进行全扫描,这可能比基于tag的查询慢,特别是在大规模数据集上。
参与计算:field值用于数学表达式、聚合函数(如 mean、max、sum)和统计分析中。
可变:对于同一组合的measurement、tags和时间戳,field值可以随时间改变。InfluxDB将这些变化记录为单独的数据点。
总结:
Measurement 定义了所收集数据的上下文和类别,类似于关系型数据库中的一个表。
Tag 提供了用于高效过滤和分组数据的元数据和分类信息,充当索引键。
Field 存储了您打算测量、分析和可视化的实际定量或定性数据值。

这篇关于JAVA操作Influxdb的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1