【VictoriaMetrics】vm单机版和vm-storage的查询功能的对比
1.vm-storage源码调用表
| 文件 | 行号 | 函数 | 说明 |
|---|---|---|---|
| app/vmstorage/main.go | 53 | main | 入口 94行调用srv.RunVMSelect() |
| app/vmstorage/transport/server.go | 151 | func (s *Server) RunVMSelect() |
启动vm-select的服务器端 208行调用s.processVMSelectConn(bc) |
| app/vmstorage/transport/server.go | 269 | func (s *Server) processVMSelectConn |
275行调用s.processVMSelectRequest(ctx) |
| app/vmstorage/transport/server.go | 467 | func (s *Server) processVMSelectRequest |
处理存储相关的各个命令 498行调用s.processVMSelectSearch(ctx) |
| app/vmstorage/transport/server.go | 1037 | func (s *Server) processVMSelectSearch |
从存储引擎读取数据 |
2.vm单机版的源码
| 文件 | 行号 | 函数 | 说明 |
|---|---|---|---|
| app/victoria-metrics/main.go | 33 | main | 入口 |
| app/victoria-metrics/main.go | 84 | requestHandler | http处理函数 108行调用vmselect.RequestHandler |
| app/vmselect/main.go | 87 | RequestHandler | 查询请求入口 220行调用prometheus.QueryRangeHandler |
| app/vmselect/prometheus/prometheus.go | 1088 | QueryRangeHandler | /api/v1/query_range 入口 1112行调用queryRangeHandler |
| app/vmselect/prometheus/prometheus.go | 1118 | queryRangeHandler | queryRangeHandler 1151行调用promql.Exec |
| app/vmselect/promql/exec.go | 29 | Exec | 执行查询 43行调用evalExpr |
| app/vmselect/promql/eval.go | 186 | evalExpr | 191行调用evalRollupFunc |
| app/vmselect/promql/eval.go | 482 | evalRollupFunc | 509行调用evalRollupFuncWithMetricExpr |
| app/vmselect/promql/eval.go | 646 | evalRollupFuncWithMetricExpr | 684行调用netstorage.ProcessSearchQuery 截止这个函数,VM单机版和群集版的vm-select几乎是一致的。 |
| app/vmselect/netstorage/netstorage.go | 1009 | ProcessSearchQuery | 执行ql查询语言。从存储引擎读取数据 |
3.结论
- 证实了我的猜想:
- vm单机版和vm集群版,在查询上,本质的不同就是进程内处理数据和进程间处理数据的差别。
- vm单机版中,解析完promql后,直接通过存储引擎的接口拉取数据,然后进行计算。(逻辑上并未看见因为存储引擎就在本机而做的特殊优化)
- VM群集版中:
- vm-select负责解析promql,然后转换成range_query的参数
- vm-select通过网络协议请求vm-storage
- vm-storage查询到time series和data point后,返回给vm-select(数据极度精简,且经过ZTD算法压缩)
- vm-select从多个vm-storage收到数据后,进行去重、计算、输出JSON
- vm单机版从理论上比vm群集版节约了这些步骤:
- vm-select到vm-storage的网络通讯可以省掉
- vm-storage向vm-select返回数据的ZSTD压缩可以省掉
- 不必访问多个vm-storage,因此vm-select的响应时间等于最慢的那个vm-storage。单机版中没有这个等待。
- 数据量很大的情况下,上述的节省也是非常可观的。
- 我认为vm单机版的优化还是不够:
- 如果存储节点在本地,起码可以做边捞取数据边汇总,这样查询时候的内存占用就会减小很多。(但这样也不会节约计算时间)
- 最好增加recording rules的能力,通过预计算提升查询性能
【VictoriaMetrics】vm单机版和vm-storage的查询功能的对比的更多相关文章
- Linux虚拟内存(swap)调优篇-“swappiness”,“vm.dirty_background_ratio”和“vm.dirty_ratio”
Linux虚拟内存(swap)调优篇-“swappiness”,“vm.dirty_background_ratio”和“vm.dirty_ratio” 作者:尹正杰 版权声明:原创作品,谢绝转载 ...
- Springboot+Vue实现仿百度搜索自动提示框匹配查询功能
案例功能效果图 前端初始页面 输入搜索信息页面 点击查询结果页面 环境介绍 前端:vue 后端:springboot jdk:1.8及以上 数据库:mysql 核心代码介绍 TypeCtrler .j ...
- 通过维基API实现维基百科查询功能
通过英文维基的免费API,可以实现对维基百科的搜索查询或者标题全文查询等,尝试了一下通过title实现全文查询,返回的结果是wikitext格式,暂时不知道该如何应用,所以仅实现了查询功能,可以返回最 ...
- Django models .all .values .values_list 几种数据查询结果的对比
Django models .all .values .values_list 几种数据查询结果的对比
- 创建ASP.NET Core MVC应用程序(5)-添加查询功能 & 新字段
创建ASP.NET Core MVC应用程序(5)-添加查询功能 & 新字段 添加查询功能 本文将实现通过Name查询用户信息. 首先更新GetAll方法以启用查询: public async ...
- MySQL 5.5开启慢查询功能
vim /etc/my.cnf [mysqld] slow-query-log = on # 开启慢查询功能 slow_query_log_file = /usr/local/mysql/data/s ...
- php+mysql预查询prepare 与普通查询的性能对比
prepare可以解决大访问量的网站给数据库服务器所带来的负载和开销,本文章通过实例向大家介绍预查询prepare与普通查询的性能对比,需要的朋友可以参考一下. 实例代码如下: <?php cl ...
- ASP.NET MVC系列:为视图添加查询功能
首先,在MoviesController里添加一个查询方法,代码如下 public ActionResult SearchIndex(string title) { //查询数据库中的电影表 var ...
- 完善ext.grid.panel中的查询功能(紧接上一篇)
今天的代码主要是实现,Ext.grid.panel中的查询,其实我也是一名extjs新手,开始想的实现方式是另外再创建一个新的grid类来存放查询出的数据(就是有几个分类查询就创建几个grid类),这 ...
随机推荐
- CF507A Amr and Music 题解
Content 有一个容量为 \(k\) 的背包.有 \(n\) 个物品,第 \(i\) 个物品的体积为 \(c_i\).请求出背包最多能够装下的物品的个数,并输出任意一个方案. 数据范围:\(1\l ...
- java 多线程:线程通信-等待通知机制wait和notify方法;(同步代码块synchronized和while循环相互嵌套的差异);管道通信:PipedInputStream;PipedOutputStream;PipedWriter; PipedReader
1.等待通知机制: 等待通知机制的原理和厨师与服务员的关系很相似: 1,厨师做完一道菜的时间不确定,所以厨师将菜品放到"菜品传递台"上的时间不确定 2,服务员什么时候可以取到菜,必 ...
- ligerUI问题
1.checkboxColWidth:990,Grid的复选框的宽度设置为什么不起作用. 2.当grid出现横线不对齐时,可以设置detailColWidth:90,属性进行设置.此属性好像只是针对复 ...
- 20款GitHub上优秀的Go开源项目
docker 无人不知的虚拟华平台,开源的应用容器引擎,借助该引擎,开发者可以打包他们的应用,移植到任何平台上. https://github.com/docker/docker 38154 star ...
- 论文解读SDCN《Structural Deep Clustering Network》
前言 主体思想:深度聚类需要考虑数据内在信息以及结构信息. 考虑自身信息采用 基础的 Autoencoder ,考虑结构信息采用 GCN. 1.介绍 在现实中,将结构信息集成到深度聚类中通常需要解决以 ...
- C. Success Rate
Success Rate 题目链接 题意 给你两个分数形式的数,然后有两种变化方式 上下都+1 仅下面部分+1 让你求第一个分数变化到第二个分数的最小步数. 思路 有几种特殊情况分类讨论一下. 首先我 ...
- 【LeetCode】852. Peak Index in a Mountain Array 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 二分查找 查找最大值位置 寻找第一个下降的位置 日期 ...
- 【LeetCode】817. Linked List Components 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- 用户线程&&守护线程
守护线程是为用户线程服务的,当一个程序中的所有用户线程都执行完成之后程序就会结束运行,程序结束运行时不会管守护线程是否正在运行,由此我们可以看出守护线程在 Java 体系中权重是比较低的.当 ...
- 第四十六个知识点 在Sigma协议中,正确性,公正性和零知识性意味着什么
第四十六个知识点 在Sigma协议中,正确性,公正性和零知识性意味着什么 Sigma协议 Sigma协议是Alice想要向Bob证明一些东西的协议(Alice知道一些秘密).他们有下面的一般范式:Al ...