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

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.lryc.cn/news/483738.html

相关文章:

  • Leetcode 75 Sort colors
  • 如何进行数据库连接池的参数优化?
  • 有了miniconda,再也不用担心python、nodejs、go的版本问题了
  • openresty入门教程:init_by_lua_block
  • sol机器人pump机器人如何实现盈利的?什么是Pump 扫链机器人?
  • Spring-boot 后端java配置接口返回jsp页面
  • LabVIEW车辆侧翻预警系统
  • 亲测有效:Maven3.8.1使用Tomcat8插件启动项目
  • Find My电子体温计|苹果Find My技术与体温计结合,智能防丢,全球定位
  • jmeter常用配置元件介绍总结之后置处理器
  • html5多媒体标签
  • 51c自动驾驶~合集10
  • JAVA学习日记(十五) 数据结构
  • 室内定位论文精华-无人机与机器人在地下与室内环境中的自主导航与定位新技术
  • Java 中如何自定义一个类加载器,加载自己指定的类?
  • LeetCode【0037】解数独
  • 计算机视觉 ---常见图像文件格式及其特点
  • Cent OS-7的Apache服务配置
  • mysql每日一题(上升的温度,date数据的计算)
  • 前端人之网络通信概述
  • Python从0到100(七十二):Python OpenCV-OpenCV实现手势音量控制(文末送书)
  • 【云原生开发】K8S多集群管理系统成果展示
  • spring boot项目打成war包部署
  • 网络学习第四篇
  • 【资料】网络安全风险评估报告,风险管理报告,网络安全风险管理计划,网络安全网络安全能力验证报(Word原件)
  • Django基础用法+Demo演示
  • 【webrtc】 RTP 中的 MID(Media Stream Identifier)
  • React 中 为什么多个 JSX 标签需要被一个父元素包裹?
  • 记录日志中logback和log4j2不能共存的问题
  • 第5章: 图像变换与仿射操作