KVM虚拟化技术解析:从企业应用到个人创新的开源力量

1 .KVM:开源虚拟化的核心引擎

KVM(Kernel-based Virtual Machine)作为Linux内核原生集成的开源虚拟化模块,彻底改变了现代数据中心的虚拟化格局。它通过将Linux内核转变为Type-1型虚拟机监控器(Hypervisor),利用硬件虚拟化扩展(Intel VT-x/AMD-V)直接在物理硬件上运行虚拟机,实现了接近原生性能的虚拟化解决方案。与传统闭源方案不同,KVM以完全开源的方式发展,成为OpenStack、oVirt等云平台的基础技术,支撑着全球75%以上的公有云工作负载。

KVM的核心价值在于其深度集成于Linux内核的特性。自2006年被纳入Linux主线内核以来,KVM能够随着内核的每次更新而持续演进,无需独立的开发周期。这种设计使KVM可以直接调用内核的进程调度器、内存管理模块和设备驱动程序,消除了传统Hypervisor与主机操作系统之间的通信开销,从而显著提升性能表现。基准测试表明,在计算密集型任务中,KVM虚拟机的性能可达物理机95%以上,这一数据印证了其在性能关键型场景中的卓越表现。

在技术架构层面,KVM采用了一种独特而高效的设计理念——“KVM不做模拟”。KVM模块本身并不处理设备模拟或用户空间管理,而是作为Linux内核的一个可加载模块(kvm.ko),负责处理处理器虚拟化和内存虚拟化的核心任务。实际运行中,每个KVM虚拟机作为标准的Linux进程(QEMU进程) 存在,虚拟机的虚拟CPU(vCPU)则对应进程中的线程,由Linux调度器统一管理。这种架构使KVM能够继承Linux内核的丰富功能,包括强大的安全控制(SELinux、AppArmor)、高级内存管理以及完善的硬件支持生态。

与市场上其他虚拟化技术相比,KVM在性能、隔离性和操作系统支持方面展现出显著优势:

与OpenVZ对比:KVM提供完全硬件隔离的虚拟机环境,避免了OpenVZ等容器技术因共享内核导致的安全隐患和操作系统限制与Xen对比:KVM无需特殊修改客户操作系统,支持全虚拟化(HVM) 模式下的Windows及其他闭源操作系统与VMware对比:KVM以开源免费模式提供媲美商业产品的性能,尤其适合预算有限但技术能力较强的团队

作为云计算基础设施的基石,KVM已从单纯的技术项目演变为完整的生态系统,涵盖企业级管理平台、轻量级解决方案和多云管理工具,为不同规模的组织提供灵活高效的虚拟化选择。

2 深度解析:KVM的底层技术实现机制

2.1 CPU虚拟化:硬件辅助的效能革命

KVM的性能优势源于对现代处理器虚拟化扩展的深度利用。当系统启动KVM模块时,物理CPU的特权层级被重新规划:Host操作系统运行在非虚拟化环境中的Ring 0级别,而KVM则引入了一个新的特权层级——Guest模式。这种架构下,虚拟机中的操作系统内核指令直接在物理CPU上执行,无需二进制转换或复杂模拟。当虚拟机需要执行I/O操作或特权指令时,处理器自动触发VM-Exit事件,将控制权交还给KVM;处理完成后通过VM-Entry返回虚拟机。这种硬件辅助的上下文切换机制大幅降低了虚拟化开销。

在Linux进程模型中,每个KVM虚拟机对应一个标准的QEMU进程,而每个虚拟CPU(vCPU)则映射为该进程中的一个线程。Linux内核的Completely Fair Scheduler(CFS) 负责这些vCPU线程的调度,确保虚拟机获得公平的CPU时间片分配。管理员可以通过cgroups对虚拟机的CPU资源进行精细化控制,例如为关键业务虚拟机分配更多的CPU份额或绑定特定的物理核心。

2.2 内存管理:智能映射的工程艺术

KVM的内存虚拟化采用基于硬件扩展的影子页表和直接页表映射技术,实现了接近物理机的内存访问性能。传统虚拟化环境中,内存地址需要经历“虚拟机逻辑地址→虚拟机物理地址→主机物理地址”的双重转换,带来了显著性能开销。KVM通过处理器的EPT(Intel) 或NPT(AMD) 技术,将这两级转换交由硬件内存管理单元(MMU)直接处理,消除了软件模拟的性能损耗。

