从零到一:influxdb时序性数据库的基本概念与操作指南

news/2025/1/19 15:16:43/

目录

​编辑

引言

数据库(database)

创建数据库

删除数据库

进入数据库

展示influxdb中所有数据库

测量(measurement)

写入测量

展示测量

总结


引言

InfluxDB是一个开源的时序数据库,专门设计用于处理时间序列数据。它是由InfluxData公司开发的,并且被广泛用于监控、分析和存储具有时间戳的数据,例如应用程序指标、系统性能数据、传感器数据等。以下是InfluxDB的一些关键特点和概念:

  1. 时序数据库: InfluxDB专注于存储和查询时间序列数据,这使得它非常适合处理按时间顺序生成的数据流,如传感器数据、日志文件、应用程序指标等。

  2. 数据模型: InfluxDB采用了一种灵活的数据模型,其中数据被组织成测量(Measurements)、标签(Tags)、字段(Fields)和时间戳。这种模型使用户能够高效地存储和查询不同类型的时间序列数据。

    • 测量(Measurements): 表示一类相似的时间序列数据。
    • 标签(Tags): 用于标识和过滤数据,提供了额外的元数据。标签是键值对的形式,附加在测量上。
    • 字段(Fields): 包含实际的数据值,可以是数字、字符串或布尔类型。
    • 时间戳: 表示数据点生成的时间。
  3. 查询语言: InfluxDB使用类似于SQL的查询语言(InfluxQL),允许用户执行各种查询、过滤和聚合操作。用户可以根据时间范围、标签等条件来检索数据。

  4. 连续查询和聚合: InfluxDB支持连续查询,允许用户定期计算和存储聚合数据,以加速后续查询。这对于处理大量数据并提供实时分析非常有用。

  5. 保留策略: 用户可以定义数据的保留策略,以控制存储在数据库中的数据的保留时间。这有助于有效地管理存储空间。

  6. 插件和集成: InfluxDB具有丰富的插件生态系统,可以与各种其他工具和系统集成,如Grafana、Telegraf、Kapacitor等,以提供更全面的解决方案。

  7. 集群支持: InfluxDB具有内置的集群支持,可以横向扩展以处理大规模的数据。

  8. Telegraf: Telegraf是InfluxDB的插件驱动的代理,用于从各种源收集数据,并将其写入InfluxDB。它是一个开源项目,支持多种输入和输出插件。

  9. 开源和社区支持: InfluxDB是开源的,拥有活跃的社区,用户可以在GitHub上找到其源代码和文档。

官网链接:InfluxDB | InfluxData

数据库(database)

创建数据库

create database <database_name>

这里<database_name>应该替换为你的数据库名称

删除数据库

drop database <database_name>

进入数据库

use <database_name>

展示influxdb中所有数据库

show databases;

测量(measurement)

结构: measurement 由以下组成:

  • 名称(Name,可以理解为关系型数据库中的表名称): measurement 的名称标识了存储的数据类型或事件。例如,一个气象站可能有一个 measurement 名称为 "weather",用于存储与天气相关的数据。
  • 标签(Tags,可以理解为关系型数据库中的索引列): 可选的标签是键值对,用于为数据点添加元数据,以便更容易过滤和查询。标签通常用于标识数据的来源或其他维度信息。
  • 字段(Fields,可以理解为关系型数据库中的非索引字段,主要用来存储数据): 字段包含实际的数值或测量数据。每个字段都有一个名称和相应的数值。字段的类型可以是整数、浮点数、字符串等
  • 时间戳(Time,可以理解为关系型数据库中的主键,可以自己生成、也可以由influxdb自动生成):表示数据点生成的时间。

写入测量

influxdb在插入数据的时候不需要像关系型数据库一样先创建表,在插入数据的时候制定measurement的名字会自动创建相应的measurement

INSERT measurement_name,tag_key=tag_value field_key=field_value

例如:

INSERT weather,location=us-west temperature=75,humidity=40

展示测量

show measurements
-- 类似与mysql中的show tables;

查询测量

  1. 基本查询:

    SELECT * FROM <measurement_name>
  2. 范围查询:

    SELECT * FROM measurement_name WHERE time > start_time AND time < end_time

    例如:

    SELECT * FROM weather WHERE time > '2023-01-01T00:00:00Z' AND time < '2023-01-02T00:00:00Z'

    注意如果插入的时候未自定义时间戳,则无法按照国际时间进行时间戳查询,需要进行计算机时间纳秒转换。

  3. 选择查询:

    SELECT field1, field2 FROM measurement_name

    例如:

    SELECT temperature, humidity FROM weather

  4. 条件查询:

    SELECT * FROM measurement_name WHERE tag_key = 'tag_value' AND field_key > 50

    例如:

    SELECT * FROM weather WHERE location = 'us-west' AND temperature > 70

