博客
关于我
PostgreSQL unlogged table
阅读量:558 次
发布时间:2019-03-09

本文共 1134 字,大约阅读时间需要 3 分钟。

PostgreSQL 提供了 "unlogged table" 的概念,这种表类似于 Oracle 的 nologging 表选项,主要用于减少写入时的共享加速组件(WAL)的日志记录,从而提升写入性能。这种表在高频率或批量写入场景中非常有用。以下是对 unlogged table 的逐项分析以及与普通表的性能对比分析。

1. **unlogged table 的特点**

  • unlogged table 不记录 WAL 日志,写入速度更快,适合高频率的插入操作。
  • 当数据库 experience a crash 后,表数据将在恢复时自动清空。这意味着需要确保这种表在设计时有重建机制。
  • 正常关闭数据库后,unlogged table 的数据仍会保留,只是重启时会清空。
  • unlogged table 最常见的用途是处理中间结果或频繁更改的会话数据,这类数据不需要持久化保存。
  • 2. **性能对比分析**

  • **普通表与 unlogged table 的比较**
    • 普通表需要记录 WAL 日志,写入速度相对较慢,且在.Master和从库间同步时会产生额外负担。而 unlogged table 不需要记录日志,因此写入速度更快。
    • 如果使用同步事务(如 Oliviavári 提出的两阶段提交),普通表的性能会有更大的下降,而 unlogged table 则表现较为稳定。
  • **unlogged table 与普通表的对比**
    • 在大多数情况下,unlogged table 的插入速度至少不逊于普通表的无索引插入速度,甚至在批量写入时性能更优。动态 SQL 生成的硬解析问题可以通过批量操作来减轻。
    • 在使用类似 Oracle 的 nologging 选项时,unlogged table 的表现类似,且其在 PostgreSQL 中的实现更为灵活。
  • 3. **适用场景**

  • 对于需要快速写入的中间结果表或频繁变更的会话数据,使用 unlogged table 是最佳选择。
  • 此外,unlogged table 在批量导入数据时特别有用,因为它可以显著降低处理 lateness。
  • 4. **注意事项**

  • unlogged table 不记录 WAL 日志,写入速度更快,但数据在 database crash 后会自动清空,需要谨慎处理。
  • 建议在使用 unlogged table 时,加上手动的重建逻辑,以确保数据的持久化和一致性。
  • 综上所述,unlogged table 在吞吐量和性能方面优于普通表,尤其适合处理那些不需要持久化存储的高频率数据。购买扩展阅读:如果你需要更深入地理解 Postgres 的性能优化技巧,可以参考《PostgreSQL性能优化指南》。

    转载地址:http://aycpz.baihongyu.com/

    你可能感兴趣的文章
    Netty基础—2.网络编程基础四
    查看>>
    Netty基础—3.基础网络协议一
    查看>>
    Netty基础—3.基础网络协议二
    查看>>
    Netty基础—4.NIO的使用简介一
    查看>>
    Netty基础—4.NIO的使用简介二
    查看>>
    Netty基础—5.Netty的使用简介
    查看>>
    Netty基础—6.Netty实现RPC服务一
    查看>>
    Netty基础—6.Netty实现RPC服务三
    查看>>
    Netty基础—6.Netty实现RPC服务二
    查看>>
    Netty基础—7.Netty实现消息推送服务一
    查看>>
    Netty基础—7.Netty实现消息推送服务二
    查看>>
    Netty基础—8.Netty实现私有协议栈一
    查看>>
    Netty基础—8.Netty实现私有协议栈二
    查看>>
    Netty多线程 和 Redis6 多线程对比
    查看>>
    Netty学习总结(1)——Netty入门介绍
    查看>>
    Netty学习总结(2)——Netty的高性能架构之道
    查看>>
    Netty学习总结(3)——Netty百万级推送服务
    查看>>
    Netty学习总结(4)——图解Netty之Pipeline、channel、Context之间的数据流向
    查看>>
    Netty学习总结(5)——Netty之TCP粘包/拆包问题的解决之道
    查看>>
    Netty学习总结(6)——Netty使用注意事项
    查看>>