实际测试表明,启用EPT/NPT后,虚拟机内存访问延迟降低达40%,特别对数据库、大数据分析等内存敏感型应用效果显著。另一个关键技术是VPID(Virtual-Processor Identifiers),它通过在TLB(Translation Lookaside Buffer)中为每个vCPU维护独立的缓存条目,避免了每次上下文切换时的TLB刷新操作,进一步提升了内存访问效率。系统管理员可以通过以下命令验证这些关键特性是否启用:

# 检查CPU是否支持EPT/NPT和VPID
grep -E 'ept|vpid' /proc/cpuinfo# 确认内核模块已启用这些特性
cat /sys/module/kvm_intel/parameters/{ept,vpid}

2.3 存储与网络I/O:半虚拟化的性能突破

KVM默认使用QEMU模拟标准存储设备(如IDE、SATA控制器)和网络设备(如Intel E1000网卡),这种纯软件模拟确保了广泛的兼容性,但性能较低。为解决此问题,KVM引入了virtio半虚拟化框架,在虚拟机中安装专用驱动后,可创建高效通信通道:

virtio-blk:提供接近原生性能的块设备访问,减少存储I/O延迟virtio-net:实现虚拟机与宿主机间的高吞吐量网络通信,支持10Gbps+的数据传输vhost-net:将virtio-net的数据平面卸载到内核空间,进一步降低CPU占用率6

在存储优化方面,KVM支持多种缓存策略以适应不同场景:

writethrough:同步写入磁盘,安全性高但性能较低(适合关键事务)writeback:数据先写入主机缓存后异步写入磁盘,性能高但有断电风险(适合非关键负载)none:绕过主机缓存直接访问磁盘(特殊场景使用)unsafe:仅用于快照模式,不保证数据持久化9

表:KVM核心组件及其功能

组件功能描述关键优势
kvm.ko内核模块,处理CPU和内存虚拟化直接集成于Linux内核,零额外开销
QEMU设备模拟和用户空间管理灵活支持多种硬件架构和设备类型
libvirt虚拟化管理API和工具集统一管理接口,支持多种Hypervisor
virtio半虚拟化驱动框架接近原生性能的I/O操作
vhost内核加速模块将数据平面卸载至内核,减少上下文切换

这些底层技术创新共同构成了KVM高性能的基石,使其能够在企业级应用中与商业虚拟化解决方案竞争并占据优势地位。

3 主流KVM解决方案全景分析

3.1 One-KVM:轻量级创新的先锋

针对传统KVM部署复杂、管理工具笨重的问题,One-KVM项目提出了革命性的轻量化解决方案。它通过简洁命令行接口和自动化配置脚本,将KVM的部署门槛从专业运维人员降低至普通开发者。用户只需几条简单命令即可完成虚拟机的全生命周期管理,无需深入理解KVM底层架构。例如,创建一台Ubuntu虚拟机仅需执行:

one-kvm create --name myvm --ram 2048 --vcpu 2 --image ubuntu-lts

One-KVM的技术创新点在于其模块化架构和智能默认配置。项目内置了经过优化的网络配置模板、存储预分配策略和安全基线设置,自动处理了传统KVM部署中繁琐的手动配置环节。同时,其资源调度器深度整合Linux cgroups,确保多虚拟机间的资源隔离与性能稳定。这些特性使One-KVM特别适合以下场景:

开发测试环境:快速创建与销毁临时性开发沙箱教育实验室:为学生提供隔离的操作系统实践环境边缘计算节点:在资源受限的设备上部署轻量级虚拟化服务个人云平台:构建基于KVM的家庭私有云

3.2 企业级KVM生态系统

除轻量级方案外,KVM在企业环境已形成丰富的生态系统:

oVirt:红帽支持的企业级虚拟化管理平台,提供类似VMware vCenter的集中管理体验。其核心架构包含基于浏览器的管理控制台、自动化引擎和分布式存储支持,适合管理大规模虚拟机集群(数百节点以上)。oVirt的独特优势在于与GlusterFS的深度集成,可实现虚拟机存储的无单点故障架构。Proxmox VE:将KVM与LXC容器技术融合的一体化平台,提供基于Web的直观管理界面。其特色功能包括内置的备份/恢复系统、实时迁移支持和ZFS存储集成,特别适合中小型企业作为VMware的替代方案。Proxmox的社区版完全免费,商业支持订阅价格远低于VMware,成本效益显著。云联万维OneCloud:基于KVM构建的多云管理平台,支持统一管理本地KVM集群和公有云资源。在2020年A轮融资5000万元后,产品持续迭代,其融合云3.0版本实现了全容器化架构。典型案例显示,该平台帮助教育科技公司VIPKID降低50% 的云支出。

3.3 解决方案对比与选型指南

表:KVM解决方案对比分析

特性One-KVMoVirtProxmox VEOneCloud
定位轻量级管理工具企业级虚拟化平台一体化虚拟化环境多云管理平台
架构命令行工具+脚本集中式服务器+Web控制台独立节点+集群协作微服务架构
部署复杂度★☆☆ (极低)★★★★ (高)★★☆ (中)★★★☆ (中高)
集群支持是(大规模)是(中等规模)是(跨云)
学习曲线平缓陡峭中等中等
适用场景开发/边缘计算数据中心私有云中小企业虚拟化混合云管理
独特优势极简资源占用企业级高可用性容器+虚拟机统一管理多云成本优化

企业在实际选型中需考虑环境规模、技术能力和集成需求三大因素:

技术能力较强的小团队:One-KVM或Proxmox VE提供平衡的功能与易用性大规模生产环境:oVirt提供企业级高可用和存储特性混合云/多云架构:OneCloud类平台实现统一资源治理和成本优化

这些多样化的解决方案彰显了KVM生态的灵活性和适应性,能够满足从嵌入式设备到超大规模云平台的广泛需求。

4 企业采用KVM的核心价值与技术实践

4.1 成本效益与性能优势的双重收获

企业在虚拟化平台选型时,许可成本往往是首要考量。对比VMware的分级订阅模式(基础功能起价数千美元/每CPU,高级特性需额外付费),KVM作为开源解决方案可节省80%以上的软件授权费用14。某中型企业(200+虚拟机)的实际迁移案例显示,从VMware过渡到KVM后,三年内总体拥有成本(TCO)下降62%,包括:

完全消除CPU许可费用减少专有硬件依赖(如特定存储阵列)利用现有Linux运维技能降低培训支出

在性能表现方面,KVM展现出与商业解决方案匹敌甚至超越的能力。得益于紧耦合的内核架构和硬件辅助虚拟化,KVM在以下场景表现卓越:

计算密集型负载:HPC、科学计算等场景接近裸机性能高并发网络处理:结合DPDK(Data Plane Development Kit)实现千万级PPS数据包处理内存数据库:低延迟内存访问优化提升Redis/Memcached性能6

某电商平台基准测试显示,在相同硬件条件下,KVM运行Nginx的HTTP请求处理能力达到VMware ESXi的1.3倍,同时延迟降低18%。这种性能优势直接转化为业务容量提升和基础设施成本下降1。

4.2 灵活集成与安全强化的技术实践

KVM的开源本质使其易于与现代云原生技术栈集成:

容器化融合:通过Kata Containers项目,KVM可作为容器运行时,为每个Pod提供轻量级虚拟机隔离混合云桥梁:OneCloud平台实现本地KVM集群与AWS/Azure的统一编排,支持跨云迁移和灾备基础设施即代码:libvirt API与Terraform、Ansible等工具集成,实现虚拟机生命周期的声明式管理5

在安全性方面,KVM继承了Linux内核的健壮安全模型,并添加虚拟化特定增强:

sVirt(Secure Virtualization):结合SELinux的强制访问控制,为每个虚拟机创建独立的安全上下文QEMU沙箱:限制设备模拟进程的权限,减小攻击面TPM虚拟化:为虚拟机提供可信平台模块,满足金融等高安全需求场景6

某金融机构采用KVM后,实现了纵深防御策略:

主机层:加固Linux内核,禁用未使用服务Hypervisor层:启用sVirt和定期完整性度量虚拟机层:为每个租户分配独立虚拟TPM网络层:配置虚拟防火墙规则和入侵检测
该架构成功通过PCI-DSS认证,证明KVM满足金融级安全要求。

4.3 行业应用场景深度剖析

不同行业基于KVM构建了各具特色的解决方案:

云服务提供商:One-KVM等轻量平台支撑边缘计算节点,在低成本硬件上实现资源隔离。例如,某CDN服务商在500+个边缘站点部署One-KVM,将虚拟机部署时间从15分钟缩短至90秒,运维人力减少40%。教育科研机构:利用oVirt构建校园私有云,为师生提供按需的计算资源。某高校部署200节点KVM集群,承载教学实验平台和科研计算任务,相比原有VMware方案节省许可费用约$320,000/年。金融行业:KVM的安全增强特性满足核心交易系统需求。某证交所使用KVM运行低延迟交易平台,结合SR-IOV技术实现微秒级网络延迟,同时确保多租户隔离。

这些实践案例证明,KVM已从“低成本替代方案”发展为具备性能、安全和管理优势的企业级平台,成为数字化转型的关键基础设施。

5 个人爱好者的KVM创新应用场景

5.1 家庭实验室与技能提升平台

对技术爱好者而言,KVM是构建家庭虚拟化实验室的理想平台。一台配备16GB内存的旧x86主机即可运行5-6台虚拟机,创建复杂的网络拓扑环境。这种环境特别适合:

认证考试准备:搭建符合RHCE、CCNA等认证要求的练习环境安全研究:创建包含故意漏洞的虚拟机进行渗透测试实验软件开发:在隔离虚拟机中测试跨平台应用(Linux/Windows/macOS)家庭自动化中心:在轻量级虚拟机中运行Home Assistant、Node-RED等智能家居平台29

One-KVM项目极大简化了个人实验环境的搭建过程。其预配置脚本库支持一键部署Kubernetes集群、Hadoop环境或OpenStack开发沙箱。例如,创建3节点Kubernetes集群仅需执行:


one-kvm cluster create --name myk8s --nodes 3 --role master,worker

此命令自动完成虚拟机创建、网络配置和基础软件安装,将原本数小时的手动部署压缩至10分钟内完成。

5.2 前沿技术探索与旧设备再利用

KVM为个人爱好者提供了探索前沿技术的低成本途径:

ARM开发:在基于ARM的树莓派或旧手机上运行KVM(需内核补丁),学习ARM64虚拟化技术。实验证明,Cortex-A72处理器的Raspberry Pi 4可流畅运行轻量级虚拟机3。安全研究:通过嵌套虚拟化(KVM in KVM)分析恶意软件行为,避免物理主机感染内核开发:调试修改KVM内核模块,学习Linux底层工作机制9

在旧设备再利用方面,KVM展现出显著价值。个人爱好者可将淘汰的智能手机或平板改造为低功耗虚拟化集群:

基于高通平台(如MSM8916)刷入支持KVM的Linux内核通过USB集线器连接多台设备构建微型集群部署One-KVM管理节点统一调度资源
这种方案仅消耗5-10W的待机功耗,却可提供相当于入门级服务器的计算能力。

一位技术爱好者分享了其创新项目:利用4台退役智能手机(配备Cortex-A53处理器)构建KVM集群,总成本不足$100,运行包括:

家庭媒体服务器(Jellyfin)网络监控节点(Zabbix代理)个人密码管理器(Vaultwarden)开发测试环境(轻量级虚拟机)
该项目不仅实现旧设备的高效利用,年耗电量也仅为同性能x86服务器的20%3。

6 未来展望:KVM生态的技术演进与创新方向

KVM技术持续演进,多个创新方向值得关注:

轻量化与边缘计算:One-KVM等项目的成功印证了简化部署和资源效率对边缘场景的重要性。未来KVM将更深入集成eBPF技术,实现虚拟机网络和存储的零额外开销处理。RISC-V架构的KVM支持也在快速发展,将推动超低功耗边缘虚拟化设备的普及23。安全增强技术:随着机密计算需求增长,KVM社区正与硬件厂商合作强化内存加密和远程认证能力。AMD SEV(Secure Encrypted Virtualization)和Intel TDX(Trust Domain Extensions)技术已初步集成,确保虚拟机内存即使对宿主机管理员也不可读。这种硬件级隐私保护将扩展KVM在医疗数据处理和隐私计算场景的应用6。多云管理智能化:OneCloud等平台展示了KVM在混合云中的核心价值。下一步将结合机器学习算法实现跨云资源优化,例如:基于负载模式自动迁移虚拟机(KVM↔公有云)预测性容量规划防止资源瓶颈智能成本分析识别浪费支出

