InfluxDB关键概念和常用术语介绍
wptr33 2025-05-21 16:54 15 浏览
在深入学习InfluxDB数据库之前,有必要先了解一些数据库的关键概念.
write formart(数据写入格式)
向InfluxDB数据库中指定的measurement(表)中插入数据时遵循以下语法格式
<measurement>[,<tag-key>=<tag-value>...] <field-key>=<field-value>[,<field2-key>=<field2-value>...] [unix-nano-timestamp]
其中,向measurement(表)中插入数据时并不需要预先创建measurement,InfluxDB会自动创建。
database
InfluxDB的database和关系型数据库的database概念类似,作为users,continuous queries,retention policies以及measurements的逻辑上的容器,InfluxDB被设计成无模式的数据库,这就意味着很方便在任何时间添加新的的measurement,tags,field.
InfluxDB安装好后,只有一个默认的"_internal"数据库,用来记录InfluxDB运行的各种metadata.
> show databases;
name: databases
name
----
_internal
redis
retention policy
retention policy用来描述InfluxDB保存多久的数据(DURATION),以及在集群环境中(REPLICATION)储存的数据副本数量,在新建数据库时可以指定retention policy,如果不指定的话,InfluxDB会为新建的数据库默认分配一个"autogen"retention policy,该retention policy会永久保存数据.
这里需要注意的是,集群环境(REPLICATION)是InfluxDB企业版的功能.
measurement
InfluxDB中measurement的意思和关系型数据库中table的意思一致,是tag和field的逻辑容器,在InfluxDB中可以通过如下命令查看measurement.
> use redis
> show measurements;
name: measurements
name
----
cpu
disk
diskio
kernel
mem
net
processes
redis
redis_cmdstat
redis_keyspace
redis_replication
swap
system
tag key, tag value, tag set
tag由tag key和tag value组成,InfluxDB中通过tag查询数据,使用索引意味着使用tag查询数据时更快更高效.可以将tag理解为关系型数据库中建了索引的column,可以在where条件中查询的column.
tag set是由tag key和tag value组成集合的统称,例如在如下的tag device和fstype可以组合成4个不同的键值对
device fstype
nvme0n1p1 xfs
nvme1n1p1 ext4
device=nvme0n1p1, fstype=xfs
device=nvme0n1p1, fstype=ext4
device=nvme1n1p1, fstype=xfs
device=nvme1n1p1, fstype=ext4
以上四个根据不同的tag key和value组合的不同的键值对统称为tag set.
那么如何查看一个measurement的tag呢,通过如下命令.
> show tag keys from disk;
name: disk
tagKey
------
device
fstype
host
mode
path
field key, field value, field set
field由field key和field value组成,field value可以是字符串,浮点数,整点数,以及布尔值,InfluxDB中每个field value都会被分配一个时间戳,InfluxDB中不能通过field查询数据,强制使用field作为查询条件意味着会使用全表扫描,在高数据量的情况下会造成InfluxDB性能问题,可以将field理解为关系型数据库中未创建索引的column,并且不可以在where条件中使用field条件查询.
查看一个measurement中的field字段
> show field keys from disk;
name: disk
fieldKey fieldType
-------- ---------
free integer
inodes_free integer
inodes_total integer
inodes_used integer
total integer
used integer
used_percent float
timestamp
InfluxDB是一个时序数据库( time series database),所以time是我们使用InfluxDB的前提,在InfluxDB中的每个measurement都会有一个time列,time列专用来存储时间戳,时间戳用来记录日期和时间,以RFC3339为标准的UTC时间.
> select "free" from "disk" limit 10;
name: disk
time free
---- ----
2020-07-17T14:29:20Z 832636977152
2020-07-17T14:29:20Z 6035464192
2020-07-17T14:29:20Z 48997576704
2020-07-17T14:29:30Z 832636977152
2020-07-17T14:29:30Z 6035525632
2020-07-17T14:29:30Z 48997576704
2020-07-17T14:29:40Z 832636977152
2020-07-17T14:29:40Z 6035525632
2020-07-17T14:29:40Z 48997576704
2020-07-17T14:29:50Z 832636977152
point
一个point由四部分组成,measurement, tag set, field set,timestamp,一个point由它的series和timestamp构成唯一标识,point可以理解为关系型数据库中的row,
name: disk
time device free fstype host inodes_free inodes_total inodes_used mode path total used used_percent
---- ------ ---- ------ ---- ----------- ------------ ----------- ---- ---- ----- ---- ------------
2020-07-17T14:29:20Z nvme0n1p1 6035464192 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4690157568 43.72853782231456
2020-07-17T14:29:30Z nvme0n1p1 6035525632 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4690096128 43.72796498839057
2020-07-17T14:29:40Z nvme0n1p1 6035525632 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4690096128 43.72796498839057
2020-07-17T14:29:50Z nvme0n1p1 6035505152 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4690116608 43.7281559330319
2020-07-17T14:30:00Z nvme0n1p1 6035505152 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4690116608 43.7281559330319
2020-07-17T14:30:10Z nvme0n1p1 6034497536 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4691124224 43.737550409385314
2020-07-17T14:30:20Z nvme0n1p1 6034518016 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4691103744 43.73735946474398
2020-07-17T14:30:30Z nvme0n1p1 6034518016 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4691103744 43.73735946474398
2020-07-17T14:30:40Z nvme0n1p1 6034538496 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4691083264 43.73716852010266
2020-07-17T14:30:50Z nvme0n1p1 6034538496 xfs ec1d-userredis-01 10404452 10484480 80028 rw / 10725621760 4691083264 43.73716852010266
series
series就是共享measurement, tag set,以及field key的point的集合.
通过以下命令查看一个measurement的series.
> show series from disk;
key
---
disk,device=hq-nfs-01.eng.telenav.com:/nfs_home/home/,fstype=nfs,host=ec1d-userredis-01,mode=rw,path=/nfs/home
disk,device=hq-nfs-01.eng.telenav.com:/nfs_home/home/,fstype=nfs,host=ec1s-tempredis-01,mode=rw,path=/nfs/home
disk,device=hq-nfs-01.eng.telenav.com:/nfs_home/home/,fstype=nfs,host=ec1s-tempredis-02,mode=rw,path=/nfs/home
disk,device=hq-nfs-01.eng.telenav.com:/nfs_home/home/,fstype=nfs,host=ec1s-userfavorite-01,mode=rw,path=/nfs/home
disk,device=hq-nfs-01.eng.telenav.com:/nfs_home/home/,fstype=nfs,host=ec1s-userredis-01,mode=rw,path=/nfs/home
disk,device=nvme0n1p1,fstype=xfs,host=ec1d-userredis-01,mode=rw,path=/
disk,device=nvme0n1p1,fstype=xfs,host=ec1s-tempredis-01,mode=rw,path=/
disk,device=nvme0n1p1,fstype=xfs,host=ec1s-tempredis-02,mode=rw,path=/
disk,device=nvme0n1p1,fstype=xfs,host=ec1s-userfavorite-01,mode=rw,path=/
disk,device=nvme0n1p1,fstype=xfs,host=ec1s-userredis-01,mode=rw,path=/
disk,device=nvme1n1p1,fstype=ext4,host=ec1d-userredis-01,mode=rw,path=/data/01
disk,device=nvme1n1p1,fstype=ext4,host=ec1s-tempredis-01,mode=rw,path=/data/01
disk,device=nvme1n1p1,fstype=ext4,host=ec1s-tempredis-02,mode=rw,path=/data/01
disk,device=nvme1n1p1,fstype=ext4,host=ec1s-userfavorite-01,mode=rw,path=/data/01
disk,device=nvme1n1p1,fstype=ext4,host=ec1s-userredis-01,mode=rw,path=/data/01
以上就是对InfluxDB相关概念的简单介绍.
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
如何将AI助手接入微信(打开ai手机助手)
-
Java面试必考问题:什么是乐观锁与悲观锁
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)