首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Navicat 面向 PostgreSQL 查询超时的工具解决方案

Navicat 面向 PostgreSQL 查询超时的工具解决方案

作者头像
猫头虎
发布于 2024-04-08 07:02:25
发布于 2024-04-08 07:02:25
3390
举报

Navicat 面向 PostgreSQL 查询超时的工具解决方案

图片
图片

早前,我们发表过一篇《PostgreSQL 与 Navicat :数据库的中坚力量》 ,从产品的发展介绍了两者的渊源与共性,获得了许多童鞋的认可。而随着PostgreSQL 在国内热度愈发高涨,应用也愈发广泛。近期,我们收到许多用户的问询,涉及一些使用时的技术问题,例如:PostgreSQL 查询延时的优化方法等。今天,小编就带大家解析如何通过 Navicat 工具便捷地跟踪、设置查询超时语句时长和设置权限来确保你的 PostgreSQL 数据库实例保持良好状况和可用性,并保障数据库系统的性能稳定。

查询超时的必要性

查询超时指在执行数据库查询操作时,如果在一定时间内无法完成查询,则会自动终止查询操作并返回错误结果。其目的是为了保护数据库系统的稳定性和性能,并避免查询操作耗尽系统资源。它是数据库系统稳定性和性能的保障措施之一。如果没有设置查询超时,当一个查询操作耗费过多的时间时,系统资源就会不足,影响其他操作和整个系统的运行。因此,设置查询超时时间具有非常重要的必要性。

** **

应用场景
  1. 并发操作较多:在高并发的情况下,如果一些查询耗时过长,则可能会影响其他查询的执行效率,进而影响整个系统的响应速度。
  2. 大数据量查询:如果查询数据量过大,会消耗大量的系统资源,可能会导致系统崩溃,因此需要设置查询超时时间,防止查询过长时间执行。
  3. 防止恶意攻击:对于一些恶意的SQL注入攻击,我们可以设置查询超时时间来防止攻击者通过无限循环查询来耗尽系统资源。

查询分析器 | Navicat Monitor

Navicat Monitor 3 监控工具 - 查询分析器画面顶部(如下图),我们设计了一个图表,用以显示等待时间最长的查询:

图片
图片

它能够准确地标识出滞后的查询。这一点非常重要,因为它们可以让一切陷入瘫痪。

除了在标识出慢速查询并对其进行修复外,另一种策略就是全面限制查询执行时间。在PostgreSQL 等专业级数据库中,可以通过设置 statement_timeout 变量来限制整个数据库甚至每个用户的查询执行时间。下面,我们将学习如何在 Navicat 16 for PostgreSQL 中运用这个重要的数据库变量。

在数据库级别设置

statement_timeout 变量

为数据库设置默认语句超时是很常用的方式。这可确保连接到数据库的任何应用程序或人员的查询运行时间都不会超时。合理的默认值建议是 30 秒或 60 秒。但如果你愿意,可以设置更长的时间。以下是将值设置为 60 秒的语句:

ALTER DATABASE mydatabase SET statement_timeout = ‘60s’;

在 Navicat 16 for PostgreSQL 中,我们可以选择主菜单中的“工具”>“服务器监控”>“PostgreSQL”以查看 statement_timeout 变量。你会在“变量”选项卡找到它:

图片
图片

事实上,因为服务器有很多变量,你可能要使用查找工具来找出 statement_timeout 变量。你可以单击“全部高亮显示”切换按钮以更有效地找到匹配的变量。

当然,如果你想直接 show 语句,也可以在 Navicat 轻松实现:

图片
图片

为特定用户设置查询超时

为了更精确地控制,我们可以为特定用户设置查询超时值(总是会有人选择整个数据库…)。这能使用 ALTER ROLE 语句做到,它可以设置许多数据库变量,包括 statement_timeout。

我们尝试创建一个名为“guest”的新用户角色:

图片
图片

现在我们可以使用 ALTER ROLE 语句来限制查询执行时间,如下所示:

ALTER ROLE guest SET statement_timeout=‘5min’;

我们可以查询pg_roles 表来获取关于 statement_timeout 的信息(包括它是如何设置的):

图片
图片

rolconfig 值是一个数组,因此我们可以使用 unnest 取消嵌套,那么一行会显示一个设置:

图片
图片

** **

结语

为用户标识出滞后的查询是非常重要的,因为它让你对查询时间了如指掌,让你免受数据库性能陷入瘫痪的风险。为此,Navicat Monitor 3 监控工具的查询分析器画面顶部就设计出了这个费时查询图表。