KVM生态系统演进趋势图
在这里插入图片描述

社区协作模式的创新同样值得关注。2025年,Linux基金会启动“KVM Collective”计划,联合芯片厂商(Intel/AMD/ARM)、云服务商(AWS/Google Cloud/Azure)和终端用户共同制定KVM发展路线图。这种开放治理模式加速了GPU虚拟化、持久内存支持等功能的交付进程。

这些趋势表明,KVM正从单纯的虚拟化技术演变为涵盖硬件、系统软件和云服务的完整生态系统,为下一代计算基础设施提供开放、安全且高效的基石。
结语:虚拟化民主化的开源之路

KVM及其生态系统的发展历程,展现了一个开源项目如何从技术实验演变为全球数字基础设施的基石。通过One-KVM等创新项目,KVM技术正突破企业数据中心的边界,进入开发者的笔记本电脑、家庭实验室甚至移动设备,实现虚拟化技术的民主化。

对企业而言,KVM不仅意味着成本节约,更重要的是提供了避免供应商锁定的战略选择和深度定制的技术自由。对个人爱好者,KVM则是探索操作系统、云计算和硬件原理的互动实验室,将理论知识与实践验证完美结合。

随着轻量化项目、边缘计算支持和安全增强技术的持续创新,KVM将在云边协同的新计算时代扮演更核心角色。其成功印证了开源协作模式在基础设施软件领域的强大生命力——当技术壁垒被打破,创新将无处不在。

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

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

相关文章

28.Linux :通过源代码编译安装lamp

Linux :通过源代码编译安装lamp 区别特性源代码编译安装yum 安装安装方式从源代码编译构建预编译的二进制包自定义程度高度可定制有限定制性能优化可针对特定硬件优化通用优化依赖管理手动解决依赖关系自动解决依赖安装复杂度复杂,需技术经验简单&#x…

应用控制技术

一、 应用特征识别技术1.传统行为检测技术1.1 五元组检测原理1.2 配置思路1.3 效果展示需求背景21.4 传统行为检测的缺陷无法识别应用层内容:若应用更换端口(如QQ改用随机端口)或伪装协议(如HTTPS加密),传统…

当MySQL的int不够用了

关于int的长度很多时候看到int(8)这样的定义,其实这是工具导出的不专业。int是范围,不是长度。在开发有了共识(知道这个长度不算数,要看范围)以后,上来就是所有的类型都是bigint。int的范围int的取值范围是…

让AI学会“边做边想“:ReAct的实战指南

小智的求职困境有个叫小智的AI助手,它刚从"大语言模型大学"毕业,满怀信心地去应聘一家咨询公司的智能助理职位。面试官问:"北京和上海哪个城市人口更多?"小智立刻回答:"根据我的知识&#xf…

vue优化有哪些手段?

vue本身存在的方法 v-if 和v-show 的合理运用,频繁使用的组件使用v-show,不频繁的使用v-if,来减少dom的渲染路由懒加载 采用()>import(index.vue)当路由被访问的时候才回去加载使用keep-alive缓存页面,减少没必要的重复渲染同时也可以减少服务器的压力使用computed缓存数据,…

【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)

摘要: 裂缝是结构健康的重要隐患,传统人工巡检耗时耗力且易遗漏。本文将带您利用当前最先进的YOLO12实例分割模型,构建一个高效、准确、更高精度的裂缝检测系统。我们将从数据准备、模型训练到结果可视化,手把手实现一个完整的项目…

“让机器人更智慧 让具身体更智能”北京世界机器人大会行业洞察

2025年8月8日,世界机器人大会在北京盛大开幕。本届大会以“让机器人更智慧 让具身体更智能”为主题,由中国电子学会、世界机器人合作组织主办,包括开幕式、闭幕式、论坛等。同期举办世界机器人博览会、世界机器人大赛等活动,打造了…

PHP如何使用JpGraph生成折线图?

JpGraph是一个功能强大的PHP图表库,它通过封装GD库函数,为开发者提供了简单高效的数据可视化解决方案。作为专门用于绘制统计图的面向对象库,JpGraph支持创建折线图、柱状图、饼图等20余种图表类型,并能自动处理坐标轴、刻度、图例…

