BPF中怎么将SSH会话转换为结构化事件

BPF中怎么将SSH会话转换为结构化事件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

创新互联为企业级客户提高一站式互联网+设计服务,主要包括成都做网站、成都网站制作、成都外贸网站建设重庆APP软件开发、小程序开发、宣传片制作、LOGO设计等,帮助客户快速提升营销能力和企业形象,创新互联各部门都有经验丰富的经验,可以确保每一个作品的质量和创作周期,同时每年都有很多新员工加入,为我们带来大量新的创意。 

1、混淆处理-比如说下列命令:

echo Y3VybCBodHRwOi8vd3d3LmV4YW1wbGUuY29tCg== | base64 –decode | sh

当该命令解码后即为“curl http://www.example.com”,但是SSH会话记录中并不会包含curl命令。

2、Shell脚本-如果用户上传并执行了一个脚本,那么脚本中的命令将无法被会话记录捕捉到,而是直接将脚本文件输出。

3、终端控制-终端支持各种控制命令,最常用的应该是sudo了,禁用终端的echo将允许我们在运行命令的同时不会被SSH会话记录捕捉到。

技术实现

为了解决这个问题,Teleport需要一种方法来在会话持续的过程中将非结构化的SSH会话转换为结构化的事件流。那么这种结构化事件流中应该包含什么呢?

我们对多种方法进行了研究,我们研究的内容从诸如regex模式匹配之类的特殊方法到更复杂的尝试,比如自己解析原始SSH会话。我们还研究了Linux提供的各种API和系统,如Audit、fanotify和BPF。

在选择使用哪种技术来构建时,我们有以下几个关键的标准:

1、减小误报,理想情况下为0。如果你的系统误报率非常高,那么你对警报的关注度可能会因此而减少,这将导致关键问题被忽略。

2、减少由监控所引起的任何性能影响,理想情况下为0,这也能减轻向用户添加额外资源的负担。

这些特定的方法都会存在误报的问题。我们在解析和解释组成SSH会话的字节流时,无法在不引起错误警告的情况下保证数据的准确率。而且由于性能方面的原因,我们排除了Linux Audit。

BPF是什么?

Brendan Gregg,是BPF程序的开发人员,他经常将BPF描述为一种“新型软件”。BPF允许用户空间程序以安全和高效的方式在内核的某些位置设置钩子并发出事件。

安全和性能意味着什么?在这种情况下,“安全”意味着BPF程序不能陷入无限循环中,导致系统崩溃。BPF程序不太可能像内核模块那样使整个操作系统崩溃。BPF程序也有性能,如果不能足够快地使用事件,则会删除事件,而不是拖累整个系统的性能。

Teleport如何使用BPF

Teleport当前使用了三个BPF程序:execsnoop用于捕捉程序执行,opensnoop用来捕捉程序所打开的文件,tcpconnect用来捕捉程序建立的TCP链接。

为了更好地了解这三个BPF程序的功能,大家看看我们在运行“man ls”命令时,execsnoop捕捉到的内容:

# ./execsnoopTracing exec()s. Ctrl-C to end.   PID   PPID ARGS 20139  20135 mawk -W interactive -v o=1 -v opt_name=0 -v name= [...] 20140  20138 cat -v trace_pipe 20171  16743 man ls 20178  20171 preconv -e UTF-8 20181  20171 pager -s 20180  20171 nroff -mandoc -rLL=173n -rLT=173n -Tutf8 20179  20171 tbl 20184  20183 locale charmap 20185  20180 groff -mtty-char -Tutf8 -mandoc -rLL=173n -rLT=173n 20186  20185 troff -mtty-char -mandoc -rLL=173n -rLT=173n -Tutf8 20187  20185 grotty

现在你也许已经了解了BPF程序的功能了,简单的“man”命令,原来后面有这么多其他的程序在执行。

Teleport已将这三个程序的代码嵌入在了自己的库中,当我们启用了增强型会话记录功能之后,它便会执行这些程序。

BPF中怎么将SSH会话转换为结构化事件

就其本身而言,这些程序都是用于调试和跟踪的优秀工具,因为它们可以告诉我们整个系统在执行哪些操作。事实上,这就是我们最开始选择这些工具的目的:我们使用它们来调试Teleport遇到的一些问题,而这些问题可能会导致它在某些场景中耗尽文件描述符。但是,我们使用Teleport的目的各有不同,我们有时需要将程序执行与SSH会话以及标识符关联起来。

为了将程序执行与特定的SSH会话关联起来,我们选择使用cgroup(cgroupv2)。当Teleport启动SSH会话时,它首先会重新启动并将自己放置在cgroup中。这将允许程序对当前进程以及Teleport将要启动的所有进程进行跟踪,并分配唯一标识ID。Teleport所运行的BPF程序还可以发出执行它们的程序的cgroup ID,这允许我们将事件与特定的SSH会话和标识关联起来。

切入主题

了解了关于BPF的相关内容之后,你也可以将增强型会话记录功能引入你自己的程序之中,脚本代码已托管至GitHub【传送门】。

首先启动Ubuntu 19.04或RHEL/CentOS 8 VM并运行上面链接提供的脚本。该脚本只会安装内核头和bcc-tools,这些都是增强型会话记录运行的前提条件。除此之外,它还会安装jq,这样更有助于可视化查看结构化事件流。

安装命令如下:

yum install -y kernel-headers bcc-tools

apt install -y linux-headers-$(uname -r) bpfcc-tools

如需启用Teleport中的增强型会话记录功能,请将下列内容添加至配置文件中:

   ssh_service:       enhanced_recording:          enabled: yes

当你以本文说明的方式在终端中执行“curl http://www.gravitational.com”时,你将会看到下列输出内容:

{  "argv": [    "http://www.gravitational.com"  ],  "cgroup_id": 4294967355,  "code": "T4000I",  "ei": 15,  "event": "session.command",  "login": "root",  "namespace": "default",  "path": "/bin/curl",  "pid": 2315,  "ppid": 2294,  "program": "curl",  "return_code": 0,  "server_id": "e56dc762-0171-4d6e-aa56-24f2ae268c7f",  "sid": "72aabcd8-38c8-11ea-af55-42010a800031",  "time": "2020-01-17T01:27:05.07Z",  "uid": "4b493296-7df2-4ec7-9282-a19c0d98e261",  "user": "test-user"}{  "cgroup_id": 4294967355,  "code": "T4002I",  "dst_addr": "104.24.97.116",  "dst_port": 80,  "ei": 0,  "event": "session.network",  "login": "root",  "namespace": "default",  "pid": 2315,  "program": "curl",  "server_id": "e56dc762-0171-4d6e-aa56-24f2ae268c7f",  "sid": "72aabcd8-38c8-11ea-af55-42010a800031",  "src_addr": "10.128.0.49",  "time": "2020-01-17T01:27:05.145Z",  "uid": "42831223-1da2-4b26-a783-08060fd8d7b1",  "user": "test-user",  "version": 4}

此时,我们可以看到用户将以两种方式运行curl程序。第一种就是程序执行本身,第二种方法就是程序的行为,curl将会发送一个网络请求。

当然了,你也可以尝试运行其他内容,比如说经过混淆处理的命令等等,你同样可以在日志中查看到执行结果。

关于BPF中怎么将SSH会话转换为结构化事件问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


本文名称:BPF中怎么将SSH会话转换为结构化事件
文章URL:http://pwwzsj.com/article/gcodic.html