模拟神器之QEMU

1. 简介

QEMU(quick emulator)是一款由法布里斯·贝拉(Fabrice Bellard)等人编写的免费的可执行硬件虚拟化的(hardware virtualization)开源托管虚拟机(VMM)。

QEMU 是一个托管的虚拟机镜像,它通过动态的二进制转换,模拟CPU,并且提供一组设备模型,使它能够运行多种未修改的客户机OS,可以通过与KVM一起使用进而接近本地速度运行虚拟机(接近真实电脑的速度)。

QEMU还可以为user-level的进程执行CPU仿真,进而允许了为一种架构编译的程序在另外一种架构上面运行(借由VMM的形式)。

大致介绍完就不得不介绍编写此软件的作者:法布里斯·贝拉

2. 法布里斯·贝拉

  1. 1972年生于法国格勒诺布尔(Grenoble)。在高中就读期间开发了著名的可执行压缩程序LZEXE,这是当年DOS上第一个广泛使用的文件压缩程序。大学就读于巴黎综合理工学院,后在巴黎高等电信学校攻读。

  2. 1996年,他编写了一个简洁但是完整的C编译器和一个Java虚拟机Harissa。Fabrice Bellard发明的TinyCC是GNU/Linux环境下最小的ANSI C语言编译器,是目前号称编译速度最快的C编译器。

  3. 1997年,他提出了最快速的计算圆周率的算法,是贝利-波尔温-普劳夫公式的变体。在计算圆周率的过程中,Fabrice Bellard使用改良后的查德诺夫斯基方程算法来进行圆周率的计算,并使用贝利-波尔温-普劳夫公式来验证计算的结果。为了纪念他对圆周率算法所作出的杰出贡献,Fabrice Bellard所使用的改良型算法被命名为Fabrice Bellard算法,这种算法是目前所有圆周率算法中最快的一种,这个计算N位PI的公式比传统的BBP算法要快47%。

  4. 1998年,贝拉开发出VReng (虚拟现实引擎),这是一个分布式 3D 应用程序,运用多播技术允许通过 Internet 连接在虚拟世界中导航。之后,贝拉注意到有效的OpenGL后端是基于软件的,比实际需求要慢很多。于是他决定基于 VReng 的代码来编写一个更小和更快的3D光栅。

  5. 2000年,他化名Gérard Lantau,创建了FFmpeg项目。FFmpeg单词中的FF指的是Fast Forward,FFmpeg这个2000年发起著名的开源多媒体播放器项目,是MPlayer的姊妹项目。这是一个如此重要的成就。这个多平台、多功能的多媒体编码解码器由Fabrice Bellard发起并管理,现在是由Michael Niedermayer在进行维护。

    这个项目无比强大,我们今天所熟知的视频播放软件,如暴风影音、QQ影音、YouTube、VLC等都使用了FFmpeg的编解码函数库。FFmpeg易扩展、功能强、速度快、占资源少,支持的音视频格式极其广泛,基本上超越了其他所有同类软件,被誉为处理数字视频和音频的“瑞士军刀”。

  6. 2002 年,贝拉发布了 TinyGL,一个 OpenGL 的子集的小型实现。TinyGL 比 Mesa 和Solaris 的OpenGL 快很多,是平台独立的,并且数量级比后二者小很多,总共才 400KB。这也是他在图像处理领域取得的重要成就。

  7. 2003年,开发了Emacs克隆QEmacs

  8. 2004年,他编写了一个只有138KB的启动加载程序TCCBOOT,可以在15秒内从源代码编译并启动Linux系统。

  9. 2005年,用普通PC和VGA卡设计了一个数字电视系统。

  10. 2005年,发布了QEMU,QEMU是一个处理器仿真,可以用软件来模拟不同处理器体系,允许为一个特定处理器编译的程序通过软件仿真在另外一个体系上运行。QEMU近似于已有的Bochs、PearPC,但具有后两者所不具备的高速及跨平台等特性。

    📢 因为QEMU的速度之快、效率之高,它被包含在许多主要的虚拟化技术中,如 VirtualBox、Xen以及Linux Kernel-based 虚拟机(KVM)。

  11. 2009年12月31日,他声称打破了圆周率计算的世界纪录,算出小数点后2.7万亿位,仅用一台普通个人电脑。他使用的个人PC价格不到2000欧元,仅用了116天,就计算出了PI的小数点后第2.7万亿位,超过了由目前排名世界第47位的T2K Open超级计算机于2009年8月17日创造的世界纪录。新纪录比原纪录多出1200亿位,然而,他使用的这台桌面电脑的配置仅为:2.93GHz Core i7 CPU,6GB内存,7.5TB硬盘。

  12. 2011年,他使用JavaScript写了一个PC虚拟机Jslinux。这个虚拟机仿真了一个32位的x86兼容处理器,一个8259可编程中断控制器,一个8254可编程中断计时器,和一个16450 UART。

  13. 2012年,在PC上用软件实现4G LTE基站。

  14. 2019年,他编写了一款新的Javascript引擎QuickJS

