Esxi 开启虚拟机显示 "对象类型需要托管的 I/O 错误 模块 Disk 打开电源失败" 解决办法

本贴最后更新于 898 天前,其中的信息可能已经事过景迁

一、虚拟机出现的症状及错误提示

突然停电,虚拟机服务器 Esxi 也突然关机,造成虚拟机打开时提示以下错误

ESXI 无法打开磁盘“XXX.vmdk”或其所依赖的快照磁盘之一,对象类型需要托管的 I/o,模块 Disk 打开电源失败

v247a7d18d93ef9409f56cc9a2377a8653r.jpg

二、某一个快照所依赖的磁盘原因: 未能锁定文件 如果发现有.lck 文件 则比较好解决

如果是提示:“无法打开磁盘" x:**vmdk "或者某一个快照所依赖的磁盘原因: 未能锁定文件”

问题出现的原因:

虚拟磁盘(.vmdk)本身有一个磁盘保护机制,为了防止多台虚拟机同时访问同一个虚拟磁盘(.vmdk)带来的数据丢失和性能削减方面的隐患,每次启动虚拟机的时候虚拟机会使用扩展名为 .lck(磁盘锁)文件对虚拟磁盘(.vmdk)进行锁定保护。当虚拟机关闭时 .lck(磁盘锁)文件自动删除。但是可能由于您非正常关闭虚拟机,这时虚拟机还没来得及删除您系统上的 .lck(磁盘锁)文件,所以当下次您启动虚拟机的时候出现了上述错误。

解决方案:

删除虚拟机配置文件和虚拟磁盘文件夹的所有以 .lck 结尾的文件以及文件夹

还有一种情况

*三、虚拟机目录下并没有 .lck 结尾的文件但虚拟机磁盘依然打不开

但是很多人发现虚拟机目录下并没有 *.lck 结尾的文件但虚拟机磁盘依然打不开,这是怎么回事呢?

解决办法:

答案其实很简单,这就和你的文件系统的删除文件机制有关系(删除文件时先删除磁盘文件对应的目录树,并将对应扇区标记为未分配,等待下个文件写入时再分配到此扇区,并不是直接填零对应文件区域),虽然在表面上看不见(显示系统文件也如此),但是 .lck 却可能存在你的主控文件表(MFT)中,由于虚拟机软件可以直接绕过文件系统操作磁盘底层,所以其实对应的文件早已删除,只是由于磁盘文件系统故障,虚拟机软件检测到 MFT 中的对应文件关联还在,所以你只要对你的虚拟磁盘所在的磁盘分区进行磁盘检查(chkdsk ?:/f),过程中你会发现一些提示"CHKDSK 发现主控文件表(MFT)位图中有标记为已分配的可用空间,正在更正文件系统错误..."有的磁盘则提示"正在校验索引页...,发现个未被索引的文件..."这可能就是那个未被正确删除索引 *.lck ,当磁盘检查完成后,你会发现虚拟机磁盘的错误提示没有了(摘自 wzg19690226wzg 博客)

如果磁盘正被占用可能需要重启系统才能解决

四、如果磁盘检查也无法解决的话

如果遇到断电突然 VMDK 损坏了,如果重启后没有发现.lck 文件把硬盘锁死还是无法启动,只是提示

ESXI 无法打开磁盘“XXX.vmdk”或其所依赖的快照磁盘之一,失败 - 对象类型需要托管的 I/o,模块 Disk 打开电源失败,错误如下所示

v2861241d036bc2793a48670965a1d7eabr.jpg

v2863f5ef5905115a3a348cc36b6803acdr.jpg

可能需要 vmkfstool 修复硬盘

1、先检查文件有否损坏

vmkfstool -x check vm-101-disk-0.vmdk

如果提示 Disk needs repair, 则说明已损坏,需要修复

2、使用命令对文件进行修复

vmkfstool -x repair vm-101-disk-0.vmdk

完成后后提示 Disk was successfully repaired. 则表明修复成功,我修复后就可以成功打开了

但过了几天,老妈的电饭煲短路又导致停电,又出现这个错误,看来按上面办法只能短期修复,无法永久解决。查了相关资料。打开 esxi 的 ssh 端口,在命令行使用 ssh 登录到 esxi ,再执行以下命令转换

3、永久修复,将文件格式进行转换

vmkfstools -i 原文件名.vmdk 目标文件名.vmdk -d thin

会生成 2 个文件,一个 目标文件名.vmdk 一个是 目标文件名-flat.vmdk ,目标文件名.vmdk 比较小,相当于一个配置说明文件 ,目标文件名-flat.vmdk 比较大,是真正的数据文件(小辣椒 高效 Office)。

转换后,则希望将原文件名改名,将目标文件名 改名 原文件名

mv 原文件名.vmdk 原文件名-bak.vmdk

再把 目标文件名改过来

mv 目标文件名.vmdk 原文件名.vmdk

mv 目标文件名-flat.vmdk 原文件名-flat.vmdk

以为到这步应该成功了。但开启虚拟机却提示找不到 原文件名.vmdk,但原文件名.vmdk 用 ls 查看是真实存在的。

v2f344512e198f597b9015a494af2c6c89r.jpg

经过排查,原来是 原文件名.vmdk 里有一个配置 是指向 目标文件名-flat.vmdk ,使用 vi 修改 原文件名.vmdk

vi 原文件名.vmdk 将 指向 修改为 原文件名-flat.vmdk 就可以了

v26e7790cb4b150af28dc5a81149378b60r.jpg

再重启虚拟机就正常了,可以正常进入虚拟机里面,且数据一切正常。

v2e04425cc79a0d38155444234a53f4674r.jpg

如果磁盘为直接上传到存储内进行挂载的,均需要重新转换磁盘格式。

注意:保险起见,建议所有操作前,先把虚拟机进行备份(将虚拟机所有文件复制一份到备份处)

五、将虚拟机硬盘映射到实体机硬盘恢复数据

如果上面的方法均无法处理,但数据又想恢复,可使用以下方法

“打不开磁盘或快照所依赖的磁盘” 也可将虚拟机硬盘映射到实体机(如使用 vmware workstation),把重要数据抄出来。

  1. 打开电脑后,打开虚拟机进入
  2. 接着选择对应的虚拟机系统,在虚拟机的"右上角"找到“编辑虚拟机设置”然后的跳出的菜单栏里找到选择的“硬盘”,接着选择“实用工具”点击下拉菜单的“映射”进入
  3. 然后选择你需要的硬盘即可映射在主机上,打开主机上的“我的电脑” 在实体机找到你的硬盘,把数据抄出来即可
  4. 关闭方法就是在第二步选择”实用工具“选择断开连接即可。

六、使用虚拟机的快照直接还原

而我可能运气更好一些,刚才前几天中过勒索病毒,而为了防止再中招。我刚为此虚拟机做过一次快照。

而且做完快照后,我还没有在虚拟机里添加过新的内容,所以直接使用快照还原,选择要还原的快照点,再单击还原快照。几秒钟不到,虚拟机就恢复了。

v2f2ce8ebd3d137c132315eb95b86a365cr.jpg

  • ESXi
    6 引用 • 2 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 10 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    58 引用 • 25 回帖 • 3 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 667 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 158 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 636 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    298 引用 • 763 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1280 回帖
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    32 引用 • 108 回帖
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 701 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖 • 2 关注
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 550 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    170 引用 • 1529 回帖
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 78 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    29 引用 • 202 回帖 • 28 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 487 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 639 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 706 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 636 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 113 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    89 引用 • 1251 回帖 • 407 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 80 关注
  • Word
    13 引用 • 41 回帖
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 336 关注