操作系统能知道自己是在虚拟机中运行的吗?

“这是最后的机会,之后你将无法回头。服下蓝药丸,故事结束,你会在床上醒来,继续信任你愿意相信的一切。服下红药丸,你将留在仙境,我会带你走进兔子洞,告诉你真相有多深……记住,我所提供的,只有真相,仅此而已……”

This is your last chance. After this there is no turning back. You take the blue pill, the story ends, you wake up in your bed and believe whatever you want to believe. You take the red pill, you stay in Wonderland, and I show you how deep the rabbit hole goes… Remember, all I’m offering is the truth, nothing more…

这是电影《黑客帝国1》中的经典场景之一。墨菲斯(Morpheus)邀请尼奥(Neo)做出一个决定,选择红药丸还是蓝药丸——选择追求真相还是沉迷虚假。

图片

运行在虚拟机中的操作系统与生活(被奴役)在矩阵中的居民面临同样的问题,它们能够感知到自己运行在一个虚幻的环境中吗?或者说,它们能够区分自己是运行在真正的硬件上,还是由 Oracle VirtualBox、VMware 等虚拟机软件创建的“矩阵”中呢?

真巧,Oracle(先知)一词出现在了一篇以黑客帝国开场的文章中

答案是取决于具体情况,但有些线索能够帮助操作系统判断身在何处


例如,这里在苹果的 macOS 上安装了 Oracle VirtualBox,又在新建的虚拟机中安装了 Ubuntu。那 Ubuntu 是否知道自己运行在虚拟机,而不是 mac 中呢?

只需要在 Ubuntu 中执行一条命令就可以知道答案:

$ systemd-detect-virt

oracle

图片

这里输出了“oracle”,证明 Ubuntu 是知道自己运行在 Oracle VirtualBox 中的

该命令的工作原理其实不难:通过一系列预设的探索策略,检查运行在虚拟机中的操作系统的“隐秘角落”,寻找真相。

比如,最简单的策略之一就是扫描如下文件:

  • /sys/class/dmi/id/product_name

  • /sys/class/dmi/id/sys_vendor

  • /sys/class/dmi/id/board_vendor

  • /sys/class/dmi/id/bios_vendor

  • /sys/class/dmi/id/product_version

若在其中发现 VirtualBoxVMwareAmazonEC2QEMU 等关键词,就可以知道自己是运行在对应的虚拟机中。

/sys/class/dmi 是什么

在 Linux 系统中, /sys/class/dmi 是一个虚拟文件系统路径(执行 mount 命令可以看到, sysfs on/sys type sysfs(rw,noexec,nosuid,nodev)),用于访问有关硬件系统的信息,尤其是与 DMI(Desktop Management Interface)相关的数据。

DMI 是一种用于在计算机系统中管理硬件的信息接口,提供系统厂商( sys_vendor)、主板( board_vendor)、BIOS( bios_vendor)等详细信息。

图片

systemd-detect-virt 命令的其他策略还包括探索 /proc/device-tree//sys/hypervisor/ 等路径的内容。当无法从这些特殊的文件中找到有价值的信息时,该命令还会执行 x86 架构 CPU 中的一条特殊指令 CPUID,以此来获取虚拟环境的信息。

此外,该命令还能判断操作系统是否运行在 Docker、LXC 等容器中。

除了 systemd-detect-virt 命令, hostnamectl 命令也能输出有关操作系统运行环境的信息。

图片


图片

尼奥选择了红药丸,随后墨菲斯告知尼奥现在差不多是 2199 年,而不是他以为的 1999 年。这时,墨菲斯提出了一个核心问题,什么是真实

“什么才是真实?你怎么定义‘真实’?如果你说的‘真实’是你能触摸到的、能闻到的、能品尝到的、能看到的,那‘真实’其实就是你大脑解读的电信号。”

What is real? How do you define real? If you’re talking about what you can feel, what you can smell, what you can taste and see, then real is simply electrical signals interpreted by your brain.

正如墨菲斯所说,你认为眼见为实, systemd-detect-virt 也是这样“想”的,它会优先根据从 /sys/class/dmi/id/中看到的内容为判断依据,接收来自此处的信号。

那我是不是能通过篡改这些文件,从而让操作系统误以为运行在另一个虚拟空间中呢?理论上是可以的,只不过看看那些文件的权限。

-r--r--r-- 1 root root 4096 Dec 4 19:11 /sys/class/dmi/id/bios_vendor

-r--r--r-- 1 root root 4096 Dec 4 19:11 /sys/class/dmi/id/board_vendor

-r--r--r-- 1 root root 4096 Dec 4 19:13 /sys/class/dmi/id/chassis_vendor

-r--r--r-- 1 root root 4096 Dec 4 18:45 /sys/class/dmi/id/sys_vendor

...

“矩阵”不想让你醒来。

内容概要:本文系统性地介绍了基于“断线解环”思想的配电网辐射状拓扑约束建模方法,旨在通过Matlab代码实现,复现顶级EI论文中的核心技术。该方法聚焦于保障配电网在运行过程中维持严格的辐射状结构,防止环路形成,从而提高系统的安全性、稳定性和运行效率。文章深入阐述了如何利用混合整数线性规划(MILP)等优化技术处理复杂的拓扑约束条件,并结合标准配电网络进行仿真验证,特别适用于含分布式电源接入的现代复杂配电网。资源包不仅包含完整的Matlab实现代码,还整合了大量前沿科研方向的相关代码与资料,涵盖微电网优化调度、电动汽车协同管理、风光储联合系统、路径规划、深度学习预测等多个热门领域,并提供YALMIP等建模工具的支持,极大地方便了科研人员的学习、复现与二次开发。; 适合人群:具备电力系统、自动化、电气工程或相关工科专业背景,熟练掌握Matlab/Simulink仿真环境,正在从事电力系统优化、智能电网、分布式能源等领域科研或工程应用的人员,尤其适合研究生、博士生及具有一定科研基础的工程师。; 使用场景及目标:① 深入理解并掌握配电网辐射状拓扑约束的数学建模原理与“断线解环”策略的核心思想;② 成功复现高水平EI/SCI期刊论文中的优化模型与算法流程;③ 借助所提供的丰富案例代码,快速开展微电网经济调度、电动汽车优化、新能源预测、多目标优化等方向的科研项目;④ 熟练运用YALMIP等高级建模语言进行电力系统优化问题的建模、求解与分析。; 阅读建议:建议读者优先关注网盘中提供的完整代码、说明文档及示例数据,严格按照资源目录结构循序渐进地学习,重点剖析“断线解环”在消除环路、保证拓扑可行性方面的具体实现逻辑。务必亲自动手运行、调试和修改Matlab代码,以深化对理论模型与编程实现之间联系的理解。同时,可充分利用文中列举的其他研究主题作为灵感来源,拓展自身的科研视野与创新思路。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值