linux中生成考核用的GPT分区表结构修复案例

简介:

实验一:


目的:用于生成大量模拟破坏GPT分区结构案例,并生成唯一方式修复后的评判方法。

故障:在一个完整的GPT分区磁盘上,丢失了GPT主分区表,或备份分区表。

要求:

    1、利用WINHEX手工方式,修复给定镜像文件的分区结构。

    2、不得对现存主分区表或备份分区表做任何修改。

    3、不得使用WINHEX GPT分区模板进行参考修复。

    4、修复后生成整个镜像文件的MD5 HASH值。

实验样本生成过程:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#!/bin/sh
#删除头部做50个 
for ((i=1;i<=50;i++)); do
  r1=$(($i+200))
  qemu-img create -f raw $i.img  "$r1" M
  losetup  /dev/loop0  $i.img
  parted -s  /dev/loop0  mklabel gpt
  parted -s  /dev/loop0  mkpart -s primary ext3 128s 100%
  dd  if = /dev/loop0  2> /dev/null  |md5sum -b| tr  a-z A-Z 1>>md5.txt
  dd  if = /dev/loop0  of= head "$i" .img bs=512 count=64
  dd  if = /dev/zero  of= /dev/loop0  bs=512 seek=1 count=2048
  dd  if = /dev/loop0  of=f "$i" .img
  tar  -zcvf f "$i" . tar .gz f "$i" .img
  rm  f "$i" .img
  losetup -D
  rm  $i.img
done
#删除尾部做50个
for ((i=51;i<=100;i++)); do
  r1=$(($i+200))
  r2=$(($r1*2048-64))
  qemu-img create -f raw $i.img  "$r1" M
  losetup  /dev/loop0  $i.img
  parted -s  /dev/loop0  mklabel gpt
  parted -s  /dev/loop0  mkpart -s primary ext3 128s 100%
  dd  if = /dev/loop0  2> /dev/null  |md5sum -b| tr  a-z A-Z 1>>md5.txt
  dd  if = /dev/loop0  of= tail "$i" .img skipk=$r2 bs=512
  dd  if = /dev/zero  of= /dev/loop0  bs=512 seek=$r2
  dd  if = /dev/loop0  of=f "$i" .img
  tar  -zcvf f "$i" . tar .gz f "$i" .img
  rm  f "$i" .img
  losetup -D
  rm  $i.img
done


实验二:

目的:用于生成大量模拟破坏GPT分区结构案例,并生成唯一方式修复后的评判方法。

故障:在一个完整的GPT分区磁盘上,之前有一个位置不确定的分区(脚本中起始于100~150M,结束于350~400M),现在被重新分区后变成了一个完整的大分区。

要求:

    1、利用WINHEX手工方式,修复给定镜像文件的分区结构。

    2、仅在现有分区表项上做修改,仅修改其起始位置,结束位置。

    3、不得使用WINHEX GPT分区模板进行参考修复。

    4、修复后生成整个镜像文件的MD5 HASH值。

实验样本生成过程:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#!/bin/bash
for ((i=1;i<=100;i++)); do
  r1=$(($RANDOM % 50+100))
  r2=$(($RANDOM % 50+350))
  qemu-img create -f raw $i.img 500M
  losetup  /dev/loop0  $i.img
  parted -s  /dev/loop0  mklabel gpt
  parted -s  /dev/loop0  mkpart -s primary ext3  "$r1" "$r2"
  mkfs.ntfs -f  /dev/loop0p1
  dd  if = /dev/loop0  2> /dev/null | md5sum -b| tr  a-z A-Z 1>>md5.txt
  dd  if = /dev/loop0  2> /dev/null gzip  >s "$i" .gz
  parted -s  /dev/loop0  rm  1
  parted -s  /dev/loop0  mkpart -s primary ext3 128s 100% 
  dd  if = /dev/loop0  2> /dev/null  | gzip  > "$i" .gz
  losetup -D
  rm  $i.img
done





本文转自 张宇 51CTO博客,原文链接:http://blog.51cto.com/zhangyu/1940719,如需转载请自行联系原作者
目录
相关文章
|
3月前
|
Shell Linux C++
Linux C/C++ 开发(学习笔记二):Shell脚本编程案例
Linux C/C++ 开发(学习笔记二):Shell脚本编程案例
39 0
|
3月前
|
算法 Linux Shell
Linux C/C++ 开发(学习笔记三):Linux C编程案例
Linux C/C++ 开发(学习笔记三):Linux C编程案例
25 0
|
1月前
|
存储 算法 Linux
【Linux系统编程】Linux 文件系统探究:深入理解 struct dirent、DIR 和 struct stat结构
【Linux系统编程】Linux 文件系统探究:深入理解 struct dirent、DIR 和 struct stat结构
45 0
|
2月前
|
Linux
linux tree命令找不到:如何使用Linux Tree命令查看文件系统结构
linux tree命令找不到:如何使用Linux Tree命令查看文件系统结构
37 0
|
3月前
|
网络协议 Linux
【Linux C TCP服务器端-epoll案例】
本文主要介绍了linux下Select的TCP通信流程,实现了客户端和服务器的通信,主要实现了消息的回发,即服务器将消息原封不动的回发给客户端。
29 0
|
3月前
|
网络协议 Linux
【Linux C TCP服务器端-poll案例】
本文主要介绍了linux下Select的TCP通信流程,实现了客户端和服务器的通信,主要实现了消息的回发,即服务器将消息原封不动的回发给客户端。
24 0
|
3月前
|
网络协议 Linux
Linux C TCP服务器端-select案例
本文主要介绍了linux下Select的TCP通信流程,实现了客户端和服务器的通信,主要实现了消息的回发,即服务器将消息原封不动的回发给客户端。
34 0
|
3月前
|
Linux 调度 索引
Linux内核源码的组织结构
Linux内核源码的组织结构
|
3月前
|
Linux API
字符设备驱动(1):Linux字符设备驱动结构
字符设备驱动(1):Linux字符设备驱动结构
39 1
|
3月前
|
Linux Android开发
Linux内核学习(五):linux kernel源码结构以及makefile分析
Linux内核学习(五):linux kernel源码结构以及makefile分析
78 0