JAVA操作Influxdb

news2024/11/18 21:47:51

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 存储了您打算测量、分析和可视化的实际定量或定性数据值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1621012.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【电控笔记5.6】Butterworth滤波器

Butterworth滤波器 需求&#xff1a;在增益交越频率拥有最小的相位滞后 波器经常被使用原因是 Butterworth 滤波器对于给定阶数&#xff0c;拥有最倾斜的衰减率而在伯德图又不会产生凸峰&#xff0c;同时在低频段的相位滞后小&#xff0c;因此本节将为各位介绍 Butterworth 低…

按照以下步骤使用Transformer模型

“Transformer”是一种深度学习模型架构&#xff0c;用于处理序列数据&#xff0c;特别是在自然语言处理&#xff08;NLP&#xff09;领域中表现出色。它由Google Brain团队于2017年提出&#xff0c;并在机器翻译任务中取得了突破性的成果。Transformer的核心思想是完全基于自注…

SpringBoot整合七牛云实现图片的上传管理

唠嗑部分 各位小伙伴大家好&#xff0c;我是全栈小白&#xff0c;今天我们来分享一下SpringBoot如何整合七牛云存储实现图片的上传与存储 首先我们来说说图片存储&#xff0c;在项目中图片几乎是必不可少的&#xff0c;那么大家会选择怎样存储呢&#xff0c;当然有几种方案 …

form-serialize插件,快速收集表单元素的值

form-serialize插件可以快速获得表单元素的值&#xff0c;主要用于当表单很多的情况下&#xff0c;将表单的值一起打包发给服务器。 使用方法&#xff1a; 1.引入插件 2.获取表单的dom 3.使用插件的serialize方法 serialize方法有两个参数&#xff0c;第一个是获取到的表单d…

Docker容器搭建Hadoop集群(hadoop-3.1.3)

Docker容器环境下搭建Hadoop集群&#xff08;完全分布式&#xff09; hadoop版本为hadoop-3.1.3 &#xff08;1&#xff09;安装额外的速度较快的镜像库 yum install -y epel-release &#xff08;2&#xff09;安装同步工具&#xff0c;方便在多台服务器上进行文件的传输 …

java开发之路——用户管理中心_简单初始化

用户管理中心_简单初始化 (一) 初始化项目1. 使用 Ant Design Pro(现成的管理系统) 进行前端初始化2. 后端初始化三种初始化java项目 (二) 遇到的问题【问题1】Ant design pro页面打不开&#xff0c;一直在budiling控制台出现错误error-./src/components/index.ts【问题2】初始…

【期末复习向】智能信息系统前4章梳理

第四章 不确定性推理 [了解即可]4.1 不确定性概述 不确定性推理概念 所谓推理&#xff0c;就是从已知事实出发&#xff0c;运用相关的知识&#xff08;或规则&#xff09;逐步推出结论或者证明某个假设成立或不成立的思维过程。 不确定性方法分类 1.模型方法 a&#xff0…

新技术前沿-2024-大型语言模型LLM的本地化部署

参考快速入门LLM 参考究竟什么是神经网络 1 深度学习 1.1 神经网络和深度学习 神经网络是一种模拟人脑神经元工作方式的机器学习算法,也是深度学习算法的基本构成块。神经网络由多个相互连接的节点(也称为神经元或人工神经元)组成,这些节点被组织成层次结构。通过训练,…

【Linux】谈谈shell外壳是什么?

&#x1f490; &#x1f338; &#x1f337; &#x1f340; &#x1f339; &#x1f33b; &#x1f33a; &#x1f341; &#x1f343; &#x1f342; &#x1f33f; &#x1f344;&#x1f35d; &#x1f35b; &#x1f364; &#x1f4c3;个人主页 &#xff1a;阿然成长日记 …

在pycharm中导入sklearn库失败到成功

运行下列代码&#xff1a; pip install -i https://pypi.tuna.tsinghua.edu.cn/simple scikit-learn 可以发现下载库时&#xff0c;不是直接下载sklearn库&#xff0c;而是下载scikit-learn库 之前下载一直失败&#xff0c;终于找到原因了。果然还是得多尝试&#xff0c;还…

