今天拿到了一个vmware的虚拟机硬盘镜像,是其他公司的演示产品。

启动之后是带着ubuntu字样的grub。进入系统之后也不是shell,而是一个定制的命令行。所以如果想了解细节的话,只能单独挂硬盘了。

首先现在同事的vmware虚拟机里用CentOS的光盘挂载了一下,简单的看了看,用起来不太方便,遂准备把整个虚拟机镜像拿到T7来处理。

文件名:wobeidalemasaike.ova 共15GB。

一:ova 就是 tar格式的。先解压

/home/tong/Temp [tong@T7] [:]
> tar xvf wobeidalemasaike.ova /home/tong/Temp [tong@T7] [:]
> ll
total
-rw-r--r-- tong tong 15G Apr : wobeidalemasaike-disk1.vmdk
-rw-r--r-- tong tong 135 Apr : wobeidalemasaike.mf
-rw-r--r-- tong tong 15G Apr : wobeidalemasaike.ova
-rw-r--r-- tong tong 10K Apr : wobeidalemasaike.ovf

二:转换成qcow2格式。这个过程我用了4个小时,并且硬盘IO始终100%,电脑几乎动不了,而无法进行其他工作。。。

/home/tong/Temp [tong@T7] [:]
> qemu-img convert -f vmdk -O qcow2 wobeidalemasaike-disk1.vmdk wobeidalemasaike-disk1.qcow2 /home/tong/Temp [tong@T7] [:]
> ll |grep disk1
-rw-r--r-- tong tong 19G Apr : wobeidalemasaike-disk1.qcow2
-rw-r--r-- tong tong 15G Apr : wobeidalemasaike-disk1.vmdk

另外,可以对比一下文件格式的大小。

三:挂载。这个时候,就要吐草一下步骤二的,转格式真的很愚蠢,因为无论是使用qemu-nbd挂载还是直接启动,都可以直接使用vmdk格式,而不需要一定使用qcow2。

  简直是愚蠢透了,浪费了4,5个小时的时间。

  启动是这样的:

/home/tong/Temp [tong@T7] [:]
> qemu-system-x86_64 -hda wobeidalemasaike-disk1.vmdk

  挂载可以参考这个:

  http://www.cnblogs.com/hugetong/p/5903105.html

四:挂好之后,预料之中,分区是加密的:

/home/tong [tong@T7] [:]
> blkid
/dev/nbd0p1: UUID="7e126a21-4f25-4c78-a39d-ad891d3809e1" TYPE="ext4" PARTLABEL="boot" PARTUUID="40670754-aee2-4f4a-a85c-48d4667f65f8"
/dev/nbd0p2: UUID="115a6d13-b04e-4e56-9a52-05408487431f" TYPE="swap" PARTLABEL="swap" PARTUUID="b8fbd911-1b24-4be4-bdc9-3ffc884c6d0c"
/dev/nbd0p3: UUID="7b98be95-b401-44d2-9889-1c266ab9d0c3" TYPE="crypto_LUKS" PARTLABEL="root" PARTUUID="cb8c0f4f-fd20-475b-993a-0b82f144caf2"
/dev/nbd0p4: UUID="f9edf6ec-0cda-4b88-ab0c-d87627f24d9d" TYPE="crypto_LUKS" PARTLABEL="recovery" PARTUUID="24151f98-f6f0-4ee1-8c25-6f045835b3de"
/dev/nbd0p5: UUID="d75fd96e-7ee9-44ba-94d6-b342dbafe72d" TYPE="ext4" PARTLABEL="data" PARTUUID="ae85b8cd-2816-4e03-87b1-83ef159ceeda"

  TODO: 加密分区。

五: 分区在加密,也会被initrd解出来,所以initrd应该怎么处理呢?

六: 内核呢?

七:解压内核:(14441 = 14432 + 8 )就是1f8b08的地址偏移。

[root@jay-rhel boot]# od -t x1 -A d vmlinuz-2.6.-.el6_jay.x86_64 | grep "1f 8b 08"
8d 3d ff e0 1f 8b c4 9c
[root@jay-rhel boot]# dd if=vmlinuz-2.6.-.el6_jay.x86_64 bs= skip= | zcat > vmlinux-jay gzip: stdin: decompression OK, trailing garbage ignored
[root@jay-rhel boot]# file vmlinux-jay
vmlinux-jay: ELF -bit LSB executable, x86-, version (SYSV), statically linked, stripped

参考:http://smilejay.com/2013/06/extract-vmlinuz-and-initrd/

八:解密了!@2017-04-19

  我费劲心机的研究,也没有把它解出来。测试部轻轻松的一个single就搞定了。。。。

8.1 把boot分区挂载起来,把grub里面的password去掉。

8.2 添加kernel选项:

rw single init=/bin/bash

8.3 给root一个密码。

8.4 重启。

8.5 用root登录。整个加密分区就都拿到了。

九,进来了才知道,不过只是干了这么一件事而已。。。。。

# cat /etc/passwd
super:x:::Super User:/home/super:/opt/radar-console/bin/clish-shell
admin:x:::Admin User:/home/admin:/opt/radar-console/bin/clish-shell

十,加个什么破密,防君子啊。。。。

最新文章

  1. IE7,6与Fireofx的CSS兼容性处理方法集结
  2. Android 滑动菜单框架--SwipeMenuListView框架完全解析
  3. LabVIEW之生产者/消费者模式--队列操作 彭会锋
  4. 微信公众号开发之被逼学web服务端1-----使用SecureCRT连接Linux服务器
  5. Javascript实现计数器,定时警告和停止
  6. mouseleave 与 mouseout 的不同
  7. openstack 实例迁移
  8. TextBox控件
  9. Mac下go语言goclipse插件安装部署
  10. NOIP2012模拟试题 121105【奶牛排队(tahort)
  11. 使用javascript解一道关于会议日程安排的面试题
  12. C#设计模式之二十一访问者模式(Visitor Pattern)【行为型】
  13. DevOps让研发人员越来越失望?比如工作量与报酬
  14. Zepto.js_开始
  15. axios请求
  16. hadoop hdfs 数据迁移到其他集群
  17. linux 下 mac 地址如何查询
  18. 如何禁止某个linux用户访问某些文件夹及执行某些命令
  19. 黄聪:超实用的PHPExcel[导入][导出]实现方法总结
  20. android中碰撞屏幕边界反弹问题

热门文章

  1. ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
  2. Godot游戏引擎 3.0 Beta2 于12月21日发布
  3. kafka性能测试1.0.0
  4. openCV函数
  5. 关于Unity中的Mesh Collider碰撞器
  6. [原]OpenGL基础教程(一)多边形绘制
  7. [IR] Concept Search and PLSA
  8. SpringBoot------Servlet3.0的注解自定义原生Servlet
  9. 8 -- 深入使用Spring -- 5...2 使用@Cacheable执行缓存
  10. sklearn参数优化方法