InfluxDB使用总结与性能优化[转]

如果项目的功能模块中用到对时间特性比较敏感的数据,例如性能监控,趋势走向等需求时,InfluxDB将会是一个不错的选择,虽然其很强很彪悍,但只有在使用的过程中遵循一定规范与原则,才能发挥其良好的特性。

本文会先介绍一些InfluxDB的基本概念,然后列出一些在设计Schema时应该注意的问题,最后列出一些常见的优化方式。

基本介绍
概念
Database: 数据库名,在 InfluxDB 中可以创建多个数据库,不同数据库中的数据文件是隔离存放的,存放在磁盘上的不同目录。
Retention Policy: 存储策略,用于设置数据保留的时间,每个数据库刚开始会自动创建一个默认的存储策略 autogen,数据保留时间为永久,之后用户可以自己设置,例如保留最近2小时的数据。插入和查询数据时如果不指定存储策略,则使用默认存储策略,且默认存储策略可以修改。InfluxDB 会定期清除过期的数据。
Measurement: 对于传统数据库的表,例如 cpu_usage 表示 cpu 的使用率。
Tag sets: tags 在 InfluxDB 中会被建立索引,且放在内存中。如果某种数据经常用来被作为查询条件,可以考虑设为Tag
Field: 记录值,是查询的主要对象,例如value值等
Point:代表一条记录
Series:tag key 与tag value的唯一组合
Timestamp: 每一条数据都需要指定一个时间戳,在 TSM 存储引擎中会特殊对待,以为了优化后续的查询操作。
操作
由于Tag与Field的不同特性,在编写SQL进行查询时,Tag与Field支持不同的操作,总结如下:

Tag 
只能使用Tag进行Group
只能使用Tag进行正则表达式操作
SHOW TAG VALUES WITH KEY = qual_data;    #qual_data只能是tag,填写field无输出

Field 
只能使用Field进行函数操作,例如sum()
只能使用Field进行比较操作
如果需要使用int,float,boolean类型进行存储,只能使用Field
select qual_data from mangguo_data where domain='value';    #value只能是field,填写tag无输出

Schema 设计总结
不要把数据放到measurement名称中。
例如 不要让measurement名称看起来是这样的:

cpu.server1.us_west
应该改成
cpu,host=server1,region=us_west

不要把数据放到Tag value中 
例如 不要让measurement名称看起来是这样的:
cpu,host=server1.us_west
应该改成
cpu,host=server1,region=us_west
  • 不要使用取值范围很广的数据作为tag,例如uuid,hash等等
  • 如果实在有这方面的需求,考虑一下几点建议
  • 切成多个shard,并分到多个实例上
  • 使用tag 前缀进行区分
  • 使用field
  • 使用集群
  • Tag Key不要与Field的名称相同
  • Tags的数量不要太少
  • database的数量不要太多
  • 当database的数量达到千万级别时,会出现打开文件过多,占用内存过多等问题。
    优化
    常见的优化方式如下
控制series的数量
Series会被索引且存在内存中,如果量太大会对资源造成过多损耗,且查询效率也得不到保障。 
可以通过以下方式查询series的数量:
 influx -database 'cloudportal' -execute 'show series' -format 'csv'|wc -l

通过以下方式查询tag values的数量:
influx -database 'cloudportal' -execute 'SHOW TAG VALUES FROM six_months.collapsar_flow WITH KEY = dip' -format 'csv'|wc -l

数量是否合适可以参考以下标准:

  • 机器配置


    机器配置
  1. 使用批量写
    如果使用HTTP一次写一条记录,或许还没有太大的负担,但是如果用HTTPS的进行一条一条的写,在加密/解密上的资源损耗会非常的大。如果不能使用HTTP,则推荐使用UDP协议
  2. 使用Continuous Queries 进行数据汇聚
    对于查询时间范围较大且数据粒度要求不是非常高的数据,可以考虑使用CQ进行数据汇总,并对汇总结果进行查询
  3. 使用恰当的时间粒度
    在数据存储的时候默认使用纳秒。而对于很多业务操作而言,可能只需要精确到秒级别。这种情况对于存储资源以及查询性能都会有一定的影响。想法如果业务需要毫秒级别的精确程度,而存的时候使用了秒级别的数据,此时查询又会出现数据的丢失
  4. 存储的时候尽量对Tag进行排序
  5. 无关的数据写不同的database
  6. 根据数据情况,调整shard的duration
    默认7天创建一个,如果查询的时间范围较大,会打开多个shard文件,对于数据量不大,且查询范围可能较大的数据,可以将shard duration时间设置的长一点
  7. 存储分离
    将WAL目录与data目录分别映射到不同的磁盘上,以减少读写操作的相互影响
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352