小程序制作平台网站设计平台 互联网品牌制作专家
关于A5客户收购GoogleAdsense带有搜索账户的相关事宜更多

软文发布平台资讯中心

解析PostgreSQL中Oid和Relfilenode的映射问题

解析PostgreSQL中Oid和Relfilenode的映射问题

  项目招商找A5 快速获取精准代理名单

PostgreSQL中的表会有一个RelFileNode值指定这个表在磁盘上的文件名(外部表、分区表除外)。一般情况下在pg_class表的relfilenode字段可以查出这个值,但是有一些特定表在relfilenode字段的查询结果是0,这个博客中将会探究这些特殊表relfilenode的内核处理。

正常表的Relfilenode

当我们创建一张普通表时,在pg_class系统表里可以查询出其relfilenode,可以看出在表刚刚创建时其oid和relfilenode都是16808,在磁盘上也可以查询到16808这个文件。事实上,这个文件存储了我们向表t2插入的数据。

postgres=# create table t2(i int);CREATE TABLEpostgres=# select oid,relname,relfilenode from pg_class where relname = 't2';oid | relname | relfilenode -------+---------+-------------16808 | t2 | 16808(1 row)

postgres=# \qmovead@movead-PC:/h2/pgpgpg/bin$ ll ../data/base/12835/16808 -rw-------+ 1 movead movead 0 12月 31 17:11 ../data/base/12835/16808movead@movead-PC:/h2/pgpgpg/bin$

在我们对一张表执行truncate,vacuum full等操作后,会重写这个表的数据,会引发这个表relfilenode值的变更。如下测试可以看出truncate之后,t2表的relfilenode从16808变为了16811.

postgres=# truncate t2;TRUNCATE TABLEpostgres=# select oid,relname,relfilenode from pg_class where relname = 't2';oid | relname | relfilenode -------+---------+-------------16808 | t2 | 16811(1 row)

postgres=# checkpoint;CHECKPOINTpostgres=# \qmovead@movead-PC:/h2/pgpgpg/bin$ ll ../data/base/12835/16808ls: 无法访问'../data/base/12835/16808': 没有那个文件或目录movead@movead-PC:/h2/pgpgpg/bin$ ll ../data/base/12835/16811-rw-------+ 1 movead movead 0 12月 31 17:16 ../data/base/12835/16811movead@movead-PC:/h2/pgpgpg/bin$

Nail表的Relfilenode

postgres=# select oid, relname, relfilenode,reltablespacefrom pg_classwhere relfilenode = 0 and relkind = 'r'order by reltablespace;oid | relname | relfilenode | reltablespace ------+-----------------------+-------------+---------------1247 | pg_type | 0 | 01255 | pg_proc | 0 | 01249 | pg_attribute | 0 | 01259 | pg_class | 0 | 03592 | pg_shseclabel | 0 | 16641262 | pg_database | 0 | 16642964 | pg_db_role_setting | 0 | 16641213 | pg_tablespace | 0 | 16641261 | pg_auth_members | 0 | 16641214 | pg_shdepend | 0 | 16642396 | pg_shdescription | 0 | 16641260 | pg_authid | 0 | 16646000 | pg_replication_origin | 0 | 16646100 | pg_subscription | 0 | 1664(14 rows)

postgres=#

上述查询可以看出,从pg_class系统表中查询出的这些表的relfilenode为0。其中pg_type、pg_proc、pg_attribute、pg_class是非共享表,在内核中称他们为Nail表。剩余的表是在pg_global表空间里的共享表。

pg_class表中relfilenode字段的意义是为了告诉程序,某一张表在磁盘上存储的文件名。比如我们查询t2表时,一定会先到pg_class系统表中获取其relfilenode,然后到磁盘找到这个文件,然后打开并扫描。可是如果我们想查询pg_class系统表在磁盘上的文件名时,应该去哪找到它的relfilenode?在PostgreSQL中提供了一组函数接口进行oid和relfilenode的转化。

