开发者社区 > 数据库 > 数据仓库 > 正文

云原生数据仓库AnalyticDB PostgreSQL版有两个问题帮我解答下?

云原生数据仓库AnalyticDB PostgreSQL版有两个问题帮我解答下,第一是只要有长连接的进程,就会导致任何表都无法用vacuum full 清理还是这个进程中的查询SQL里用到了这张表才清理不掉?第二是我只需要关注active状态长时间未断开的还是idle状态长时间未断开的也需要关注?

展开
收起
真的很搞笑 2024-01-21 19:40:04 56 0
2 条回答
写回答
取消 提交回答
    1. 只要在事务中的长进程就会导致任何表的vacuum都受影响
    2. 需要关注的是active和idle in transaction状态的进程,idle状态的不需要关注了 ,此回答整理自钉群“云原生数据仓库AnalyticDB PostgreSQL版交流群开源讨论群”
    2024-01-22 10:56:01
    赞同 展开评论 打赏
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    只有当长连接的进程中的查询SQL里用到了这张表时,才会导致无法使用VACUUM FULL进行清理。同时,您需要关注长时间未断开的active状态和idle状态的连接

    AnalyticDB PostgreSQL版是一种基于PostgreSQL的MPP数据仓库服务,其设计用于处理大规模数据分析任务。在数据库维护过程中,VACUUM和VACUUM FULL是两种重要的清理工具,它们的作用是在数据库中回收空间。VACUUM命令主要对页内的数据进行整理,而VACUUM FULL则会跨数据页移动数据,并请求排他锁来进行更为彻底的整理。如果存在长连接的进程,并且这些进程中的查询正在使用某张表,那么VACUUM FULL将无法对该表进行清理。这是因为VACUUM FULL在执行时需要获得排他锁,而长连接的进程会持有该表的锁,从而阻止了VACUUM FULL的操作。

    对于长时间未断开的连接,无论是active状态还是idle状态,都应该予以关注。Active状态的长连接可能意味着有持续的数据库操作正在进行,而idle状态的长连接则可能是应用程序未能正确关闭数据库连接所致。

    综上所述,为了确保数据库性能和资源的有效利用,建议定期检查并管理长连接,以及合理规划VACUUM和VACUUM FULL的使用。

    2024-01-21 19:48:35
    赞同 展开评论 打赏

阿里云自主研发的云原生数据仓库,具有高并发读写、低峰谷读写、弹性扩展、安全可靠等特性,可支持PB级别数据存储,可广泛应用于BI、机器学习、实时分析、数据挖掘等场景。包含AnalyticDB MySQL版、AnalyticDB PostgreSQL 版。

相关产品

  • 云原生数据仓库AnalyticDB MySQL版
  • 相关电子书

    更多
    阿里云云原生技术实践营 | 上海站 立即下载
    阿里云云原生 Serverless 技术实践营西安站材料合集 立即下载
    智算时代,基于 Kubernetes 落地云原生 AI 立即下载

    相关镜像