【DB吐槽大会】第28期 - PG 每次只扩展1个block

简介: 大家好,这里是DB吐槽大会,第28期 - PG 每次只扩展1个block

背景



1、产品的问题点

  • PG 每次只扩展1个block

2、问题点背后涉及的技术原理

  • 当写入或更新数据时, 如果现有的数据文件无法放下新的tuple, 需要extend 数据文件, 但是PG只扩展1个数据块.

3、这个问题将影响哪些行业以及业务场景

  • 高速写入的业务场景, 例如IOT, 时序, feedlog类.

4、会导致什么问题?

  • 导致extend block exclusive锁竞争, 影响写入性能

5、业务上应该如何避免这个坑

  • 编译时, 选择更大的block size, 只能弱化无法避免这个问题.

6、业务上避免这个坑牺牲了什么, 会引入什么新的问题

  • 管理更加复杂, 而且无法完全避免.
  • 由于目前PG的一个实例只能选择一种block size规格, 如果选择大的block size, 会导致某些需要小block size的表可能性能变差并浪费更多shared buffer. (例如偏TP的业务)

7、数据库未来产品迭代如何修复这个坑

  • 希望可以自定义扩展规则, 例如
  • 表级别可以设置, 每次扩展多少个block, 或者:
  • 根据数据表的大小, 阶梯性增加每次扩展多少个blocks, 直到封顶max extend blocks



相关文章
|
关系型数据库 数据库 PostgreSQL
【DB吐槽大会】第38期 - PG 不能自动创建(扩展)分区
大家好,这里是DB吐槽大会,第38期 - PG 不能自动创建(扩展)分区
|
存储 关系型数据库 物联网
【DB吐槽大会】第27期 - PG 单一 block size
大家好,这里是DB吐槽大会,第27期 - PG 单一 block size
|
SQL 关系型数据库 数据库
【DB吐槽大会】第78期 - PG 不支持绕过shared buffer的查询和写入
大家好,这里是DB吐槽大会,第78期 - PG 不支持绕过shared buffer的查询和写入
|
SQL 关系型数据库 数据库
【DB吐槽大会】第75期 - PG 不支持索引失效功能
大家好,这里是DB吐槽大会,第75期 - PG 不支持索引失效功能
|
关系型数据库 数据库
【DB吐槽大会】第46期 - PG copy不能跳过错误行
大家好,这里是DB吐槽大会,第46期 - PG copy不能跳过错误行
|
SQL 关系型数据库 Java
【DB吐槽大会】第16期 - PG Standby不支持解析逻辑日志
大家好,这里是DB吐槽大会,第16期 - PG Standby不支持解析逻辑日志
|
SQL 存储 关系型数据库
【DB吐槽大会】第60期 - PG 只读实例不支持写操作
大家好,这里是DB吐槽大会,第60期 - PG 只读实例不支持写操作
|
容灾 关系型数据库 数据库
【DB吐槽大会】第37期 - PG 没有block级增量备份恢复
大家好,这里是DB吐槽大会,第37期 - PG 没有block级增量备份恢复
|
存储 算法 NoSQL
【DB吐槽大会】第19期 - PG 没有block level压缩
大家好,这里是DB吐槽大会,第19期 - PG 没有block level压缩
|
关系型数据库 数据库 索引
【DB吐槽大会】第32期 - PG 没有全局索引
大家好,这里是DB吐槽大会,第32期 - PG 没有全局索引