内容简介:原文链接:查询日志分析器是一个Neo4j桌面应用,用于帮助了解Neo4j企业版服务器查询日志文件。
原文链接: https://medium.com/neo4j/meet...
查询日志分析器是一个Neo4j桌面应用,用于帮助了解Neo4j企业版服务器查询日志文件。
当Neo4j突然变慢、或者查询效率过低、再或者查询负载过高时,这时最好的办法就是查看查询日志。而查询日志通过neo4j.conf文件配置的。
dbms.logs.query.enabled=true # If the execution of query takes more time than this threshold, # the query is logged. If set to zero then all queries dbms.logs.query.threshold=100ms dbms.logs.query.parameter_logging_enabled=true dbms.logs.query.time_logging_enabled=true dbms.logs.query.allocation_logging_enabled=true dbms.logs.query.page_logging_enabled=true dbms.track_query_cpu_time=true dbms.track_query_allocation=true
一般情况下,设置一个阈值,当请求超过这个时间(示例是100ms,或者设置为0,代表所有请求)时,就会被记录下来。这也意味着,查询日志中记录的请求并不是服务器上的所有查询。但是这个 工具 仍然可以为你提供一个快速定位可能造成查询瓶颈的方向。
在后续的文章中我将会做详细的介绍。
当在开发项目时,最好要经常在开发服务器和测试服务器上分别去分析你的查询日志,以便发现问题。
工欲善其事必先利其器。接下来,先看一下如何安装查询日志分析器。
下面是在Neo4j Desktop 1.1.10+安装查询日志分析器。
打开“Graph Aplications"侧边栏,把URL ( https://neo.jfrog.io/neo/api/... 到"Insert Graph Application"输入框中,按下”Install“按钮。
选择一个工程,点击应用列表中的"+ Add Application"。
在这里增加“Query Log Analyzer”到你的工程中。
下面我来重点解释一下查询日志分析器。
查询日志分析器
查询日志分析器需要一个query.log文件。你将文件上传到工具中,然后它就开始分析。分析文件完成后,将显示下信息:
在上面的示例中的日志文件中,有17341行数据(一行一请求),有249个查询被发现。这些查询会显示在“Query Analysis"标签页中,你可以看到每个查询的统计数据。
查询分析
在Query Analysis标签页中,不同的查询是按 查询次数*平均时间 降序排列的。这样的 排序 可以将最耗时的查询排在最前面。
在Query Analysis标签页中,有以下字段和功能:
- The Query(在AvgTime — Avg Mem值的下面)
这是实际的查询语句 -
Query Count
日志文件中查询的次数,对于这个查询,还有下面一些功能可以使用:
- Filter
在Query Log标签内中,只显示这个查询的查询纪录。 - Highlight
在Query Log标签内中,高亮显示这个查询。当要看同时发到服务器的查询时,会更便于查看。 - Timline
实验性的!在Query Timeline标签中今次显示查询
- Filter
- Avg Time, Min Tim, Max Time
这里的时间是查询执行的累积时间(查询+执行计划+等待)。 -
Avg CPU
实际请求执行所占CPU时间。当详细时间日志被禁用时,这里显示0.
设置项:
dbms.logs.query.time_logging_enabled=true dbms.track_query_cpu_time=true
-
Max Planning
这是执行计划阶段所花费的最大时间,当鼠标悬停在该值上时,将会显示最小时间和平均时间。一般一个查询第一次被触发时,查询生成执行计划,然后这个执行计划被放到查询缓存中,当查询再次被执行时,生成执行计划的时间几乎为0。当执行计划被从缓存中移除时,下一个请求才会再次编译成执行计划。当Time logging被禁用时,此值显示0.设置项:
dbms.logs.query.time_logging_enabled=true
-
Avg Waiting
查询被执行前的平均等待时间。这个等待可能是由于数据库负载过重造成,也可能是由于数据库锁造成的。当Time logging被禁用时,此值显示为0。设置项:
dbms.logs.query.time_logging_enabled=true
-
Cache Hits %
代表这个请求的数据有百分之多少是从缓存中读取的。100%意味着所有数据都是从缓存中读取的。设置项:
dbms.logs.query.page_logging_enabled=true
-
Avg Mem
代表这个请求分配了多少内存。注意,这是一个累积值,表明了查询的内存占用情况。设置项:
dbms.logs.query.allocation_logging_enabled=true dbms.track_query_allocation=true
-
Protocol + Clients
在请求的上下文中你可以看到所使用的协议。其值有:
- bolt
一个blot客户端连到数据库。 - http
http客户端使用Neo4j的rest接口。(Neo4j老版本使用) - embedded
来自数据库内部的调用,像存储过程或函数。
- bolt
此外,还有一个客户端列表显示,它列出了当前有多少个不同IP向Neo4j服务器发出请求。注意,blot驱动是使用连接池连接数据库的,所以,你能看到1个IP会有多个客户端。
查询日志
Query Log标签页,使用查询日志行作为了标头。更多的信息则需要拖动水平滚动条才能看到。在第一个Query Analysis标签页里选择一个查询点击“Highlight",再点击Filter时,就会跳到这个页面,且只显示你选中的请求日志记录。这时,你可以拷贝这个标签页中的请求和参数去分析一个请求。
Query Timeline
Query Timeline是一个实验性的功能,它绘制出了每时间段(默认5分钟)查询总量和每秒种平均查询次数。它是基于日志文件中记录的时间,而不是查询开始时间。通过这张图,可以快速的了解到服务器是什么什么时候请求最多。
以上所述就是小编给大家介绍的《Neo4j知识库:初识Neo4j查询日志分析器》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 手写一个词法分析器
- React 性能分析器介绍
- Elasticsearch(八)【NEST高级客户端--分析器】
- Elasticsearch(八)【NEST高级客户端--分析器】
- Linux 下网络协议分析器 Wireshark 使用基础
- c++ CMake添加目标调用clang分析器
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Go语言学习笔记
雨痕 / 电子工业出版社 / 2016-6 / 89
作为时下流行的一种系统编程语言,Go 简单易学,性能很好,且支持各类主流平台。已有大量项目采用 Go 编写,这其中就包括 Docker 等明星作品,其开发和执行效率早已被证明。本书经四年多逐步完善,内容覆盖了语言、运行时、性能优化、工具链等各层面知识。且内容经大量读者反馈和校对,没有明显的缺陷和错误。上卷细致解析了语言规范相关细节,便于读者深入理解语言相关功能的使用方法和注意事项。下卷则对运行时源......一起来看看 《Go语言学习笔记》 这本书的介绍吧!