【已解决简单好用】notepad++怎么设置中文

打开Notepad软件。点击软件界面顶部菜单栏中的“Settings”选项。在下拉菜单中选择“Preferences”进行语言设置。在打开的设置窗口中&#xff0c;找到“General”选项。在“General”选项中&#xff0c;找到“Localization”&#xff08;界面语言&#xff09;项。在下拉菜单中…

Spring-IOC之组件扫描

版本 Spring Framework 6.0.9​ 1. 前言 通过自动扫描&#xff0c;Spring 会自动从扫描指定的包及其子包下的所有类&#xff0c;并根据类上的特定注解将该类装配到容器中&#xff0c;而无需在 XML 配置文件或 Java 配置类中逐一声明每一个 Bean。 支持的注解 Spring 支持一系…

IDEA最好用插件推荐

1 背景 俗话说&#xff1a;“工欲善其事必先利其器”&#xff0c;本问介绍几款强大实用的 IDEA 插件&#xff0c;助力大家开发。 希望大家做一个聪明又努力的人&#xff0c;而不只是一个努力的人。 以下插件大都可以通过 IDEA 自带的插件管理中心安装&#xff0c;如果搜不到可以…

如何给word中的拼音加声调?分享3个方法

一&#xff0c;前言 在Word文档中标注拼音声调&#xff0c;是许多人在处理中文文档时经常需要面对的问题。对于不熟悉拼音的人来说&#xff0c;这可能会是一个挑战。但是&#xff0c;通过掌握一些简单的步骤和技巧&#xff0c;我们可以轻松地在Word文档中标注拼音声调。 二&a…

车载以太网DoIP 协议,万字长文详解

&#x1f345; 我是蚂蚁小兵&#xff0c;专注于车载诊断领域&#xff0c;尤其擅长于对CANoe工具的使用&#x1f345; 寻找组织 &#xff0c;答疑解惑&#xff0c;摸鱼聊天&#xff0c;博客源码&#xff0c;点击加入&#x1f449;【相亲相爱一家人】&#x1f345; 玩转CANoe&…

YOLOv8 实现车牌检测,生成可视化检测视频(20240424)

原项目源码地址&#xff1a;GitHub 我的源码地址&#xff1a;Gitee 环境搭建请参考&#xff1a;Win10 搭建 YOLOv8 运行环境&#xff08;20240423&#xff09;-CSDN博客 环境测试请参考&#xff1a;本地运行测试 YOLOv8&#xff08;20240423&#xff09;-CSDN博客 训练数据…

三、CPU基础-缓存

计算机中缓存一般分为两个部分 1.内存 2.CPU Cache 一、CPU Cache分级 CPU Cache 通常分为大小不等的三级缓存&#xff0c;分别是 L1 Cache、L2 Cache 和 L3 Cache。 L1 Cache 和 L2 Cache 都是每个 CPU 核心独有的&#xff08;通常会分为「数据缓存」和「指令缓存」&#…

百度安全多篇议题入选Blackhat Asia以硬技术发现“芯”问题

Blackhat Asia 2024于4月中旬在新加坡隆重举行。此次大会聚集了业界最杰出的信息安全专业人士和研究者&#xff0c;为参会人员提供了安全领域最新的研究成果和发展趋势。在本次大会上&#xff0c;百度安全共有三篇技术议题被大会收录&#xff0c;主要围绕自动驾驶控制器安全、跨…

告别互信息:跨模态人员重新识别的变分蒸馏

Farewell to Mutual Information: Variational Distillation for Cross-Modal Person Re-Identification 摘要&#xff1a; 信息瓶颈 (IB) 通过在最小化冗余的同时保留与预测标签相关的所有信息&#xff0c;为表示学习提供了信息论原理。尽管 IB 原理已应用于广泛的应用&…

使用CSS+HTML完成导航栏

HTML <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <title>导航栏示例</title> &l…