【PostgreSQL内核学习(六)—— 工具使用学习】

news2025/1/13 17:49:34

工具使用学习

  • 工具使用学习
  • 安装中出现的问题

声明:本文的工具学习内容来自于《小宇带你学pg内核分析》
工具的代码仓库链接为:
https://github.com/shenyuflying/pgNodeGraph
此外,我还参考了以下文章:
https://rng-songbaobao.blog.csdn.net/article/details/104023090
在此非常感谢以上博主所提供的资源!!!

工具使用学习

工具的用途:通过这个工具我们可以十分方便的把日志文件的输出(文字形式)转化为图片。

使用步骤:

  1. 在代码仓库中拉取代码
    在这里插入图片描述
  2. 获取日志文件中的抽象语法树

  要让 PostgreSQL 服务器在日志中打印解析和计划节点树,你可以按照以下步骤进行设置:

  • 打开 PostgreSQL 配置文件 postgresql.conf,可以通过以下命令定位到配置文件的位置:`psql -c “SHOW config_file;”
  • 编辑 postgresql.conf 文件,在文件中找到 logging_collector 配置项,并确保其值为 on,表示启用日志收集器。
  • 找到 log_destination 配置项,并确保其值中包含 csvlog,例如:log_destination = 'stderr,csvlog'
  • 找到 logging_collector 配置项,并确保其值为 on,表示启用日志收集器。
  • 找到 log_statement 配置项,并将其值设置为 all,表示记录所有类型的 SQL 语句。如果你只想记录解析和计划节点树的信息,可以将其设置为 parse
  • 找到 debug_print_parsedebug_print_rewrittendebug_print_plan 配置项,并将它们的值设置为 on,表示启用打印解析和计划节点树的调试输出。
  • 保存配置文件,并重新启动 PostgreSQL 服务器,使配置生效。

  完成上述步骤后,PostgreSQL 服务器将在日志中打印解析和计划节点树的详细信息。你可以通过查看日志文件来获取相应的输出信息。

  1. 进行gdb调试
  • 首先在exec_simple_query函数中打上断点:b exec_simple_query
  • 单步调试进入函数pg_analyze_and_rewrite
  • 单步调试进入函数parse_analyze
  • 单步调试进入函数transformTopLevelStmt
  • 单步调试进入函数transformOptionalSelectInto
  • 使用 bt 查看当前调用堆栈的回溯信息,即显示当前正在执行的函数以及它们的调用关系,如下所示:
    在这里插入图片描述
  • 得到分析树 parseTree
  • 随后在GDB调试中执行如下操作:call elog_node_display(15,”name”,要显示的结果的地址,1);
      这句代码是 PostgreSQL 中的调试输出语句,用于将查询树(parseTree)以更美观的格式打印出来,并输出到日志。该函数是由宏 elog_node_display 来实现的。具体参数的意思如下:
    (1)15:这是日志的日志级别,表示 LOG 级别,即输出为信息性消息。
    (2)name”:这是打印出来的查询树的标题,相当于给打印的内容起一个名称,可以用来区分不同的输出。
    (3)parseTree这是要打印的查询树,通常是 Query 结构体类型的指针。
    (4)1:这是打印的详细程度级别,为 1 表示最详细的打印方式
  1. 在日志文件中查找最新的记录(日志文件路径:postgresql/data/log
    在这里插入图片描述
  2. 将生成的文件在工具文件包的 “node” 文件夹下拷贝一份,文件后缀名为 .node
    在这里插入图片描述
  3. 运行命令:./pgNodeGraph
    在这里插入图片描述
  4. 最后在 pic 文件中可以查看生成的图片文件。
    在这里插入图片描述
    在这里插入图片描述

安装中出现的问题

  在执行命令./pgNodeGraph时出现报错如下:
在这里插入图片描述
原因:似乎是内存问题,通过查找资料了解到是说内存超过2G会出现问题。需要添加编译选项:-mcmodel。
解决办法:修改 pgNodeGraph 中的 gcc命令如下:gcc -mcmodel=medium -g node2dot.c -o node2dot

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/777981.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【腾讯云 Cloud Studio 实战训练营】使用Cloud Studio制作蛋仔派对兑换码工具

目录 🍳前言🍳实验介绍🍳产品介绍🍳抓包分析😃登录分析😃😃第一步,获取验证码😃😃第二步,保存验证码😃😃第三步&#xff0…

RocketMQ教程-(4)-领域模型概述

Apache RocketMQ 是一款典型的分布式架构下的中间件产品,使用异步通信方式和发布订阅的消息传输模型。通信方式和传输模型的具体说明,请参见下文通信方式介绍和消息传输模型介绍。 Apache RocketMQ 产品具备异步通信的优势,系统拓扑简单、上下…

ffmpeg中filter_query_formats函数解析

ffmpeg中filter_query_formats主要起一个pix fmt引用指定的功能。 下下结论&#xff1a; 先看几个结构体定义&#xff1a; //删除了一些与本次分析不必要的成员 struct AVFilterLink {AVFilterContext *src; ///< source filterAVFilterPad *srcpad; ///<…

C语言程序运行需要的两大环境《C语言进阶》

目录 程序的翻译环境和执行环境 翻译环境分为两部分&#xff0c;编译链接 第一步&#xff1a;预编译&#xff08;预处理&#xff09; 第二步&#xff0c;编译 第三步&#xff1a;汇编 关于运行环境分为四点&#xff1a; 关于链接库 程序的翻译环境和执行环境 在 ANSI C(标…

三十章:Segmenter:Transformer for Semantic Segmentation ——分割器:用于语义分割的Transformer

0.摘要 图像分割在单个图像块的级别上经常存在歧义&#xff0c;并需要上下文信息来达到标签一致性。在本文中&#xff0c;我们介绍了一种用于语义分割的Transformer模型- Segmenter。与基于卷积的方法相比&#xff0c;我们的方法允许在第一层和整个网络中对全局上下文进行建模。…

C语言 与 C++ 通讯录对比实现(附源码)

目录 1.通讯录的基本框架 C语言版 C版 2.增加联系人 C语言版 C版 3.删除联系人 C语言版 C版 4.查找与打印联系人 C语言版 C版 5.修改联系人 C语言版 C版 6.排序联系人 C语言版 C版 7.其他 8.总结 本文章将对C语言、C版本的通讯录进行对比实现。其中C版本引入大量C语言没有的特性…

macOS 源码编译 Percona XtraBackup

percona-xtrabackup-2.4.28.tar.gz安装依赖 ╰─➤ brew install cmake ╰─➤ cmake --version cmake version 3.27.0brew 安装 ╰─➤ brew update╰─➤ brew search xtrabackup > Formulae percona-xtrabackup╰─➤ brew install percona-xtrabackup╰─➤ xtr…

提升 API 可靠性的五种方法

API 在我们的数字世界中发挥着关键的作用&#xff0c;使各种不同的应用能够相互通信。然而&#xff0c;这些 API 的可靠性是保证依赖它们的应用程序功能正常、性能稳定的关键因素。本文&#xff0c;我们将探讨提高 API 可靠性的五种主要策略。 1.全面测试 要确保 API 的可靠性…

Kubernetes 入门

Kubernetes 入门 文章目录 Kubernetes 入门一、Kubernetes 环境部署1. 环境准备2. 测试部署 Nginx3. 在任意节点使用 kubectl 二、深入 pod1. 使用配置文件部署引用2. 探针 三、资源调度1.标签与选择器2.Deployment3.StatefulSet4.DaemonSet5.HPA6. Service7. Ingress8. 配置管…

【Unity】为角色添加动画

如何添加动画 在Animations的AnimationClips文件夹下自己为角色创建一个文件夹 为角色添加Animator 然后选中上面创建的文件夹&#xff0c;拖动到上图中的Controller中 点击最上方任务栏的Window>Animation>Animation&#xff0c;这会弹出一个Animation窗口 该窗口存在时…

算法leetcode|63. 不同路径 II(rust重拳出击)

文章目录 63. 不同路径 II&#xff1a;样例 1&#xff1a;样例 2&#xff1a;提示&#xff1a; 分析&#xff1a;题解&#xff1a;rust&#xff1a;go&#xff1a;c&#xff1a;python&#xff1a;java&#xff1a; 63. 不同路径 II&#xff1a; 一个机器人位于一个 m x n 网格…

SQL_SQL_常见面试问题

问题类型 &#xff1a;SQL优化 问题描述 &#xff1a;用户浏览日志&#xff08;date, user_id, video_id&#xff09;, 统计 2020.03.29 观看不同视频个数的前5名 user_id。 思路 &#xff1a;主要注意预计算&#xff0c;避免直接去重 解决方案 &#xff1a; Hive_HQL_Hive…

【VB6|第20期】遍历Excel单元格的四种方法

日期&#xff1a;2023年7月19日 作者&#xff1a;Commas 签名&#xff1a;(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释&#xff1a;如果您觉得有所帮助&#xff0c;帮忙点个赞&#xff0c;也可以关注我&#xff0c;我们一起成长&#xff1b;如果有不对的地方&#xf…

架构实战微服务架构拆解

作业内容 拆分电商系统为微服务。 背景&#xff1a;假设你现在是一个创业公司的 CTO&#xff0c;开发团队大约 30 人左右&#xff0c;包括 5 个前端和 25 个后端&#xff0c;后端开发人员 全部都是 Java&#xff0c;现在你们准备从 0 开始做一个小程序电商业务&#xff0c;请你…

2023牛客暑期多校训练营1--K Subdivision(最短路树)

题目描述 You are given a graph with n vertices and m undirected edges of length 1. You can do the following operation on the graph for arbitrary times: Choose an edge (u,v) and replace it by two edges, (u,w) and (w,v), where w is a newly inserted vertex.…

【毕业季】九年程序猿有话说

活动地址&#xff1a;毕业季进击的技术er 九年程序猿有话说 勇敢前行&#xff0c;绽放青春&#xff0c;不负韶华&#xff01;选择IT的原因职场新人如何选择工作工作中&#xff0c;如何快速成长工作中用技术做过的最有成就感的事&#xff1f;程序员三十五岁瓶颈你怎么看&#xf…

445. 两数相加 II

445. 两数相加 II 给你两个 非空 链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数字都不会以零开头。 示例1&#xff1a; 输入&#xff1a;l1 [7,2,4,…

RocketMQ教程-(4)-主题(Topic)

本文介绍 Apache RocketMQ 中主题&#xff08;Topic&#xff09;的定义、模型关系、内部属性、行为约束、版本兼容性及使用建议。 定义​ 主题是 Apache RocketMQ 中消息传输和存储的顶层容器&#xff0c;用于标识同一类业务逻辑的消息。 主题的作用主要如下&#xff1a; 定义…

断路器分、合闸线圈直流电阻试验和绝缘电阻试验

断路器分、合闸线圈直流电阻试验 试验目的 对于断路器来说, 分、 合闸线圈是用于控制断路器分合闸状态的重要控制元件。 断路器停电检修时, 可以通过测试分、 合闸线圈的直流电阻来判断其是否正常。 试验设备 万用表 厂家&#xff1a; 湖北众拓高试代销 试验接线 分、 合闸线圈…

Linux系统进程概念详解

这里写目录标题 冯诺依曼体系结构操作系统(Operator System)1.概念2.目的3.管理4.系统调用和库函数概念 进程1.概念2.描述进程-PCB3.查看进程4.通过系统调用获取进程标示符5.通过系统调用创建进程-fork 进程状态1.Linux内核源代码2.进程状态查看 进程优先级1.基本概念2.查看系统…