操作系统能知道自己是在虚拟机中运行的吗?
moboyou 2025-04-08 13:08 14 浏览
“这是最后的机会,之后你将无法回头。服下蓝药丸,故事结束,你会在床上醒来,继续信任你愿意相信的一切。服下红药丸,你将留在仙境,我会带你走进兔子洞,告诉你真相有多深……记住,我所提供的,只有真相,仅此而已……”
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
若在其中发现 VirtualBox、 VMware、 AmazonEC2、 QEMU 等关键词,就可以知道自己是运行在对应的虚拟机中。
/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
...
“矩阵”不想让你醒来。
作者丨胡译胡说
来源丨公众号:计算机奇闻逸事(ID:gh_2d7137908da3)
dbaplus社群欢迎广大技术人员投稿,投稿邮箱:editor@dbaplus.cn
- 上一篇:各类数据库驱动包
- 下一篇: Oracle V$SESSION 详解 —— 实时监控会话的利器
相关推荐
- 一种直扩MSK信号的二维联合捕获方法
-
袁美娟,蒋芸茹,施镇峰,孙红磊,鲍昱蒙,蔡雨琦(南京理工大学电子工程与光电技术学院,江苏南京210094)摘要:针对直扩MSK信号的特殊性以及高动态环境下载波多普勒频偏对伪码捕获的影响,提出了一...
- 基于动态分块阈值与双重VAD检测的时频域自适应去噪算法
-
基于动态分块阈值与双重VAD检测的时频域自适应去噪算法(MATLAB)动态分块阈值:采用SURE准则优化块尺寸与阈值双重VAD检测:粗精两级语音活动检测提升噪声估计精度时频域自适应:结合IMCRA噪声...
- JECE审稿意见太狠如何回复?
-
期刊关键参数ISSN2213-1388|IF=5.2|Q1区版面费2200美元|年发文1200+结构化应对框架回复信三要素:1.致谢+总结改进(例:"感谢指出模型验证不足,已补充三组对比实...
- 三维基因组: SELFISH 差异分析
-
引言本系列主要讲解3D-Genome(Hi-C)系列的分析,主要涉及三维基因组分析中的数据处理,重复性评估,Compartment/TAD/Loop检测,差异分析等,欢迎关注!SELFISHS...
- 电力EI会议,高录用技巧公开!
-
【推荐会议】IEEE电力与能源协会年会(PESGM)会议号:IEEEConference#PE-2026截稿时间:2026年1月15日举办时间与地点:2026年7月26日-30日·美国丹...
- 浅谈船舶交流电网在线绝缘监测装置研究
-
摘要:针对船舶供电系统电缆的绝缘状态问题,设计了一款电缆绝缘在线监测装置。装置采用低频交流注入法,在IT系统的中心点注入低频的交流信号,通过取样电路和A/D量化检测注入信号在电路中的响应,采用FIR滤...
- 使用Simulink学习STM32-(1)点亮一颗LED实验
-
本次实验系统环境Matlab版本:2021b系统环境:Win10专业版硬件平台:YF-STM32-ALPHA1R4模型与原理图simulink模型如图5.1所示,实验现象为PB8以0.5S周期反...
- 利用Proteus仿真STM32实现DHT11温湿度检测
-
1.前言Proteus是英国著名的EDA工具(仿真软件),从原理图布图、代码调试到单片机与外围电路协同仿真,一键切换到PCB设计,真正实现了从概念到产品的完整设计。是世界上唯一将电路仿真软件、PC...
- 使用ADSP-CM408F ADC控制器的电机控制反馈采样时序
-
简介本应用笔记介绍ADSP-CM408F模数转换器控制器(ADCC)模块的主要特性,重点讨论该产品在高性能电机控制应用的电流反馈系统中的相关性与可用性。本应用笔记的目的是为了强调模数转换器(DAC)模...
- 基于DSP的主动降噪系统设计与实现
-
摘要:针对发动机等工作时产生的周期噪声,进行主动降噪系统设计与实现。主要工作为降噪程序的设计和基于DSP的硬件实现。其中降噪程序采用自适应算法中的反馈滤波-X-最小均方算法,对此算法进行了简要讲解...
- 怎样消除薄膜收放卷上的静电
-
》收放卷常见静电危害!收放卷应用贯穿所有行业,无论是塑料薄膜、纸张、还是纺织品。而在快速收放卷的过程中,物料与辊之间会产生大量的摩擦、剥离、挤压,使物体表面积聚不同电性的静电荷,且随速度增加和时长增加...
- 电力EI会议,这些刊慎投!
-
推荐优质会议:ICPEET2025(电力工程与智能技术国际会议)会议号:IEEE-CPS#0123截稿时间:2025年4月30日召开时间/地点:2025年8月15-17日·成都论文集上...
- 电工布线现场工程图,简直就是手工艺术品展览
-
今天我们就来分享一波电工布线图,简直是一道道手工艺术品展览!电工布线是被很多人忽略的一个项目,其实这也是个技术活,因地制宜地设计布线方案、而且要同时注重美观和实用,同时要求具有一定的可扩展性。更多电工...
- 基于FPGA的伪随机序列发生器设计
-
基于FPGA的伪随机序列发生器设计1基本概念与应用1)LFSR:线性反馈移位寄存器(linearfeedbackshiftregister,LFSR)是指给定前一状态的输出,将该输出的线性...
- 五种算法(DBO、LO、SWO、COA、LSO、KOA、GRO)路径规划MATLAB
-
五种算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
- 一周热门
- 最近发表
- 标签列表
-
- curseforge官网网址 (16)
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle 数据导出导入 (16)
- oracle两个表 (20)
- oracle 数据库 使用 (12)
- 启动oracle的监听服务 (13)
- oracle 数据库 字符集 (20)
- powerdesigner oracle (13)
- oracle修改端口 (15)
- 左连接 oracle (15)
- oracle 标准版 (13)
- oracle 转义字符 (14)
- asp 连接 oracle (12)
- oracle安装补丁 (19)
- matlab三维图 (12)
- matlab归一化 (16)
- matlab求解方程 (13)
- matlab坐标轴刻度设置 (12)
- matlab脚本 (14)
- matlab多项式拟合 (13)
- matlab阶跃函数 (14)