聚合函数:

SELECT COUNT(field_key) FROM measurement_name WHERE time > start_time GROUP BY time(interval), tag_key

例如:

SELECT COUNT(temperature) FROM weather WHERE time > '2023-01-01T00:00:00Z' GROUP BY time(1h), location

总结

InfluxDB是一款专为处理时间序列数据而设计的开源时序数据库。其核心概念包括测量(Measurements)、标签(Tags)、字段(Fields)和时间戳,这些元素共同构建了灵活而高效的数据存储和查询系统。测量代表一类相似的时间序列数据,而标签和字段则提供了元数据和实际数值的存储。时间戳则用于表示数据点生成的时间。通过插入数据时自动创建测量,InfluxDB简化了数据库结构的管理。


http://www.ppmy.cn/news/1272488.html

相关文章

什么是PHP中的魔术方法?

在PHP中&#xff0c;魔术方法&#xff08;Magic Methods&#xff09;是一些特殊的方法&#xff0c;它们具有双下划线&#xff08;__&#xff09;作为前缀&#xff0c;用于在对象的生命周期中执行一些特定的操作。这些方法不需要直接调用&#xff0c;而是由PHP在特定的情况下自动…

Apache OfBiz 反序列化命令执行漏洞(CVE-2023-49070)

项目介绍 Apache OFBiz是一个非常著名的电子商务平台&#xff0c;是一个非常著名的开源项目&#xff0c;提供了创建基于最新J2EE/XML规范和技术标准&#xff0c;构建大中型企业级、跨平台、跨数据库、跨应用服务器的多层、分布式电子商务类WEB应用系统的框架。OFBiz最主要的特…

elasticsearch查询出现Limit of total fields 1000 has been exceeded

项目场景&#xff1a; 在项目中使用elasticsearch保存日志等相关数据&#xff0c;查询页面查询这些日志数据 问题描述 提示&#xff1a;这里描述项目中遇到的问题&#xff1a; 今天在检查日志数据时&#xff0c;发现数据出不来&#xff0c;检查后端日志&#xff0c;发现一直…

简历提示:如何撰写出色的简历

您的简历可能是您一生中写的最重要的一页。遵循我们的 20 条简历写作技巧&#xff0c;让您的简历取得成功。 您知道一份出色的简历的重要性。这是您获得一份好工作所需的文件&#xff0c;而一份好工作可以带来美好的生活。因此&#xff0c;我们整理了 20 个简历技巧来帮助您撰…

从memcpy()函数中学习函数的设计思想

memcpy()函数&#xff1a;可以理解为内存拷贝。 他的函数定义如下的 my_memcpy()函数相同。 下面这个函数是我的模拟实现&#xff0c;现在让我们一起来学习一下这个函数的设计思想&#xff1a; void * my_memcpy(void * des, const void* src, size_t size) {void * p des;…

linux 块设备驱动程序介绍

Linux块设备驱动是Linux操作系统中用于处理块设备的设备驱动程序。块设备是指以固定大小的块单位进行访问的存储设备&#xff0c;例如硬盘、固态硬盘和USB存储设备等。 Linux块设备驱动负责管理块设备的读写操作&#xff0c;并将数据传输到相应的存储设备上。它还负责处理块设…

【知识分享】Java实现排序的方法及代码实现

Java实现排序的基础方法有很多&#xff0c;下面介绍几种比较常见的排序算法及其代码实现。 1.冒泡排序 冒泡排序是一种基础的排序算法&#xff0c;其思想是依次比较相邻的两个元素&#xff0c;如果顺序不对则交换它们的位置&#xff0c;直到整个数组都排好序为止。 代码实现…

什么是sql的谓词下推

SQL的谓词下推&#xff08;Predicate Pushdown&#xff09;是一种数据库查询优化技术&#xff0c;它将查询中的过滤条件&#xff08;谓词&#xff09;尽可能地“下推”到查询计划中更早的阶段执行。这意味着&#xff0c;系统尝试在处理和转换数据之前先应用这些过滤条件&#x…