暂无图片
暂无图片
暂无图片
暂无图片
暂无图片
postgres12特性
845
2页
1次
2019-12-21
5墨值下载
PostgreSQL 12
的可拔插存储引擎
--
表访问方法以及
bloackholes
案例
正文
PostgreSQL
使 便
Decoder
plugins
extension
background workers
、索引访问方法、
hooks
、自定义函数、聚合、数据
类型等。
对代码做了大量的重构后
PG12
具备了表访问方法的基础架构,允许自定义表数据如
何存储以及访问。默认情况下,
PG
的表还是使用
heap
存储引擎。他的工作原理是基于
8KB
的页面管理方式,并以段文件(默
1GB
)的形式管理页面。需要保存所有版本的
tuple
使
tuple
使
vaccum
autovacuum
变得更加昂贵。当然,本文目的不是讨论这个,需要了解的话可以查看手册。
访问
cool
允许形式
PG
,就
MySQL
多个
一样,使实现诸如列存储的功能成为可能。做的方法大致分为两类:
通过
PG
存储管理器的访问方法,充分利用现有
shared bu%er
层以及现有的页格式。
2
个优势:自动支持备份和
checksum
通过
PG
访问依赖
PG
shared bu%er
。使于操
为可能。当然,需要自己添加函数来完成对
checksum
和备份的支持。
O'awa
PG
大会上有两个主题关于这个特性:
h'ps://www.pgcon.org/2019/schedule/events/1374.en.html
h'ps://www.pgcon.org/2019/schedule/events/1321.en.html
最近们开讨论
AMs
zheap
或者
zstore
。可插的
WAL
也收限制
WAL
resource manager IDs
hard values
AM
TIDs
为一个重要问题。
有大量的回调函数定义了
AM
表是什么(当前有
42
个),未来接口可能会改变。
我写了个简单
demo
作为表访问方
blackhole_am
。作为一个新插件的一个
demo
操作函数都是空函数。创建表访问方式需要
CREATE ACCESS METHOD
。编译后生成一个动态
链接库,以扩展插件的形式集成到
PG
=# CREATE EXTENSION blackhole_am;
CREATE EXTENSION
=# \dx+ blackhole_am
Objects in extension "blackhole_am"
Object description
-----------------------------------------
access method blackhole_am
function blackhole_am_handler(internal)
(2 rows)
default_table_access_method
访
using
=# CREATE TABLE blackhole_tab (id int) USING blackhole_am;
CREATE TABLE
=# INSERT INTO blackhole_tab VALUES (generate_series(1,100));
INSERT 0 100
=# SELECT * FROM blackhole_tab;
id
----
(0 rows)
原文
https://paquier.xyz/postgresql-2/postgres-12-table-am-blackhole/
of 2
5墨值下载
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文档的来源(墨天轮),文档链接,文档作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论

关注
最新上传
暂无内容,敬请期待...
下载排行榜
Top250 周榜 月榜