除了标准的 PostgreSQL 内存中共享缓冲区之外,AlloyDB Omni 磁盘缓存还可在固态硬盘 (SSD) 等快速存储空间上启用存储缓冲区。在数据目录位于较慢存储空间中的 AlloyDB Omni 安装中,磁盘缓存可加快数据检索速度。
与 PostgreSQL 共享缓冲区一样,AlloyDB Omni 磁盘缓存也是非永久性的,这意味着缓存的数据会在重启时丢失。
默认情况下,AlloyDB Omni 磁盘缓存会使用文件系统报告的所有存储空间。您可以使用 omni_disk_cache_file_size 参数定义为缓存数据预留的存储空间量。
启用 AlloyDB Omni 磁盘缓存
如需启用磁盘缓存,请完成以下所有子部分:
预配磁盘并创建文件系统
对于 AlloyDB Omni 磁盘缓存,您可在一个或多个磁盘上创建文件系统,并将其装载。此外,您还可以使用 mdadm 或
lvm 等实用程序,通过多个磁盘共用容量并使用任何文件系统。
以下步骤演示了如何在使用 NVMe SSD 的情况下使用 lvm 和 ext4。
通过所有可用的实体设备创建卷组:
nvme_prefix="STORAGE_PREFIX" nvme_list=$(ls "$nvme_prefix"*) sudo vgcreate VOLUME_GROUP ${nvme_list}
替换以下内容:
STORAGE_PREFIX:使用非易失性存储快速通道 (NVMe) 接口挂接到虚拟机的目标本地磁盘路径的前缀,例如在 Google Cloud上,NVMe 设备路径始终以/dev/nvme0n开头。VOLUME_GROUP:在其中组合 SSD 的卷组的名称,例如omni-disk-cache-volume。
-
如需通过来自上一步的卷组的可用容量创建逻辑卷,请使用以下命令:
sudo lvcreate -n LOGICAL_VOLUME -l 100%FREE VOLUME_GROUP
将
LOGICAL_VOLUME替换为被 LVM 视为分区的逻辑卷的名称,例如omni_disk_cache_device。 - 在逻辑卷上创建
ext4文件系统。如果需要,您可以按照数据安全要求指定其他ext4选项。sudo mkfs.ext4 /dev/VOLUME_GROUP/LOGICAL_VOLUME
如需创建用作宿主机上的装载点的目录并装载文件系统,请使用以下命令:
sudo mkdir /OMNI_DISK_CACHE_DIRECTORY sudo mount /dev/VOLUME_GROUP/LOGICAL_VOLUME /OMNI_DISK_CACHE_DIRECTORY
将
OMNI_DISK_CACHE_DIRECTORY替换为用作装载点的目录的名称或该目录的路径,例如omni_disk_cache_directory。
授予对磁盘缓存目录的权限
在为 AlloyDB Omni 启用磁盘缓存之前,您必须先授予对磁盘缓存目录的完整访问权限。如需授予权限,请运行以下命令:
sudo chown postgres:postgres /OMNI_DISK_CACHE_DIRECTORYsudo chmod -R a+rw /OMNI_DISK_CACHE_DIRECTORY
将 OMNI_DISK_CACHE_DIRECTORY 替换为磁盘缓存目录的路径。
启用磁盘缓存
如需为数据库启用磁盘缓存,请完成以下步骤:
以
SUPERUSER身份连接到数据库。/usr/lib/postgresql/18/bin/psql -h localhost -U postgres设置
omni_disk_cache_enabled和omni_disk_cache_directoryGrand Unified Configuration (GUC) 标志。ALTER SYSTEM SET omni_disk_cache_enabled=on; ALTER SYSTEM SET omni_disk_cache_directory='/OMNI_DISK_CACHE_DIRECTORY';(可选)默认情况下,AlloyDB Omni 会使用文件系统中的所有可用空间。如果需要,您可以通过更新
omni_disk_cache_file_sizeGUC 标志来替换此设置。ALTER SYSTEM SET omni_disk_cache_file_size=SIZE_IN_MB;将
SIZE_IN_MB替换为您希望磁盘缓存使用的磁盘空间量(以 MB 为单位)。重启 AlloyDB Omni。
sudo systemctl restart alloydbomni18
验证磁盘缓存配置
启用 AlloyDB Omni 磁盘缓存后,可使用 iotop 或 iostat 等可用实用程序监控对磁盘进行的读写活动,以验证是否可以访问磁盘缓存。
此外,您还可以检查 AlloyDB Omni 磁盘缓存是否已打开。
如需验证 AlloyDB Omni 的磁盘缓存配置,请使用以下命令。
sudo journalctl -u alloydbomni18 | grep "opened omni disk cache"如果磁盘缓存配置正确,日志中会显示 Successfully opened omni disk cache ... 消息。