贝拉的产出如此之快,质量如此之高,被誉为:

        世界上最多产的程序员(Super-ProductiveProgrammer)

3. 模式

在 qemu 的术语中,运行整个操作系统的方式,称为 full system emulation, 在 Ubuntu/CentoS 由软件包 qemu-system-xxx (比如qemu-system-ppc, qemu-system-aarch64, qemu-system-arm)提供功能。

运行单个程序文件的方式,称为 user mode emulation,由软件包qemu-user或者qemu-user-static提供功能。

3.1 Full System Emulation

虚拟整个操作系统就需要制作内核镜像和根文件系统镜像 [参考这篇文章]

这篇文章里,提供了两种方法来制作根文件系统,一种是基于busybox的,另一种是基于Ubuntu的rootfs的。我采用的是busybox,比较小巧,当然也比较简陋,很多etc配置都没有。

编译好的内核和根文件系统镜像都以压缩包的形式放在这里了 [下载地址]

可以直接拿来验证。对于根文件系统镜像,可以mount挂载后进行修改,但是对于内核镜像,就不能直接修改了,所以最好还是都自己编译一下。

接下来就是启动虚拟机了。

qemu-system-aarch64 -cpu cortex-a57 -smp 4 -m 2048M -M virt -nographic \-kernel build_arm64/arch/arm64/boot/Image \-append "console=ttyAMA0 root=/dev/vda init=/linuxrc rw" \-drive format=raw,file=../busybox_rootfs/busybox-1.31.1-rootfs_ext4.img
  • 第一行的"cpu"指定了处理器的架构,"smp"指定了处理器的个数,"m"指定了内存的大小。
  • 第二行的"kernel"指定编译生成的内核镜像的存放位置,第三行的"append"是内核启动的附加参数。
  • 第四行的"drive"指定之前制作生成的根文件系统的镜像位置

3.2 User Mode Emulation

可以到下面的网址下载

https://github.com/multiarch/qemu-user-static/releases

在这里插入图片描述
那什么场景会使用这个模式呢?

举一个例子:我想在 PC 上运行 Arm的程序,也就是我的CPU是 X86_64 架构的,但是想运行 arm64 架构的程序。那么就可以通过 qemu 来运行。

$ qemu-aarch64-static hello_world
hello world!

hello_world 是编译好的arm可执行程序。

参考文档

  • QEMU的配置和使用
  • 用 qemu-user 在arm linux机器上运行amd64/x86程序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/535955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

X86_64平台运行Arm docker容器

QEMU是什么 QEMU是一个通用的开源的跨平台仿真模拟器,提供user和system两种模式。其模拟的作用可是可以模拟在特定的体系结构下的应用的执行或者构建,比如在x86的体系结构的操作系统上运行ARM的应用。 常见问题的场景 在ARM体系结构的硬件环境中安装D…

Boost Arm 交叉编译

Boost Arm 交叉编译 1. 源码下载 下载地址:https://sourceforge.net/projects/boost/files/boost/ 这里下载 1.74.0 版本 然后解压。 2. 配置 有些库我们是不需要的,所以就不需要编译,可以通过 -show-libraries 查看库列表 vincentmsi-…

为什么Linux会开机黑屏?

有的童鞋由于工作的需要,或者想体验一把无广告的世界,会去尝试使用Linux的发行版,但是经常被Linux拒之门外,甚至连系统到装不上,当然这个现象也在越来越少,只有更多的人去使用它,它才会变的更好…

Golang跨平台UI框架之Wails(一)

Golang作为后端、脚手架、API服务等很常见,但Go不仅仅局限于此,它的目标是星辰大海!本系列文章就开始讲解如何使用Go来构建现代化的桌面级程序。 1. 初识Wails Wails 是一个框架,可使用 Go 和 Web 技术编写桌面应用程序。我们先来欣赏一下美图: Go官方是不支持写带有GUI…

Linux安装NVIDIA显卡驱动的正确姿势

文章目录Linux安装NVIDIA显卡驱动的正确姿势什么是nouveau驱动?检测NVIDIA驱动是否成功安装集显与独显的切换使用标准仓库进行自动化安装使用**PPA**仓库进行自动化安装使用官方的NVIDIA驱动进行手动安装常见问题解决Linux安装NVIDIA显卡驱动的正确姿势 可能想玩Li…

Linux安装CUDA的正确姿势

Linux安装CUDA的正确姿势 CUDA(Compute Unified Device Architecture,统一计算架构)是由NVIDIA所推出的一种集成技术,是该公司对于GPGPU的正式名称。 透过这个技术,用户可利用NVIDIA的GeForce 8以后的GPU和较新的Qua…

Linux升级内核的正确姿势

Linux升级内核的正确姿势 很多童鞋在玩耍linux发行版的时候,都会遇到各种各样的问题,比如:网卡不能使用,亮度不能调节,触摸板不能识别,蓝牙不能使用等等,这些关系都和linux的内核有关系。 什么…

