攻亦是防,防亦是攻——Linux内核视角看权限维持

💡 原文中文,约13700字,阅读约需33分钟。
📝

内容提要

本文讨论了隐藏rootkits的技术,包括在/proc/modules和/sys/module目录中隐藏,以及使用eBPF和binfmt_misc来检测和逃避rootkits。文章还探讨了如何使用eBPF来监控恶意行为,如网络通信和恶意系统调用。

🎯

关键要点

  • 理论上不存在毫无痕迹的Rootkit,攻击者需要对操作系统底层有深入了解。
  • /proc/modules和/sys/module目录可以被用来隐藏rootkit模块。
  • 通过将rootkit模块的module结构体从双向链表上脱链,可以实现模块隐藏。
  • eBPF是一个强大的编程框架,可以在Linux内核中安全地运行沙盒程序。
  • eBPF程序可以监控系统调用、网络事件等,并在特定钩子点运行。
  • eBPF可以用于检测恶意行为,包括网络通信和恶意系统调用。
  • 使用eBPF可以实现对系统调用表的劫持检测,检查系统调用入口指针是否正常。
  • binfmt_misc功能允许识别任意可执行文件格式,可能被用于容器逃逸。
  • 通过自定义解析器和特定类型文件的处理,可以实现容器逃逸。
  • eBPF可以监测恶意行为,检测rootkit的存在和系统调用的异常。

延伸问答

什么是rootkit,它是如何隐藏的?

Rootkit是一种恶意软件,攻击者通过将其模块从内核的双向链表中脱链,隐藏在/proc/modules和/sys/module目录中。

eBPF在检测恶意行为方面有什么作用?

eBPF可以监控系统调用和网络事件,检测恶意行为并检查系统调用表的劫持情况。

如何通过eBPF实现对系统调用的劫持检测?

可以通过检查系统调用入口指针是否在内核符号地址范围内,来检测是否存在劫持情况。

binfmt_misc功能是什么,它如何影响容器逃逸?

binfmt_misc允许识别任意可执行文件格式,攻击者可以利用它执行特定格式的文件,从而实现容器逃逸。

攻击者如何利用eBPF进行网络流量的隐蔽?

攻击者可以通过eBPF在网络驱动的早期接收路径上运行程序,绕过主机的防火墙限制,隐蔽恶意流量。

如何通过修改内核模块实现rootkit的隐藏?

通过将rootkit模块的module结构体从内核的双向链表中脱链,可以实现模块的隐藏。

➡️

继续阅读