时序数据库-InfluxDB 避坑指南

本文详细介绍了InfluxDB使用过程中可能遇到的问题,包括max-series-per-database限制、max-values-per-tag的设定、内存不足导致的OOM-Killer、retention policy的管理和数据丢失、时区查询问题以及磁盘空间不足的解决办法。通过这篇避坑指南,可以帮助读者更好地理解和优化InfluxDB的运行环境。
摘要由CSDN通过智能技术生成

目录

1. influxdb max-series-per-database = 1000000

2. max-values-per-tag = 100000  

3. influxdb 物理机内存不足,influxdb 内存占用过高,被操作系统OOM-Killer  

 4. influxdb retention policy

5. influxdb 写入保留策略以为时间的数据,直接丢掉  

6. influxdb 时区查询

7. influxDB 物理机磁盘满了  


1. influxdb max-series-per-database = 1000000

设置数据库的时间序列线最大值,该值为 0 时表示无限制,默认值为 1000000
max-series-per-database = 0

如果不配置这个值,series 超过 1000000 就会报一下异常,导致数据丢失。

influxdb中,series是一个很重要的概念,它是retentionPolicy、measurement、tag set相同的集合,包含了监控对象的元数据信息,series的数量=RP*measurement*tag set。

一般来讲,监控对象稳定后,series基本是固定的;influxdb将series放在内存作为索引,加快了数据查询,这使得series的数量不能太大,否则influxdb内存会被撑爆,默认单个database内series限制为<100W个。

2021-12-02 20:29:38.712 [defaultEventExecutorGroup-2-7] ERROR com.test.daq.parse.HL7DataMsg - HL7DataMsg.parse err, e = {}
org.influxdb.InfluxDBException: partial write: max-series-per-database limit exceeded: (1000000) dropped=4783
        at org.influxdb.InfluxDBException.buildExceptionFromErrorMessage(InfluxDBException.java:161)
        at 

2. max-values-per-tag = 100000  

The maximum number of tag values allowed per

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值