[发明专利]一种容器逃逸检测与阻断方法、装置、设备及存储介质有效
申请号: | 202210576478.3 | 申请日: | 2022-05-25 |
公开(公告)号: | CN114676424B | 公开(公告)日: | 2022-09-06 |
发明(设计)人: | 王嘉雄;周涛涛 | 申请(专利权)人: | 杭州默安科技有限公司 |
主分类号: | G06F21/55 | 分类号: | G06F21/55;G06F21/56;G06F9/445;G06F9/48;G06F9/455 |
代理公司: | 杭州裕阳联合专利代理有限公司 33289 | 代理人: | 张解翠 |
地址: | 311100 浙江省杭州市余*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 容器 逃逸 检测 阻断 方法 装置 设备 存储 介质 | ||
本申请公开了一种容器逃逸检测与阻断方法、装置、设备及存储介质,涉及安全环境检测技术领域,包括以下步骤:在系统中载入动态可加载内核模块,并令动态可加载内核模块挂钩fork函数和execve函数;获取宿主机进程的关键信息并将其存入全局表;当fork函数或execve函数被容器进程调用时,获取容器进程的关键信息并存入全局表;在全局表中查找宿主机进程的关键信息并与容器进程的关键信息进行比对以确定容器进程是否发生逃逸,若是则阻断该容器进程。本方法通过对进程的执行流程进行监管,可以在逃逸进程执行恶意动作之前,就杀死该进程,实现事中阻断,最大化保护操作系统。
技术领域
本申请涉及安全环境检测技术领域,尤其涉及一种容器逃逸检测与阻断方法、装置、设备及存储介质。
背景技术
容器技术是一种虚拟化技术,它支持在操作系统级别轻松共享CPU、内存、存储空间和网络资源,并提供一种逻辑打包机制,而以这种机制打包的应用可以脱离其实际运行环境,这使得容器技术的应用越来越广泛,它所面临的安全问题也显得尤为重要,容器逃逸就是其安全问题的典型代表。
现有的容器逃逸检测方法主要有两种:一种是需要人工干预且无法做入侵检测的主动检测方法;另一种是需要挂钩多个内核调用并预先生成调用列表的被动检测方法。这两种方法各有优点,但无论哪一种方法都无法在逃逸进程执行恶意动作之前杀死该进程。
发明内容
本申请提供的一种容器逃逸检测与阻断方法,旨在解决现有技术无法及时杀死执行恶意动作的逃逸进程的问题。
为实现上述目的,本申请采用以下技术方案:
本申请的一种容器逃逸检测与阻断方法,包括以下步骤:
在系统中载入动态可加载内核模块,并令所述动态可加载内核模块挂钩用于创建子进程的fork函数和用于将进程转变成二进制程序的execve函数;
获取宿主机进程的关键信息并将其存入全局表,所述关键信息包含其进程标识符、其父进程的进程标识符、其命名空间的字符串值以及其fs_struct结构体中的值;
当所述fork函数或所述execve函数被容器进程调用时,获取所述容器进程的关键信息并存入所述全局表;
在所述全局表中查找所述宿主机进程的关键信息并与所述容器进程的关键信息进行比对以确定所述容器进程是否发生逃逸,若是则阻断所述容器进程。
作为优选,所述方法还包括当所述容器进程的进程标识符与所述全局表中的某一进程标识符相同时,用所述容器进程的关键信息覆盖所述全局表中该进程标识符对应的原有数据。
作为优选,所述在所述全局表中查找所述宿主机进程的关键信息之前还包括当所述execve函数每次被容器进程调用时,根据所述容器进程关键信息中的父进程的进程标识符在所述全局表中获取其父进程的关键信息。
作为优选,所述在所述全局表中查找所述宿主机进程的关键信息并与所述容器进程的关键信息进行比对以确定所述容器进程是否发生逃逸,包括:
查找所述全局表中所述宿主机进程的关键信息,并将所述容器进程的关键信息与其父进程的关键信息和所述宿主机进程的关键信息分别进行比对,当所述容器进程命名空间的字符串值与其父进程命名空间的字符串值不相等且其命名空间的字符串值等于所述宿主机进程命名空间的字符串值时,判定所述容器进程发生逃逸。
作为优选,所述在所述全局表中查找所述宿主机进程的关键信息并与所述容器进程的关键信息进行比对以确定所述容器进程是否发生逃逸,还包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州默安科技有限公司,未经杭州默安科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210576478.3/2.html,转载请声明来源钻瓜专利网。