另一种方法是限制查询在超时之前可以执行多久。正如在本文中提到,可以在 PostgreSQL 的数据库、会话甚至单个角色级别设置查询超时。如果你还没有设置 statement_timeout 变量,我们建议你尽快设置。这只是优化数据库性能的其中一步,但它有助于确保你的数据库实例保持良好状况和可用。

结语

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-07-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
C#开发BIMFACE系列50 Web网页中使用jQuery加载模型与图纸
在前一篇博客《C#开发BIMFACE系列49 Web网页集成BIMFACE应用的技术方案》中介绍了目前市场主流的Web开发技术与应用框架,其中前端脚本的应用在国内分2大派系 jQuery 与 Vue.js。
张传宁IT讲堂
2021/10/21
8680
C#开发BIMFACE系列37 网页集成开发1:审图系统中加载模型或图纸
在之前的《C#开发BIMFACE系列》中主要介绍了BIMFACE平台提供的服务端API接口的封装开发与测试过程。
张传宁IT讲堂
2020/03/18
8030
C#开发BIMFACE系列37 网页集成开发1:审图系统中加载模型或图纸
C#开发BIMFACE系列42 服务端API之图纸对比
在我的前一篇博客《C#开发BIMFACE系列41 服务端API之模型对比》中详细介绍了BIMFACE服务端接口模型对比的功能。 BIMFACE官方文档提供的三维模型对比接口同样也适用于二维CAD图纸对比。下图中是官方提供的对比示例程序。
张传宁IT讲堂
2021/10/13
6110
C#开发BIMFACE系列46 服务端API之离线数据包下载及结构详解
在前一篇博客《C#开发BIMFACE系列45 服务端API之创建离线数据包》中通过调用接口成功的创建一个离线数据包
张传宁IT讲堂
2021/10/18
6850
C#开发BIMFACE系列38 网页集成开发2:审图系统中的模型或图纸批注
在运维或协同的场景中,经常需要对模型或图纸进行批注,及时记录已发现的问题并交给相关负责的人员。
张传宁IT讲堂
2020/03/18
9840
C#开发BIMFACE系列38 网页集成开发2:审图系统中的模型或图纸批注
C#开发BIMFACE系列39 网页集成开发3:审图系统中三维模型比对
  在建筑施工图审查系统中,设计单位提交设计完成的模型/图纸,审查专家审查模型/图纸。审查过程中如果发现不符合规范的地方,则流程退回到设计单位,设计单位人员根据审查意见重新调整设计,调整完成后再次提交到审查专家。此时为了便于专家审查,需要知道当前轮次的模型/图纸与上一轮次的模型/图纸发生了哪些异动,针对异动情况进行审查即可。
张传宁IT讲堂
2020/04/30
4340
C#开发BIMFACE系列39 网页集成开发3:审图系统中三维模型比对
C#开发BIMFACE系列15 服务端API之获取模型的View token
在《C#开发BIMFACE系列3 服务端API之获取应用访问凭证AccessToken》中详细介绍了应用程序访问API的令牌凭证。我们知道 Access token 代表自身应用的身份,使用应用的 appkey, secret,通过调用/oauth2/token接口获取。BIMFACE所有的接口调用都需要传递 Access token 。
张传宁IT讲堂
2019/09/18
6480
C#开发BIMFACE系列49 Web网页中加载模型与图纸的技术方案
C#开发BIMFACE系列3 服务端API之获取应用访问凭证AccessToken
张传宁IT讲堂
2021/10/20
1.9K0
C#开发BIMFACE系列45 服务端API之创建离线数据包
BIMFACE的常规应用方式有公有云与私有化部署两种方式,并且浏览模型或者图纸需要使用ViewToken,ViewToken 有效期为12小时,过期后需要调用接口重新生成。该过程稍微有点麻烦且性能可能受到网络等环境的影响。本文介绍第三种更加便捷高效的方式。
张传宁IT讲堂
2021/10/18
3660
C#开发BIMFACE系列29 服务端API之获取模型数据14:获取图纸列表
一个三维模型中可能包含对应多张二维图纸列表,本篇主要介绍如何获取模型文件对应的图纸列表。
张传宁IT讲堂
2019/09/18
5430
C#开发BIMFACE系列29 服务端API之获取模型数据14:获取图纸列表
C#开发BIMFACE系列43 服务端API之图纸拆分
在上一篇博客《C#开发BIMFACE系列42 服务端API之图纸对比》的最后留了一个问题,在常规业务场景下,一个.dwg文件中包含多个图框,如下图
张传宁IT讲堂
2021/10/15
4010
C#开发BIMFACE系列26 服务端API之获取模型数据11:获取单个面积分区信息
在《C#开发BIMFACE系列25 服务端API之获取模型数据9:获取楼层对应面积分区列表》一文中介绍了如何获取单个模型中单个楼层包含的面积分区列表。有了面积分区列表之后,即可查询单个面积分区的具体信息。
张传宁IT讲堂
2019/09/18
4290
C#开发BIMFACE系列26 服务端API之获取模型数据11:获取单个面积分区信息
C#开发BIMFACE系列41 服务端API之模型对比
  在建筑施工图审查系统中,设计单位提交设计完成的模型/图纸,审查专家审查模型/图纸。审查过程中如果发现不符合规范的地方,则流程退回到设计单位,设计单位人员根据审查意见重新调整设计,调整完成后再次提交到审查专家。此时为了便于专家审查,需要知道当前轮次的模型/图纸与上一轮次的模型/图纸发生了哪些异动,针对异动情况进行审查即可。
