PostgreSQL中的表空间允许数据库管理员在文件系统中定义可以存储表示数据库对象的文件的位置。创建后,可以在创建数据库对象时
按名称引用表空间。
推荐:postgresql教程
通过使用表空间,管理员可以控制PostgreSQL安装的磁盘布局。这至少在两个方面很有用。首先,如果初始化集群的分区或卷空间不足
并且无法扩展,则可以在不同的分区上创建表空间并使用,直到可以重新配置系统。其次,表空间允许管理员使用数据库对象的使用模式
的知识来优化性能。例如,非常频繁使用的索引可以放置在非常快速,高度可用的磁盘上,如昂贵的固态设备。同时,存储很少使用或不
具有性能关键的存档数据的表可以存储在较便宜,较慢的磁盘系统上。
即使位于PostgreSQL主数据目录之外,表空间也是数据库集群的组成部分,不能被视为数据文件的自治集合。它们依赖于主数据目录中
包含的元数据,因此无法附加到其他数据库集群或单独备份。同样,如果丢失表空间(文件删除,磁盘故障等),数据库群集可能会变得
不可读或无法启动。将表空间放在像RAM磁盘这样的临时文件系统上会降低整个集群的可靠性。
更多技术请关注Python视频教程。