Project Icon

gvisor

应用程序内核 为容器提供安全隔离

gVisor是一款应用程序内核,在应用和主机操作系统间创建隔离层。它实现类Linux接口,采用Go语言编写,运行于用户空间。gVisor提供OCI运行时runsc,支持Docker和Kubernetes集成。该项目融合虚拟机的安全性与普通应用的轻量特性,为容器安全提供了创新方案。

gVisor

构建状态 问题重启器 CodeQL gVisor 聊天 代码搜索

gVisor是什么?

gVisor在运行的应用程序和主机操作系统之间提供了一个强大的隔离层。它是一个实现了类Linux接口的应用程序内核。与Linux不同,它是用内存安全的语言(Go)编写的,并在用户空间中运行。

gVisor包含一个名为runsc开放容器倡议(OCI)运行时,使其易于与现有容器工具配合使用。runsc运行时集成了Docker和Kubernetes,使运行沙盒容器变得简单。

gVisor不是什么?

  • gVisor不是系统调用过滤器(例如seccomp-bpf),也不是Linux隔离原语的包装器(例如firejail、AppArmor等)。
  • gVisor也不是日常意义上的虚拟机(例如VirtualBox、QEMU)。

gVisor采用了明显不同的第三种方法,提供了虚拟机的许多安全优势,同时保持了常规用户空间应用程序的低资源占用、快速启动和灵活性。

为什么需要gVisor?

容器不是沙盒。虽然容器彻底改变了我们开发、打包和部署应用程序的方式,但如果没有额外的隔离,使用它们来运行不受信任或潜在恶意的代码并不是一个好主意。虽然使用单一共享内核可以提高效率和性能,但这也意味着单个漏洞就可能导致容器逃逸。

gVisor是容器的应用程序内核。它限制了应用程序可访问的主机内核表面,同时仍然让应用程序访问它所期望的所有功能。与大多数内核不同,gVisor不假设或要求固定的物理资源集;相反,它利用现有的主机内核功能,并作为正常进程运行。换句话说,gVisor通过Linux来实现Linux。

不应将gVisor与用于加固容器以防外部威胁、提供额外完整性检查或限制服务访问范围的技术和工具相混淆。我们应该始终谨慎对待向容器提供的数据。

文档

用户文档和技术架构,包括快速入门指南,可以在gvisor.dev找到。

从源代码安装

gVisor可在x86_64和ARM64上构建。未来可能会支持其他架构。

出于这些说明的目的,bazel和其他构建依赖项被包装在构建容器中。可以直接使用bazel,或者输入make help查看标准目标。

要求

确保安装了以下依赖项:

构建

构建并安装runsc二进制文件:

mkdir -p bin
make copy TARGETS=runsc DESTINATION=bin/
sudo cp ./bin/runsc /usr/local/bin

测试

要运行标准测试套件,可以使用:

make unit-tests
make tests

要运行特定测试,可以指定目标:

make test TARGETS="//runsc:version_test"

使用go get

本项目使用bazel来构建和管理依赖项。为了方便起见,维护了一个与标准go工具兼容的合成go分支。

例如,要直接从这个分支构建和安装runsc

echo "module runsc" > go.mod
GO111MODULE=on go get gvisor.dev/gvisor/runsc@go
CGO_ENABLED=0 GO111MODULE=on sudo -E go build -o /usr/local/bin/runsc gvisor.dev/gvisor/runsc

随后,你可以构建并安装containerd的垫片二进制文件:

GO111MODULE=on sudo -E go build -o /usr/local/bin/containerd-shim-runsc-v1 gvisor.dev/gvisor/shim

请注意,这个分支是以最大努力的方式支持的,不支持直接在这个分支上进行开发。开发应该在master分支上进行,然后反映到go分支中。

社区与治理

有关项目治理信息,请参阅GOVERNANCE.md

gvisor-users邮件列表gvisor-dev邮件列表是提问和讨论的良好起点。

安全政策

请参阅SECURITY.md

贡献

请参阅Contributing.md

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号