Tetragon – 盯向内核的眼睛

tetragon – 盯向内核的眼睛一. 概述

1.1

什么是eBPF?

eBPF(扩展的Berkeley数据包过滤器)源自BPF,是一种通用的执行引擎,为Linux内核提供了可编程的通用能力。自Linux内核3.18版本后,BPF扩展了Berkeley数据包过滤器等多项功能,这使得eBPF与之前的cBPF区分开来。如图1所示,eBPF的架构因新功能的加入而更新,eBPF在更多场景中展现出更大的潜力,同时由于其执行速度更快,cBPF在新内核中已基本被淘汰[1]。

Tetragon – 盯向内核的眼睛图1 eBPF架构图

1.2

eBPF的应用场景有哪些?

eBPF能够深入覆盖从用户态到内核级的能力,这意味着其应用领域具有颠覆性。官方大致总结了如图2所示的四类应用场景[2]:

Tetragon – 盯向内核的眼睛图2 eBPF应用场景

1.2.1

安全防护

通过系统调用和网络过滤,eBPF能够阻止恶意的调用动作或丢弃非预期的流量,这正是检测或防护类产品的核心操作,eBPF直接作用于原对象,无需额外备份,处理效率远超传统手段。因此,绿盟科技创新研究院在云原生API网关的网络优化技术实施中也采用了这一技术。

1.2.2

调用追踪

通过在内核或用户应用程序的几乎任何位置附加eBPF程序,可以实现从用户程序到内核级别的上下文追踪。不过,笔者认为构建一个通用的追踪模型还有很长的路要走。例如,Containiq的联合创始人兼首席技术官Matt Lenhard在一篇关于分布式追踪的文章中提到,尽管在整个Kubernetes集群中的调用追踪关联性很好,但在不改动请求头的情况下,lambda函数调用的相关性追踪却非常困难[3]。

1.2.3

网络编排

eBPF最初的设计目标是优化网络过滤器的内部BPF指令集处理,这显示了其在网络技术中的重要地位。通过在网络驱动特定位置进行Hook,优化最佳路径,并利用其先天的无需包复制即可进行数据包过滤的优势,这对网络编排具有显著的优势。在此领域,Isovalent公司开发的开源项目Cilium将eBPF技术融入Kubernetes,成为了云原生的革命性技术。

1.2.4

数据监控

官方介绍,基于eBPF的数据监控不依赖于系统应用的数据,而是直接指向内核,这意味着数据审计更加透明和实时。

二. 为何讨论Tetragon?

第一,Tetragon是一款基于eBPF技术的运行时安全实施和可观察性开源工具。多年来,它一直是Isovalent Cilium Enterprise的一部分,直到2022年5月决定开源。了解这一开源背景后,许多朋友可能会像笔者一样对其更加关注。

第二,Tetragon仅实现了可视化和动作执行,留下了更多思考的空间。这就像“削了皮的土豆”,从种植到收获和清洗削皮都有完整的指导,接下来是炒土豆丝还是土豆片,甚至是雕花,全都交给大家去探索。

三. Tetragon的部署

理论上,Tetragon可以部署在任何支持BTF的内核系统中,包括虚拟机、容器或K8s集群等方式。如图3所示,在K8s环境中,Tetragon以DaemonSet的方式部署在集群的每个节点上。通过配置文件可以看到,Tetragon目前以特权容器方式运行。笔者认为,特权运行会增加整个环境的不安全风险,是否有其他更小权限的方案(如SYS_BPF_ADMIN等)值得去实践和思考。除非特别说明,本文稍后涉及的部署位置讨论均默认在K8s集群内进行。

Tetragon – 盯向内核的眼睛图3 K8s环境中Tetragon的部署方式

四. Tetragon的功能特性

Trae国内版 Trae国内版

国内首款AI原生IDE,专为中国开发者打造

Trae国内版 815 查看详情 Trae国内版

相对于传统技术,Tetragon基于eBPF提供了丰富的过滤器,包括文件、套接字、二进制名称、命名空间/函数等,直接在内核中应用这些过滤器,无需繁重的上下文切换和唤醒资源。值得注意的是,开源工具本身并未内置跟踪哪些函数和应用哪些过滤器,仅在目录中提供了部分场景示例,这为后期的功能扩展和自定义跟踪提供了较大的灵活性。此外,Tetragon的两个主打功能(可视化和实时执行)也值得进一步发掘和延伸。