Ubuntu 18.04安装NVIDIA(英伟达) RTX2080Ti显卡

Ubuntu 18.04安装NVIDIA(英伟达) RTX2080Ti显卡 在安装显卡之前请先把ubuntu 18.04系统提前安装好。 需要准备的资料: NVIDIA 驱动 下载驱动 驱动的下载地址,在此下载页面选择合适的显卡,目前最新的显卡驱动版本是…

Ubuntu18.04安装cuDNN和Tensorflow的正确姿势

文章目录Ubuntu18.04安装cuDNN和Tensorflow的正确姿势一、检查NVIDIA驱动是否安装成功二、检查CUDA是否安装成功三、安装cuDNN1. 确定版本2. 下载安装包3. 解压安装4. 安装libcupti四、安装Tensorflow1. 确定版本2. 安装pip3. 安装Tensorflow4. 检查是否正常运行五、错误解决1.…

Vim从理解到应用

1991 年,来自荷兰的一名工程师 Bram Moolenaar 为了在他的Amiga计算机上复制Vi的功能,正式发布 了Vim的第一个版本。在当时无论谁也没想到,这款软件未来能在技术圈爆发出那么大的威力,为千千万万的工程师节省了无数时间&#xff0…

JAVA知识基础(一):数据类型

在我们学习一门编程语言时,最先要了解的就是数据类型,而数据类型又都是抽象的概念,初学者理解起来比较困难,所以我们往往是先应用再理解,但是在本篇文章我决定用先理解再应用的方式尝试一下,试试效果。 1、…

Nginx(一):概念基础

上一篇我们介绍了Nginx的背景,现在我们就要开始正式对Nginx的学习了。本篇我们将对Nginx的基本定义进行介绍,了解Nginx到底是什么。然后我们会介绍Nginx最基本的三个概念:反向代理、负载均衡、动静分离。 1、Nginx是什么 Nginx(“engine x”…

Nginx(二):安装、配置、常用命令

1、Nginx在Linux操作系统中的安装 这里简单介绍一下nginx的安装了 1.1、前期准备 在安装nginx之前我们要提前准摆好它的编译工具以及库文件:zlib、poenssl。 还有有让Nginx支持Rewrite功能的PCRE. 安装的途径有很多可以参考:https://www.runoob.com/lin…

Nginx(三):反向代理

我们本篇将通过两个实例进行对Nginx反向代理的学习。 1、概念基础 反向代理,其实客户端对代理是无感知的,因为客户端不需要任何配置就是可以访问。我们只需要将请求发送到反向代理服务器上,有反向代理服务器去选择目标服务器获取数据后&…

Nginx(四):负载均衡Load balancing

1、概念基础 Load balancing,即负载均衡,是一种计算机技术,用来在多个计算机(计算机集群)、网络连接、CPU、磁盘驱动器或其他资源中分配负载,以达到最优化资源使用、最大化吞吐率、最小化响应时间、同时避…

MIP开发教程(三) 使用MIP-CLI工具调试组件

一 . 在 mip-extensions 仓库中创建新的组件二 . 预览调试组件 三 . 在 MIP 页中引用自己编写的 MIP 组件 四 . 组件提交到 GitHub 仓库时需要进行校验 站长开发的非通用组件,使用 组件上线平台 提交,上线后代码位于 GitHub/mip-extension-platform 仓…

MIP开发教程(二) 使用MIP-CLI工具调试MIP网页

初始化 MIP 配置 新建一个 MIP 网页 编写 MIP 网页代码 校验 MIP 网页 调试 MIP 网页 1. 初始化 MIP 配置 首先在html目录下进行初始化 MIP 配置: $ mip init 此时会创建mip.config文件: 2. 新建一个 MIP 网页 在mip-project/html文件夹下输入如下…

Nginx(五):动静分离

1、概念基础 Nginx动静分离简单来说就是把动态请求和静态请求分开,不能理解成只是单纯的把动态页面静态页面的物理分离。严格意义上说应该是动态请求跟静态请求的分开,可以理解成使用Nginx处理静态页面,Tomcat处理动态页面。动静分离从目前实…

Nginx(六):配置nginx高可用集群

我们知道在我们使用nginx代理多态tomcat服务器时,如果某台tomcat服务器发生宕机,那么nginx的分配机制可以自动将其剔除。但是如果发生了nginx的宕机状况,又该如何解决呢。 1、配置高可用的集群 1.1、什么是高可用 高可用HA(Hig…

MIP开发教程(一) MIP-CLI工具安装与环境部署

依赖安装 安装 MIP-CLI 创建开发文件结构 1. 依赖安装 MIP-CLI 使用 NPM 安装,依赖 node 环境: node 安装-windowsnode 安装-mac MIP-CLI 开发组件需要 git: git 安装-windowsgit 安装-mac 2. 安装 MIP-CLI MIP-CLI:mip 开…