postgres=# select pg_relation_filenode(1259);pg_relation_filenode ---------------------- 16475(1 row)

postgres=# select pg_filenode_relation(0,16475);pg_filenode_relation ----------------------pg_class(1 row)

postgres=# select pg_filenode_relation(0,16475)::oid;pg_filenode_relation ---------------------- 1259(1 row)

postgres=#

通过pg_relation_filenode()可以将oid转化为relfilenode,

通过pg_filenode_relation可以将relfilenode转化为oid.

既然pg_class表中不存储oid和relfilenode的对应关系,那么PostgreSQL是怎么样保存这个映射关系的呢?

Nail表Relfilenode的存储机制

经过研究发现,在数据目录里存在着pg_filenode.map文件,如下所示。

movead@movead-PC:/h2/pgpgpg/data/base/12835$ ll pg_filenode.map -rw-------+ 1 movead movead 512 12月 31 15:10 pg_filenode.mapmovead@movead-PC:/h2/pgpgpg/data/base/12835$movead@movead-PC:/h2/pgpgpg/data/global$ ll pg_filenode.map -rw-------+ 1 movead movead 512 12月 31 15:10 pg_filenode.mapmovead@movead-PC:/h2/pgpgpg/data/global$

在global目录下的pg_filenode.map文件里存储了shared表的oid和relfilenode的映射关系,12835目录下存储了OID为12835的数据库里nail表的oid和relfilenode的映射关系。

pg_filenode.map文件的结构为:

typedef struct RelMapping{ Oid mapoid; /* OID of a catalog */ Oid mapfilenode; /* its filenode number */} RelMapping;

typedef struct RelMapFile{ int32 magic; /* always RELMAPPER_FILEMAGIC */ int32 num_mappings; /* number of valid RelMapping entries */ RelMapping mappings[MAX_MAPPINGS]; pg_crc32c crc; /* CRC of all above */ int32 pad; /* to make the struct size be 512 exactly */} RelMapFile;

结语

这个博客主要阐述了在PostgreSQL中表的oid和relfilenode映射的两种不同表现形式,你只要记住使用pg_relation_filenode()永远会得到正确的结果,从pg_class系统表中查询则可能会得到错误的结果。

了解更多PostgreSQL技术干货、热点文集、行业动态、新闻资讯、精彩活动,请访问中国PostgreSQL社区网站:www.postgresqlchina.com

文章来源:脚本之家

来源地址:https://www.jb51.net/article/204873.htm

尊敬的看官您对解析PostgreSQL中Oid和Relfilenode的映射问题有什么看法呢?互联网品牌制作专家愿与您共同探讨!版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请加微信号oem365 举报,一经查实,本站将立刻删除。

上一篇: 通俗易懂的SEO优化技巧,SEO菜鸟都能看懂   返 回   下一篇:PostgreSQLregexp_matches替换like模糊查询的操作

相关资讯

小程序应用场景 | 小程序解决方案 | 小程序案例 | 小程序应功能 | 软文发布资源 | 网站设计

酒店预约解决方案
酒店预约小程序走红网络,也是传统转型的重要变化
详情
投票解决方案
强大功能,傻瓜式管理,有效防止作弊刷票
详情
新零售解决方案
小程序是现在新零售的新方式,深度结合线上线下
详情
预约服务解决方案
预约到店小程序通过用户在线预约到店等
详情
企业官网解决方案
企业展示小程序主要展示企业信息、产品案例等
详情
教育培训解决方案
主要展示教育机构的课程、可在线预约与购买课程
详情
推广解决方案
可以让企业通过推广模式全面展示自己的产品
详情
到店解决方案
到店服务解决方案,主要是面向实体餐饮门店
详情

我们的服务是否能满足您的需求?

如果不能,请联系我们或给我们留言,我们收到后会第一时间联系您!感谢您对我们的关注!

粤公网安备 44200002005005号