4.1

可视化

基于eBPF技术,Tetragon可以轻松观测内核子系统,包括文件系统访问、网络数据访问以及系统调用层的事件。如图4所示[4],Tetragon能够对集群进行感知,针对集群内的活动上下文事件将体现集群特性,如命名空间和pod。看到这一点,笔者不禁想到此技术在集群安全取证产品上会有无限的应用空间。

Tetragon – 盯向内核的眼睛图4 K8s环境中Tetragon的监控数据

对于可视化来说,如图5所示,Tetragon通过网络过滤和运行时过滤的结合,可以轻松展示特定单体对象(如文件、函数等)的上下文关联。Isovalent官方博客中描述其是“智能的”,不可否认,对于单个数据链的可视化深度来说,上下文信息是相当丰富的,但离智能似乎还有一段路要走。笔者认为,如何将系统中无数的调用链进行关联,以形成“血管网络图谱”,如何对调用链路进行分类乃至自动标记异常特征,以达到异常调用链路联想的效果,这是走向“智能”的一条道路。

Tetragon – 盯向内核的眼睛图5 某横向移动的可视化

Tetragon借助eBPF技术可以对网络、运行时、敏感文件以及云原生生态链组件信息进行检测,这充分展示了eBPF的强大之处,但正因为如此,应用eBPF技术到攻击面将是更加可怕的,正如美团信息安全团队所表达的担忧[5],Tetragon也是使用eBPF的相关接口,如果环境中已经有恶意程序对eBPF的结果进行伪装,那么所有的可视化上下文将无法发现问题。借用其列出的取证思路,提前结合系统层和用户态的信息进行比对将是一种最直接的解决方法。笔者还想到的是:在eBPF用户空间程序层利用第三方可信组件(注意这里不使eBPF本身变复杂)提供签名验证(如结合类似Sigstore + In-toto保证供应链组件的调用来源可信+调用内容可信),以此保证加载程序的合法性来避免此类攻击是否是一种较好的解决思路呢?

4.2

实时执行

如图6所示[6],Tetragon支持来自多层级的安全策略机制,如通过用户层、CRD和JSON API等第三方应用层或OPA等系统层注入安全策略,当然也可以在内核层预制规则。当策略被触发时,实时对下一步操作做出响应,如拦截等。这些响应动作直接在内核中对事件做出反应,而不是将事件发送到用户空间代理,这极大地缩短了上下游的响应链。

Tetragon – 盯向内核的眼睛图6 Tetragon策略架构

Tetragon提供基于多层的策略抽象代理,面向用户态的操作者可以轻松定义规则配置,达到从上至下的实时管控效果。需要注意的是,这也面临同样的问题,如果环境已经被恶意利用eBPF技术攻击,那么Tetragon的实时执行结果将可能是被篡改的。

五. 总结

由于笔者对eBPF攻击和防御技术的认识有限,本文仅依托开源组件Tetragon对eBPF技术进行一些浅显的思考,如有不妥之处,观点仅代表笔者本人,同时也欢迎有兴趣的同学后台联系我们一起交流学习,更多深层次的eBPF技术剖析后期将会由此方向的研究同学进行分享。

参考文献

1. 狄卫华.深入浅出eBPF

2. eBPF.What is eBPF

3. Matt Lenhard.Automated Distributed Tracing Using eBPF (Part 1)

4. https://www.php.cn/link/eb72d013ce941d098d78e1ed837a7b92

5. 美团信息安全团队.Linux中基于eBPF的恶意利用与检测机制

6. Isovalent.Tetragon – eBPF-based Security Observability & Runtime Enforcement

内容编辑:创新研究院 张小勇

责任编辑:创新研究院 陈佛忠

本公众号原创文章仅代表作者观点,不代表绿盟科技立场。所有原创内容版权均属绿盟科技研究通讯。未经授权,严禁任何媒体以及微信公众号复制、转载、摘编或以其他方式使用,转载须注明来自绿盟科技研究通讯并附上本文链接。

以上就是Tetragon – 盯向内核的眼睛的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/478176.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 10:17:03
下一篇 2025年11月8日 10:18:10