超级云平台:重构数字生态的“超级连接器“

在数字经济浪潮席卷全球的今天,企业数字化转型已从"选择题"变为"必答题"。然而,传统云服务模式因技术壁垒高、资源分散、协同效率低等问题,让许多企业在数字化转型中陷入"上云易、用云难"的困境。 在此背景下,一种以"全域资源整合+智能…

https如何保证传递参数的安全

HTTPS 并非直接“加密参数”,而是通过一整套加密传输机制,确保客户端与服务器之间所有通信内容(包括 URL 参数、表单数据、Cookie 等)在传输过程中不被窃听、篡改或伪造。其核心安全保障来自以下技术实现: 一、核心加密…

OpenHarmony之打造全场景智联基座的“分布式星链 ”WLAN子系统

1. 技术架构概览 无线局域网(Wireless Local Area Networks,WLAN),是通过无线电、红外光信号或者其他技术发送和接收数据的局域网,用户可以通过WLAN实现结点之间无物理连接的网络通讯。常用于用户携带可移动终端的办公、公众环境中。 WLAN组件子系统为用户提供WLAN基础功…

JMeter(入门篇)

一.简介 JMeter 是 Apache 组织使用 Java 开发的一款测试工具。 1、可以用于对服务器、网络或对象模拟巨大的负载 2、通过创建带有断言的脚本来验证程序是否能返回期望的结果 二.优缺点 优点: 开源、免费 跨平台 支持多协议 小巧 功能强大 缺点&#xff…

Lecture 12: Concurrency 5

回顾:并行用餐哲学家读者/作者问题哲学家进餐问题方案三:最大化并行需要一个更复杂的解决方案来实现最大的并行性 解决方案使用:state[N]:每个哲学家的当前状态(THINKING, HUNGRY, EATING&#…

UniApp 微信小程序之间跳转指南

概述 在UniApp开发中,经常需要实现从当前小程序跳转到其他微信小程序的功能。本文档详细介绍了如何在UniApp中实现微信小程序之间的跳转。 核心API uni.navigateToMiniProgram() 这是UniApp提供的用于跳转到其他微信小程序的核心API。 基本语法 uni.navigateToMiniP…

基于SpringBoot+Vue的养老院管理系统的设计与实现 智能养老系统 养老架构管理 养老小程序

🔥作者:it毕设实战小研🔥 💖简介:java、微信小程序、安卓;定制开发,远程调试 代码讲解,文档指导,ppt制作💖 精彩专栏推荐订阅:在下方专栏&#x1…

TRAE调教指南:用6A工作流项目规则+5S敏捷个人规则打造高效AI开发流程

TRAE调教指南:用6A工作流项目规则5S敏捷个人规则打造高效AI开发流程 引言:从"AI瞎写"到"精准交付"的实战手册一、什么是Rules:让AI"听话"的底层逻辑1. 告别重复指令疲劳2. 实现"千人千面"的个性化适…

【C语言】gets和getchar的区别

在C语言中,gets和getchar是两个用于输入的标准函数,它们在功能和用法上有所不同。 功能上: gets函数主要用于读取一行字符串,直到遇到换行符(回车键)为止。它会自动过滤掉换行符,不会将其读入到…

【数据结构与算法】数据结构初阶:详解二叉树(一)

🔥个人主页:胡萝卜3.0 🎬作者简介:C研发方向学习者 📖个人专栏: 《C语言》《数据结构》 《C干货分享》 ⭐️人生格言:不试试怎么知道自己行不行 正片开始之前,我们来了解一下我们即…

工具测试 - marker (Convert PDF to markdown + JSON quickly with high accuracy)

参考链接如下:: 参考链接:https://github.com/datalab-to/marker?tabreadme-ov-file#llm-services 底层的OCR模型:https://github.com/datalab-to/surya 作用:开源免费🆓,多 GPU 推理、生成效…

STM32HAL 快速入门(七):GPIO 输入之光敏传感器控制蜂鸣器

STM32HAL 快速入门(七):GPIO 输入之光敏传感器控制蜂鸣器 前言 大家好,这里是 Hello_Embed。上一篇我们用 GPIO 输入模式实现了按键控制 LED,本篇将进阶到 “光敏传感器控制蜂鸣器”—— 通过读取光敏传感器的信号&…