大家好,我是你们的操作系统课程老师!今天我们将从虚拟化技术讲到现代的云原生和Serverless架构,带你看看计算机系统如何从早期的虚拟机(VM)演进到容器,再到如今的微服务和函数即服务(Function as a Service, FaaS)。这些技术听起来高大上,但其实并不复杂,我会用通俗的方式讲解,并通过流程图帮你梳理清楚。让我们一起探索这场技术革命的舞台是如何搭建的吧!
现代应用程序的架构已经从传统的单体应用转向云原生和微服务。这些概念听起来可能有点陌生,但其实它们建立在我们之前学习的虚拟化和容器技术之上。简单来说,云原生就是让应用程序更小、更轻、更灵活,每个应用就像一个独立的HTTP服务,通过API与数据库或其他服务交互。
以一个教务系统为例:
teach.nju.edu.cn/fetch
)。云厂商(如阿里云)提供API Gateway,自动将请求分发到集群中的不同服务实例,实现负载均衡。这让开发者只需专注于业务逻辑,底层资源管理由云厂商搞定。
我们用流程图展示微服务的运行机制:
这个流程图展示了微服务如何通过API Gateway处理用户请求,实现高效的分布式协作。
微服务已经很轻量了,但我们还能更进一步——Serverless(无服务器)架构。在Serverless中,开发者甚至不需要管理容器,只需提供函数代码,云厂商负责运行和扩展。
传统服务器或容器的模式要求开发者指定资源需求(如内存、CPU),并保持容器运行,即使没有请求也会占用资源。而Serverless将应用拆解为函数,每次请求触发一次函数执行,用多少资源付多少钱,极大提高了资源利用率。
例如,你写一个函数get_enroll_list()
,查询教务系统的课程列表:
我们用流程图展示Serverless的工作机制:
这个流程图展示了Serverless如何动态分配资源,降低开发者的运维负担。
Serverless让云厂商(那些“黑心商人”)更开心,因为他们可以通过**超售(oversubscription)**最大化资源利用率。例如:
Serverless不仅适用于Web服务,还可以处理多媒体任务。比如,我录制的课程视频需要转码,但B站不支持CRF(质量优先)编码,强制转为CBR(固定比特率),导致画质下降。传统方式是用本地的FFmpeg工具转码,但Serverless提供了一种更优雅的解决方案。
假设我直播结束后,视频文件已存储在云端(如阿里云OSS)。我可以调用一个Serverless函数(如ffmpeg_get_metadata
),直接在云端提取视频元数据或转码:
这比本地运行FFmpeg更高效,因为云端有强大的计算资源和散热支持,开发者只需调用API,无需管理服务器。
我们用流程图展示Serverless多媒体处理:
这个流程图展示了Serverless如何简化多媒体处理,开发者只需关注函数逻辑。
Serverless和云原生技术正在改变我们对计算机的理解。传统的PC模式(本地CPU、内存、存储)可能逐渐被云终端取代。未来的操作系统可能只是一个Shell,文件系统、命令行工具都在云端运行。
最近发布的鸿蒙PC被认为是一个“Chromebook式”的系统,整个操作系统围绕浏览器运行,所有应用都是云端服务。这种模式下:
这对网络提出了更高要求,但随着5G和边缘计算的发展,这种模式完全可行。
我们用流程图展示云终端的工作机制:
这个流程图展示了云终端如何将计算任务交给云端,终端只负责显示和交互。
云原生离不开CICD(持续集成与持续部署)。CICD通过自动化工作流简化了开发和部署过程。
假设你开发了一个教务系统服务get_enroll_list.py
:
dev
分支,触发CI(持续集成)运行单元测试。main
分支,触发CD(持续部署),自动将代码部署到云端。以我们实验室的官网为例:
master
分支,触发一个HTTP请求到服务器。我们用流程图展示CICD的工作机制:
这个流程图展示了CICD如何自动化代码测试和部署,提高开发效率。
随着AI的普及,AI推理(如大语言模型)占程序运行时间的比例越来越高。本地运行AI推理需要大量计算资源,而云端的Serverless架构更适合:
例如,爬取教务系统成绩时,传统正则表达式可能因网页结构变化而失效,而大语言模型可以直接解析HTML,生成结构化数据,适应性更强。
我们用流程图展示云端AI推理:
这个流程图展示了AI推理如何通过Serverless高效运行。
今天我们从虚拟化讲到云原生和Serverless,回顾了技术如何从NEMU到虚拟机,再到容器和函数即服务。云原生让应用更小、更灵活,Serverless让开发者无需管理基础设施,CICD和AI推理进一步提升了开发效率。这些技术的背后,是“黑心商人”对资源最大化的追求,也是开发者对便捷性的需求。
未来,计算机可能只分为云和终端,本地高性能PC或许会逐渐消失。希望这节课让你感受到操作系统的魅力,以及它如何支撑了云时代的革命!如果有任何疑问,随时告诉我,我们下节课继续探索!
通过这篇博客,我以老师的身份带你沉浸式地学习了云原生和Serverless的架构,并通过流程图直观展示了每个关键机制。如果你想深入探讨某个部分,比如CICD配置或AI推理优化,告诉我,我会为你进一步讲解!