相关推荐

  • Go开发服务器防火墙弹窗问题的有效解决策略

    在go语言开发中,使用beego等框架进行热重载时,服务器二进制文件会频繁重建,这在macos系统上常导致防火墙反复弹出网络权限请求。本文提供一种简单高效的解决方案:让开发服务器仅监听本地回环地址(127.0.0.1),从而避免防火墙弹窗的干扰,并探讨如何在生产环境中灵活配置网络监听地址。 Go开发…

    2025年12月16日
    000
  • Go time.Parse 函数布局字符串的奥秘与正确用法

    本文深入探讨 go 语言 `time.parse` 函数中布局字符串(layout string)的特殊机制。它并非传统的格式化字符串,而是基于一个固定的参考时间(`2006-01-02 15:04:05.000000000 -0700 mst`)来识别日期时间组件。文章将详细解释布局字符串中数字和…

    2025年12月16日
    000
  • 如何在Golang中修改私有字段值

    答案:通过反射可修改Go结构体私有字段。使用reflect.ValueOf(&u).Elem()获取可寻址对象,再用FieldByName获取字段并调用SetString或SetInt等方法修改值,前提是字段可寻址且类型匹配。 在Golang中,结构体的私有字段(以小写字母开头的字段)默认无…

    2025年12月16日
    000
  • Go语言:通用Map键类型转换与JSON序列化实践

    在go语言开发中,当需要将`map[int]t`类型的键转换为`string`类型以适应json序列化需求时,开发者常面临编写大量重复转换函数的挑战。本文将介绍一种利用go语言反射机制实现的通用方法,能够将任意`map`类型的整数键转换为字符串键,并返回`map[string]interface{}…

    2025年12月16日
    000
  • 深入理解Go语言结构体字段的动态访问

    本文探讨了Go语言中如何通过字段名称动态访问结构体属性。虽然Go提倡直接访问以保证性能和类型安全,但在特定场景下,`reflect`包提供了强大的运行时反射能力来实现这一需求。文章将详细介绍`reflect`包的使用方法、示例代码,并强调其性能开销和潜在的类型安全问题,指导开发者在权衡利弊后合理应用…

    2025年12月16日
    000
  • Golang项目初始化与环境准备示例

    安装Go环境并验证版本,2. 创建项目目录并初始化模块生成go.mod,3. 编写main.go主程序运行测试,4. 添加gin等依赖并生成go.sum,完成基础项目搭建。 开始一个Golang项目前,正确初始化项目和配置开发环境是关键步骤。以下是一个实用的流程示例,帮助你快速搭建可运行的Go项目结…

    2025年12月16日
    000
  • 如何在Golang中使用reflect处理结构体嵌套字段_Golang reflect嵌套字段处理方法汇总

    答案:Go的reflect包可递归处理结构体嵌套字段,获取信息、修改值并支持匿名字段。通过反射遍历字段,判断类型是否为结构体,递归深入;修改时需传指针保证可寻址;匿名字段可用Field.Anonymous识别并提升访问。适用于配置映射、序列化等场景。 在 Golang 中,reflect 包提供了强…

    2025年12月16日
    000
  • 如何在Golang中测试数据库操作_Golang数据库操作测试方法汇总

    使用测试专用数据库、SQLite模拟、Mock库和Docker集成测试可有效提升Go语言数据库操作的测试效率与稳定性,确保数据隔离与测试准确性。 在Go语言开发中,数据库操作是常见需求,而如何有效测试这些操作直接影响代码的稳定性和可维护性。直接在真实数据库上运行测试会带来环境依赖、数据污染和速度慢等…

    2025年12月16日
    000
  • 如何在Golang中使用errors.Is判断错误类型_Golang错误类型判断详解

    使用errors.Is可判断错误是否与目标相等,它能递归检查包装后的底层错误。例如用fmt.Errorf(“%w”, err)包装时,errors.Is仍能识别原始错误,而直接==比较则无法做到。应优先使用errors.Is进行语义化错误判断,特别是在错误被多层包装或需匹配预…

    2025年12月16日
    000
  • 如何在Golang中管理Kubernetes集群资源

    答案:Golang通过client-go库操作Kubernetes,支持kubeconfig或InClusterConfig认证,实现资源增删改查、Watch监听及错误重试,适用于构建Operator和自动化工具。 在Golang中管理Kubernetes集群资源,主要依赖官方提供的 client-…

    2025年12月16日
    000
  • Go语言文本文件行读取实践指南

    本教程详细介绍了在go语言中如何高效地读取文本文件并将其内容按行存储到字符串切片中。核心方法是利用`ioutil.readfile`一次性读取文件内容,然后结合`strings.split`根据换行符进行分割。文章将提供完整的代码示例、详细步骤以及使用该方法时需要注意的内存消耗和错误处理等关键事项。…

    2025年12月16日
    000
  • Golang如何实现内存分配性能测试_Golang内存分配性能测试实践详解

    答案是使用Go的testing包和pprof工具可有效分析内存分配。通过b.ReportAllocs()获取每操作分配字节数和次数,对比不同实现(如字符串拼接),结合memprofile与pprof定位高分配热点,避免测试误区以确保结果准确。 在Go语言开发中,内存分配是影响程序性能的关键因素之一。…

    2025年12月16日
    000
  • 使用 git2go 获取 Git 文件模式:Blob 和符号链接的处理

    本文详细介绍了如何利用 `git2go` 库获取 git 仓库中文件(blob)的模式,特别是针对符号链接。通过访问 `treeentry` 结构中的 `filemode` 字段,并结合预定义的 `git.filemodelink` 等常量,开发者可以高效地识别文件类型和模式。文章强调了 git 文…

    2025年12月16日
    000
  • Golang如何使用profiling分析性能_Golang profiling性能分析实践详解

    pprof是Go语言性能分析的核心工具,通过runtime/pprof和net/http/pprof支持CPU、内存、goroutine等多维度 profiling;Web服务引入_ “net/http/pprof”即可暴露/debug/pprof接口,命令行程序可使用run…

    2025年12月16日
    000
  • Go语言结构体属性的动态访问:使用reflect包

    go语言通常通过直接字段名访问结构体属性,但若需在运行时根据字符串名称动态获取属性值,标准语法无法实现。本文将深入探讨如何利用go的`reflect`包来解决这一需求,提供示例代码,并分析其性能、类型安全及错误处理等方面的考量,指导开发者在特定场景下合理使用反射机制。 理解Go结构体属性访问的本质 …

    2025年12月16日
    000
  • Golang如何处理微服务调用的重试策略

    重试机制可提升微服务稳定性,通过for循环+time.Sleep实现基础重试,结合错误判断、次数限制与退避策略避免雪崩,Golang中常用标准库组合第三方工具构建可靠重试逻辑。 在微服务架构中,网络波动、服务短暂不可用等问题难以避免,因此合理的重试机制对提升系统稳定性至关重要。Golang 本身没有…

    2025年12月16日
    000
  • 如何在Golang中实现模块替换调试

    使用replace指令可将Go模块依赖指向本地代码,便于调试私有库或修复bug,通过go.mod中replace语法或Go Workspaces实现临时替换,提升多模块协同开发效率。 在Golang项目中,当需要对某个依赖模块进行调试或临时修改时,可以通过模块替换(replace)机制,将远程依赖指…

    2025年12月16日
    000
  • Golang如何实现性能瓶颈分析

    首先使用net/http/pprof采集CPU和内存数据,再通过go tool pprof分析热点函数与内存分配,结合trace工具查看并发执行轨迹,重点优化频繁分配、锁竞争、GC压力和协程泄漏问题。 Go语言提供了强大的工具链来帮助开发者定位和解决性能瓶颈。要有效分析Golang程序的性能问题,关…

    2025年12月16日
    000
  • Golang如何实现容器日志实时分析_Golang容器日志实时分析实践详解

    使用Golang实现容器日志实时分析,首先通过tail库监听日志文件变化并采集JSON格式日志;接着定义结构体解析时间戳、容器ID等字段,并利用sync.Pool优化性能;随后构建管道模式,用Goroutine和channel实现过滤、错误匹配与指标提取;最后通过定时聚合统计结果,输出至Promet…

    2025年12月16日
    000
  • 如何在Golang中实现微服务架构_Golang微服务架构实现方法汇总

    微服务架构通过拆分应用提升可维护性和扩展性,Golang因高并发和简洁语法成为理想选择。1. 服务按业务边界拆分,职责单一,用Go Modules管理依赖,独立Git仓库或monorepo隔离,API契约推荐gRPC或REST+OpenAPI。2. 通信机制:gRPC适用于内部高性能调用,基于Pro…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信