常见问题

最近更新时间:2019-03-14 17:33:36

为什么没有插入数据,但已用存储空间会增加?

由于 PostgreSQL 的 MVCC 机制:

  1. 被 DELETE 的行并不会直接物理删除。
  2. Update 的行是通过插入新行实现的,过期数据也不会直接物理删除。因此,即使没有插入数据也会存在存储数据量增加的情况。

当前云数据库已默认开启 autovacuum 配置参数,内核会自动回收过期数据,因此已用存储空间会在系统回收过期数据后自动释放出来。用户也可以手动执行 VACUUM 命令来回收过期数据(执行该命令后存储空间统计并不会立即下降,而是会把这些过期数据回收并标记为可重复利用)。如果想完全清理数据,可考虑使用带参数的 VACUUM FULL 命令(该命令会锁表,强烈建议只在维护期间使用)。
VACUUM 命令使用请参见 PostgreSQL 官方文档

为什么 CPU 利用率会超过100%?

PostgreSQL 默认使用闲时超用的策略,即允许您的业务抢占一部分额外的空闲的CPU资源。因此,当您的实例超过默认给您分配的 CPU 核数时,您的 CPU 利用率监控视图会显示超过100%,这个是正常的。
若您的 CPU 负载长期高于60%,则建议您尽快升级数据库。

为什么磁盘占用空间大于实际数据量?

更新导致 xlog 日志剧增,系统来不及归档和删除,占用了磁盘空间。或者查询操作含有大数据量的排序、连接等操作,处理过程中产生临时表并溢出到磁盘,短时间内造成大量空间占用。

如何开启或使用插件?

腾讯云 PostgreSQL 已支持大部分常用插件,可直接使用。而部分插件开启需要超级管理员权限,可到腾讯云控制台开启。或联系腾讯工作人员说明实例 ID 和插件名称开启。

PostgreSQL 重启需要注意什么?

  • 由于数据库本身对于业务的重要性,我们建议您谨慎重启,重启前尽量提前断开服务器与数据库连接,并停写数据。
  • 一般运行重启操作后需要十几秒到几分钟时间,重启期间实例将无法正常提供服务。
  • 重启数据库有几率失败,这是正常现象,如果重启时间超过10分钟建议 提交工单 咨询。
  • 重启实例不会改变实例的物理特性,因此实例的公网 IP、内网 IP、存储的任何数据都不会改变。
  • 重启后,业务需要重连数据库,请确保您的业务有重连机制。