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

【服务器数据恢复】通过reed-solomon算法恢复raid6数据的案例

服务器数据恢复环境:
一台网站服务器中有一组由6块磁盘组建的RAID6磁盘阵列,操作系统层面运行MySQL数据库和存放一些其他类型文件。

服务器故障:
该服务器在工作过程中,raid6磁盘阵列中有两块磁盘先后离线,不知道是管理员没有注意或者没有重视这个情况,没有为该raid6磁盘阵列更换离线磁盘。当第三块硬盘离线后,该raid6阵列崩溃,服务器瘫痪,该服务器上跑的业务停摆。如果更换硬盘重新组建阵列,则阵列中的所有数据会全部丢失。
服务器管理员尝试通过市面上比较流行的数据恢复软件对服务器中的数据进行抢救,但是仍有大部分数据丢失无法恢复。管理员求助我们数据恢复中心,要求恢复服务器中所有数据。

服务器数据恢复过程:
1、将故障服务器内所有硬盘编号后取出,经过硬件工程师检测没有发现有硬盘存在明显的硬件故障,都可以正常读取数据。以只读方式将所有磁盘进行扇区级别的全盘镜像,镜像完成后按照编号将所有磁盘还原到原服务器中,后续的数据分析和数据恢复操作都基于镜像文件进行,避免对原始磁盘数据造成二次破坏。
2、服务器磁盘阵列中3块硬盘同时掉线的概率可以忽略不计,要恢复磁盘阵列中的数据首先需要搞清楚这几块硬盘离线的先后顺序,找到最后离线的硬盘。如果最后离线的那块硬盘存在硬件故障则修复硬件故障,然后提取数据。根据该raid阵列的存储结构分析raid结构参数,然后利用这些参数重组raid。
3、本案例服务器中的raid6磁盘阵列使用的是双校验模式:第一个校验方式是普通的oxr(异或运算),第二个校验方式是reed-solmon算法。一般情况下通过第一个校验方式即可恢复数据,但是本案例中radi6阵列中的前两块离线硬盘很早之前就已经掉线,不具备数据恢复的条件,所以无法通过第一种校验方式来恢复数据。第二种校验方式比较复杂,所以管理员通过市面上常用的数据恢复软件恢复出来的数据大量缺失,且数据库无法使用。
4、北亚企安数据恢复中心工程师团队对reed-solomon算法进行过技术攻关,拥有通过reed-solomon算法恢复数据的实际案例经验。经过一番努力,北亚企安数据恢复工程师通过分析获取到该raid6磁盘阵列的关键参数并提取出完整的镜像数据。
5、经过用户方管理员的验证,确认所有数据成功恢复,数据库可以使用,本次服务器数据恢复工作完成。

http://www.lryc.cn/news/305626.html

相关文章:

  • LeetCode 2583.二叉树中的第 K 大层和:层序遍历 + 排序
  • element ui 安装 简易过程 已解决
  • websoket
  • 案例:微服务从Java/SpringBoot迁移到Golan
  • 小波变换模拟
  • cv::Mat图像操作
  • 【机器学习基础】一元线性回归(适合初学者的保姆级文章)
  • 2024年软件测试岗位-面试
  • 【坑】Spring Boot整合MyBatis,一级缓存失效
  • J7 - 对于ResNeXt-50算法的思考
  • R3F(React Three Fiber)基础篇
  • torch\tensorflow在大语言模型LLM中的作用
  • 设计模式-创建型模式-单例模式
  • 备战蓝桥杯—— 双指针技巧巧答链表1
  • 微信小程序返回上一级页面并自动刷新数据
  • Spring⼯⼚创建复杂对象
  • Top-N 泛型工具类
  • Java 后端面试指南
  • 142.环形链表 ||
  • Nacos、Eureka、Zookeeper注册中心的区别
  • CSS重点知识整理1
  • 【Langchain多Agent实践】一个有推销功能的旅游聊天机器人
  • 算法学习(十二)并查集
  • TensorRT及CUDA自学笔记003 NVCC及其命令行参数
  • 数据库管理-第154期 Oracle Vector DB AI-06(20240223)
  • 解决uni-app vue3 nvue中使用pinia页面空白问题
  • 不用加减乘除做加法
  • 旅游组团自驾游拼团系统 微信小程序python+java+node.js+php
  • LeetCode 第41天 | 背包问题 二维数组 一维数组 416.分割等和子集 动态规划
  • Ubuntu20.04和Windows11下配置StarCraft II环境