当前位置: 首页 > article >正文

PostgreSQL 页损坏如何修复

        PostgreSQL 错误:关系 base/46501/52712 中的块 480 存在无效的页。

        当我们在使用 PostgreSQL 数据库的时候,如果服务器发生 CRASH 或者断电等异常情况的时候,有可能会遇到上面的这个报错信息。那么我们如何去修复这个数据呢,以及这个错误是如何产生的呢?

原因:
磁盘存在损坏或者配置文件参数配置不合理无 fsync 等都可能会引起这个错误信息。那么我们首先需要找到是哪个对象发生损坏了,然后对这个对象进行修复。下面是具体的操作案例。首先我们需要找到是哪个数据库下的对象发生损坏了。通过系统表找出该 oid 对应的数据库名。然后通过 oid 找出对应的表的名称,然后我们可以通过不断的调试可以具体定位到所在的行。

SELECT * FROM pg_database WHERE oid = 46501;
SELECT * FROM pg_class WHERE oid = 52712;
SELECT * FROM table_name limit m,n;

当我们找到是哪个对象的时候,接下来就是对表的一个修复了,通过将表数据刷新到磁盘的过程实现表的一个刷盘,下面是具体的操作步骤。

修复表:
SET zero_damaged_pages = on;
VACUUM FULL table_name;
REINDEX TABLE table_name;

最后我们需要进行:做磁盘坏道检查以及对表进行重新导出导入这些操作。

        说明:有没有发现其实很多数据库的一些错误其实都和数据库的参数是有关系的,数据库的配置文件没有很好的设置会带来很多未知的错误。


http://www.kler.cn/a/392915.html

相关文章:

  • Ribbon
  • 【Redis】Redis 安装与启动
  • 使用RKNN进行YOLOv8人体姿态估计的实战教程:yolov8-pose.onnx转yolov8-pose.rknn+推理全流程
  • 面试突击-JAVA集合类(持续更新...)
  • 欲海航舟:探寻天性驱动下的欲望演变与人生驾驭
  • 如何理解 CNN 中的 RGB 图像和通道?
  • 【Linux】进程通信之管道
  • MySQL算数运算符基础:详解与入门
  • 绿色能源新视界:透明导电膜助力高效光伏
  • Mysql 创建用户并授权
  • Flink 开发工程应加载哪些依赖
  • JavaScript逆向爬虫教程-------基础篇之JavaScript密码学以及CryptoJS各种常用算法的实现
  • 英语中从句和复合句简单介绍
  • 老旧城区供水管网改造优先等级分析
  • stm32学习之路——八种GPIO口工作模式
  • el-form el-table 前端排序+校验+行编辑
  • LLMs之VDB:Elasticsearch的简介、安装和使用方法、案例应用之详细攻略
  • 服务器显卡和桌面pc显卡有什么不同
  • C++builder中的人工智能(17):神经网络中的自我规则非单调(Mish)激活函数
  • sklearn.datasets中make_classification函数
  • 3216. 交换后字典序最小的字符串
  • 单词反转和数组去重,附经典面试题一份
  • C/C++内存管理 | new的机制 | 重载自己的operator new
  • Mysql:使用binlog的一些常用技巧
  • TreeSet是什么
  • 分享一些Kafka集群优化的最佳实践?