张传宁IT讲堂
2021/10/13
3700
C#开发BIMFACE系列18 服务端API之获取模型数据3:获取构件属性
请求地址:GET https://api.bimface.com/data/v2/files/{fileId}/elements/{elementId}
张传宁IT讲堂
2019/09/18
6340
C#开发BIMFACE系列18 服务端API之获取模型数据3:获取构件属性
C#开发BIMFACE系列27 服务端API之获取模型数据12:获取构件分类树
BIMFACE官方示例中,加载三维模型后,模型浏览器中左上角默认提供了“目录树”的功能,清晰地展示了模型的完整构成及上下级关系。
张传宁IT讲堂
2019/09/18
9240
C#开发BIMFACE系列27 服务端API之获取模型数据12:获取构件分类树
C#开发BIMFACE系列1 BIMFACE 简介
BIMFACE 是广联达公司旗下的一款具有完全自主知识产权的BIM轻量化引擎,建筑行业的软件开发者可在BIMFACE所提供的基础功能上进行二次开发,为终端用户提供更加丰富、更有价值的BIM应用。
张传宁IT讲堂
2019/09/18
1.4K0
C#开发BIMFACE系列1 BIMFACE 简介
C#开发BIMFACE系列30 服务端API之模型对比1:发起模型对比
  在实际项目中,由于需求变更经常需要对模型文件进行修改。为了便于用户了解模型在修改前后发生的变化,BIMFACE提供了模型在线对比功能,可以利用在线的模型对比接口,通过简单的四个步骤实现模型在线对比。模型对比可以对两个文件/模型进行差异性分析,确定两个文件/模型之间构件的几何和属性差异,包括增加的构件、删除的构件和修改的构件。 模型对应可以用于进行文件/模型的版本对比。
张传宁IT讲堂
2020/03/18
4630
C#开发BIMFACE系列11 服务端API之源文件删除
通过BIMFACE控制台或者调用服务接口上传文件成功后,如果不再需要该文件,则可以通过BIMFACE平台提供的“源文件删除”服务接口删除具体的文件。下面详细介绍其使用方法。
张传宁IT讲堂
2019/09/18
4580
C#开发BIMFACE系列11 服务端API之源文件删除
C#开发BIMFACE系列40 服务端API之模型集成
  随着建筑信息化模型技术的发展,越来越多的人选择在云端浏览建筑模型。现阶段的云端模型浏览大多是基于文件级别,一次只可以浏览一个模型文件中的内容。而在工程项目模型设计的过程中,通常由多个设计师协同设计,不同的设计师负责不同的专业领域(例如建筑、结构、水电等)。如果想要在云端浏览整个项目工程,就需要把这些组成部分集成起来一起展示。更近一步,如果要在集成的模型之上进行业务集成的话,就要求在集成过程中对构件按单体,楼层,专业,构件分类,系统类型等进行分类或映射。
张传宁IT讲堂
2021/10/13
5790
C#开发BIMFACE系列19 服务端API之获取模型数据4:获取多个构件的共同属性
在前几篇博客中介绍了一个三维文件/模型包含多个构建,每个构建又是由多种材质组成,每个构建都有很多属性。不同的构建也有可能包含相同的属性。
张传宁IT讲堂
2019/09/18
6650
C#开发BIMFACE系列19 服务端API之获取模型数据4:获取多个构件的共同属性
推荐阅读
相关推荐
C#开发BIMFACE系列50 Web网页中使用jQuery加载模型与图纸
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档