当前位置: 首页 > news >正文

云计算服务的底层,虚拟化技术的实现原理

虚拟化技术:

一、

从cpu说起,

intel和amd等cpu制造商

为了提高其cpu对

虚拟化程序的运算速度,

给cpu硬件里面

增加了指令集

 VMLAUNCH, VMRESUME, VMEXIT, VMXOFF

这些指令集称为硬件辅助虚拟化技术的指令集。

---------------------------------------------------------------------------------------------------


什么是指令集?

是指令的集合。

什么是指令?

是cpu提供给程序的一个个功能。程序编译成机器码,可以调用这些功能。

这些功能包括,加减乘除、与或非、移动、输入输出,和虚拟机的各项操作。

指令集通常包括多种类型的指令,如:
数据移动指令(如 MOV
算术运算指令(如 ADD, SUB, MUL, DIV
逻辑运算指令(如 AND, OR, NOT, XOR
条件分支指令(如 JMP, JE, JNE
输入输出指令(如 IN, OUT
特殊功能指令(如虚拟化支持指令 VMLAUNCH, VMRESUME

 以intel的cpu举例

Intel VT-x (Virtualization Technology for x86)介绍:
Intel VT-x 是 Intel 处理器提供的硬件辅助虚拟化技术。
它通过提供一组新的指令和扩展现有指令集来支持虚拟化。
关键指令:
VMXON: 启用虚拟化模式。
VMXOFF: 关闭虚拟化模式。
VMREAD: 读取 VMCS(Virtual Machine Control Structure)中的字段。
VMWRITE: 写入 VMCS 中的字段。
VMPTRLD: 加载 VMCS。
VMPTRST: 存储 VMCS。
VMRESUME: 恢复虚拟机执行。
VMLAUNCH: 启动虚拟机执行。
VMEXIT: 退出虚拟机执行。
VMRUN: 运行虚拟机直到下一个事件发生。

程序编译成机器码,发送给cpu

cpu接收到机器码后,通过指令解码器将其解码成一系列微操作(micro-operations)

解码后的微操作被发送到cpu的执行单元进行实际执行。

各种计算之后,把结果返回给程序

程序拿着结果又去干别的事情。

比如把虚拟机启动起来。

---------------------------------------------------------------------------------------------------

二、kvm

什么是kvm?

是内核的一个模块

加载这个模块,就可以调用cpu中的虚拟化指令集。

怎么加载?

modprobe  kvm,敲回车,就好了。

linux内核是高度模块化的,跟ansible一样,需要用哪个模块,加载哪个就可以使用。

如何使用kvm模块?

用qemu来使用。

------------------------------------------------------------------------------------------------------

三、qemu

 什么是qemu?

是一个程序

可以虚拟出来硬件,比如cpu,内存,硬盘,网卡

怎么虚拟出来的?

找kvm,让kvm调用cpu的虚拟化指令集。

cpu一顿操作

就整出来了

---------------------------------------------------------------------------------------------------------

四、libvert

用户怎么管理虚拟机

用libvert提供的工具箱

libvert是一个程序

提供了API给用户

用户可以使用命令行工具来调用这些API,来管理虚拟机

比如virsh命令,virt-manager命令


 

相关文章:

云计算服务的底层,虚拟化技术的实现原理

虚拟化技术: 一、 从cpu说起, intel和amd等cpu制造商 为了提高其cpu对 虚拟化程序的运算速度, 给cpu硬件里面 增加了指令集 VMLAUNCH, VMRESUME, VMEXIT, VMXOFF 这些指令集称为硬件辅助虚拟化技术的指令集。 ---------------------…...

大数据Flink(一百一十六):Flink SQL的时间属性

文章目录 Flink SQL的时间属性 一、Flink 三种时间属性简介 二、Flink 三种时间属性的应用场景 三、​​​​​​​SQL 指定时间属性的两种方式 四、​​​​​​​​​​​​​​SQL 处理时间DDL定义 五、​​​​​​​​​​​​​​SQL 事件时间DDL定义 Flink SQL的时…...

Ansible自动化部署kubernetes集群

机器环境介绍 1.1. 机器信息介绍 IP hostname application CPU Memory 192.168.204.129 k8s-master01 etcd,kube-apiserver,kube-controller-manager,kube-scheduler,kubelet,kube-proxy,containerd 2C 4G 192.168.204.130 k8s-w…...

网络通信流程

目录 ♫IP地址 ♫子网掩码 ♫MAC地址 ♫相关设备 ♫ARP寻址 ♫网络通信流程 ♫IP地址 我们已经知道 IP 地址由网络号主机号组成,根据 IP 地址的不同可以有5钟划分网络号和主机号的方案: 其中,各类地址的表示范围是: 分类范围适用…...

数据结构一:绪论

(一)数据结构的基本概念 1.相关名词 【1】数据 1.信息的载体,描述客观事物 2.能被输入到计算机中 3.能被计算机程序识别和处理的符号的集合。 【2】数据元素 1.数据的一个“个体” 2.数据的基本单位 3.有时候也被称为元素、结点、顶点…...

使用OpenFeign在不同微服务之间传递用户信息时失败

文章目录 起因原因解决方法: 起因 从pay-service中实现下单时,会调用到user-service中的扣减余额。 因此这里需要在不同微服务之间传递用户信息。 但是user-service中始终从始至终拿不到user的信息。 原因 在pay-service中,不仅要Enable O…...

js中【Worker】相关知识点详细解读

什么是 JavaScript 中的 Worker? JavaScript 中的 Worker 是一个可以在后台线程中运行代码的 API,这样可以避免主线程(通常是 UI 线程)被阻塞。使用 Worker 时,JavaScript 可以在多线程环境中工作,解决了单…...

使用Apify加载Twitter消息以进行微调的完整指南

# 使用Apify加载Twitter消息以进行微调的完整指南## 引言在自然语言处理领域,微调模型以适应特定任务是提升模型性能的常见方法。本文将介绍如何使用Apify从Twitter导出聊天信息,以便进一步进行微调。## 主要内容### 使用Apify导出推文首先,我…...

【C++算法】滑动窗口

长度最小的子数组 题目链接: 209. 长度最小的子数组 - 力扣(LeetCode)https://leetcode.cn/problems/minimum-size-subarray-sum/description/ 算法原理 代码步骤: 设置left0,right0设置sum0,len0遍历l…...

(c++)猜数字(含根据当前时间生成伪随机数代码)

#include<iostream> #include<ctime>/*用srand((unsigned int)time(NULL));要包含这个头文件&#xff0c;如果没有这两个&#xff0c;rand()函数会一直生成42这个伪随机数。*/using namespace std;int main() {srand((unsigned int)time(NULL));//种子&#xff0c;…...

优化批处理流程:自定义BatchProcessorUtils的设计与应用

优化批处理流程&#xff1a;自定义BatchProcessorUtils的设计与应用 | 原创作者/编辑&#xff1a;凯哥Java | 分类&#xff1a;个人小工具类 在我们开发过程中&#xff0c;处理大量的数据集是一项常见的任务。特别是在数据库操作、文件处理或者…...

Framebuffer应用编程

目录 前言 LCD操作原理 涉及的 API 函数 open函数 ioctl 函数 mmap 函数 Framebuffer程序分析 源码 1.打开设备 2.获取LCD参数 3.映射Framebuffer 4.描点函数 5.随便画几个点 上机实验 前言 本文介绍LCD的操作原理和涉及到的API函数&#xff0c;分析Framebuffer…...

MongoDB根据字段内容长度查询语句

db.getCollection("qlzx_penalties_business_raw").find({$expr: {$lt: [{ $strLenCP: "$punish_name" }, 5]},"punish_name_type" : "机构", "source_data" : /中国/,})解释&#xff1a; 1-"source_data" : /中…...

Android中的单例模式

在Android开发中&#xff0c;单例模式&#xff08;Singleton Pattern&#xff09;是一种常用的设计模式&#xff0c;它确保一个类只有一个实例&#xff0c;并提供一个全局访问点来获取这个实例。单例模式在需要控制资源访问、管理共享资源或配置信息的场景下特别有用。在Androi…...

python做游戏好用吗

Python做游戏是完全可以的&#xff0c;而且也非常简单&#xff0c;有一个专门针对游戏开发的平台&#xff08;模块&#xff09;—pygame&#xff0c;允许开发人员快速设计游戏而又摆脱了低级语言的束缚&#xff0c;下面我简单介绍一下这个模块的安装和使用&#xff1a; 1、首先…...

常用游戏运行库下载

包含以下资源&#xff1a; DirectX Repair.exe DirectX Repair(Enhanced Edition). vcredist C2013 x64.exe 微软常用运行库合集 下载链接...

(1)CLIP

CLIP 概述1. 训练与推理2. 最终效果与局限性3.后续应用3.1 DALL-E3.2 ActionCLIP3.3 CLIP-Event 概述 CLIP&#xff1a;contrastive language-image pretraining 利用文本的监督信号训练一个迁移能力特别强的视觉模型 传统的视觉模型&#xff0c;人工标注图像&#xff0c;那么…...

MongoDB高可用和分片集群知识

一、MongoDB实现高可用 1. MongoDB复制集(Replication Set) 在实际生产中&#xff0c;MongoDB要实现高可用&#xff0c;以免MongoDB单实例挂了&#xff0c;服务不可用。MongoDB实现高可用是以MongoDB复制集的形式实现&#xff0c;和集群部署概念相同&#xff0c;MongoDB复制集…...

【Python日志功能】一.日志基础与基本配置

文章目录 相关链接第一篇&#xff1a;日志基础与基本配置1 日志的概念与用途2 Python logging 模块介绍3 日志级别4 配置日志格式和输出位置4.1 配置日志格式4.2 配置输出位置 5 实验&#xff1a;基本日志配置和输出实验1&#xff1a;基本日志配置实验2&#xff1a;使用配置文件…...

深圳铨顺宏科技展邀您体验前沿人工智能技术

我们诚挚地邀请您参加即将举行的展会&#xff0c;探索RFID技术在资产与人员管理中的广泛应用。这些展会将为您提供一个深入了解前沿技术和创新解决方案的机会。 东莞台湾名品博览会&#xff08;东莞台博会&#xff09;展会时间&#xff1a;9月5日至8日。此次展会展示了来自台湾…...

AI的jieba分词原理与多模式应用解析

AI的jieba分词原理与多模式应用解析...

终极指南:vgpu_unlock如何突破消费级GPU虚拟化限制?未来支持路线全解析

终极指南&#xff1a;vgpu_unlock如何突破消费级GPU虚拟化限制&#xff1f;未来支持路线全解析 【免费下载链接】vgpu_unlock Unlock vGPU functionality for consumer grade GPUs. 项目地址: https://gitcode.com/gh_mirrors/vg/vgpu_unlock vgpu_unlock是一款革命性工…...

如何开发GJSON自定义修饰符:扩展你的JSON处理能力

如何开发GJSON自定义修饰符&#xff1a;扩展你的JSON处理能力 【免费下载链接】gjson Get JSON values quickly - JSON parser for Go 项目地址: https://gitcode.com/gh_mirrors/gj/gjson GJSON是Go语言中一款高效的JSON解析工具&#xff0c;它允许开发者快速从JSON数据…...

Mirage: The Illusion of Visual Understanding

Lab4AI大模型实验室是面向AI开发者、科研党与学习者打造的一站式AI实践平台&#xff0c;深度绑定高性能弹性算力&#xff0c;支持模型复现、训练、推理全流程&#xff0c;以按需计费、低价高效破解高端算力紧缺与成本高昂难题&#xff1b;同步Arxiv前沿论文并提供翻译、导读、分…...

仿真建图实战:如何用Velodyne 16线和IMU数据提升Octomap八叉树地图质量?

高精度仿真建图进阶&#xff1a;Velodyne 16线与IMU数据融合优化Octomap八叉树地图 在机器人自主导航领域&#xff0c;八叉树地图的质量直接影响路径规划的准确性和系统资源消耗。许多开发者虽然能够完成从点云到八叉树的基础转换&#xff0c;却常常忽视传感器配置与参数调优对…...

这个 Plugin 让 OpenClaw 减少Skill 90%Token消耗

别让 Skill 列表烧光你的 Token——用一个 Plugin 让 OpenClaw 瘦身 90% 95 个 Skill&#xff0c;每轮对话就消耗 5000 多个 Token&#xff1f;本文将分享我们如何通过 Elasticsearch 语义搜索和一个 OpenClaw Plugin&#xff0c;将 Skill 列表从“全量注入”变为“按需加载”&…...

利用快马平台快速构建你的Skill-Vetter技能评估原型

利用快马平台快速构建你的Skill-Vetter技能评估原型 最近在做一个技能评估工具的原型验证&#xff0c;发现用传统方式从零开始搭建实在太费时间。后来尝试了InsCode(快马)平台&#xff0c;整个过程变得特别顺畅。这里分享一下如何用这个平台快速构建一个编程技能评估原型。 原…...

解锁iOS种子管理全攻略:iTorrent让iPhone下载更简单

解锁iOS种子管理全攻略&#xff1a;iTorrent让iPhone下载更简单 【免费下载链接】iTorrent Torrent client for iOS 16 项目地址: https://gitcode.com/gh_mirrors/it/iTorrent iTorrent是一款专为iOS 16设备设计的种子客户端&#xff0c;解决了iPhone和iPad用户无法直接…...

GLM-4V-9B多模态入门必看:图片上传→提问→结构化输出三步走

GLM-4V-9B多模态入门必看&#xff1a;图片上传→提问→结构化输出三步走 想让AI看懂图片并回答你的问题吗&#xff1f;GLM-4V-9B多模态大模型就能做到。这个模型不仅能理解图片内容&#xff0c;还能用文字详细回答你的各种问题&#xff0c;就像有个专业的图片分析师随时待命。…...

Redis如何断开主从同步关系_使用REPLICAOF NO ONE命令将从节点提升为独立主节点

执行REPLICAOF NO ONE后从节点未真正独立&#xff0c;因状态切换有延迟、需确认同步完成、配置文件残留、版本兼容性&#xff08;4.x用SLAVEOF&#xff09;、集群模式不支持、提升后写入风险及原主无感知。执行 REPLICAOF NO ONE 后从节点没真正“独立”&#xff1f;命令本身没…...