UNIX应急响应攻略
上一篇 / 下一篇 2006-02-14 14:34:36 / 天气: Array / 个人分类:其他
/*<<黑客防线>>2003/12上的策略篇是该文的简易缩略版,以下为完整版*/
GrLC*i7b\.o0木铎校园 BBS 社区P2^;T"C,R7eE)`
★UNIX应急响应攻略
'V$])N OrW/v u6I)?0
4Vm0Q[!gXn0*******************************木铎校园 BBS 社区;X[.rToE
*author:ayazero *
8_eTG(u3H:u0*mail:drdos@163.com *
Kw+LWR`0*homepage:overflow.nease.net *
(O/WY @.Im0*team:www.ph4nt0m.net *木铎校园 BBS 社区\'ciFw1w0mJRC
*******************************
ou],eY0
i5C8F d@)S0Last update 2004/05/28木铎校园 BBS 社区 ApDEO4G
木铎校园 BBS 社区]K&@ FV8N/S"l
应急响应有一半是非技术的内容,制定一个合理的响应策略是至关重要的!
"ey Cp!L0记住:现在开始对受害系统的每一步操作都可能改变已存在的证据或是导致敏感信息的丢失!木铎校园 BBS 社区uy)ZAt
f1?&_YBL]VW9W0{{初始响应}}
&QL\w1V r0木铎校园 BBS 社区 _ O yGU t{
目标:在进行司法鉴定复制之前获得系统中的易失数据,初步确定突发事件概况。
#[ ~(^y'Sg x0木铎校园 BBS 社区A n2T ^'F
==============木铎校园 BBS 社区7O6B#~El'cq
创建响应工具包
o!}6e[0?5e,l.eW0==============木铎校园 BBS 社区!C/P5l"J)Z4I_9@+is
我们调查系统,必须以高度可信赖的程序执行命令,再加上备份与修复,创建一个工具包是很有必要的。木铎校园 BBS 社区)C/Z(c)yI:q SC%D
即使在非UNIX/LINUX系统上,创建工具包也应该作为响应的第一步。木铎校园 BBS 社区A s$W ~"Jy
首先,我们需要在对应体系结构的系统上编译响应期间需要的工具,且编译程序需要考虑系统兼容的问题。木铎校园 BBS 社区h8P&~w$p"hm
通常我们需要如下的工具:
SUk6?)V5GhZFU)D0ls dd des file pkginfo
6~@a Au8@^,V0find icat lsof md5sum nc
l/eo}!cNR_gs3{4{;v0netstat pcat perl ps strace木铎校园 BBS 社区6nIM`@9c
strings truss df vi 木铎校园 BBS 社区t#D$[l4s;^
cat kstat ifconfig chkrootkit
kIMiO&b-w0more gzip last w rm木铎校园 BBS 社区 pyO'Os3k"{ t
script bash modinfo lsmod 木铎校园 BBS 社区5Y3sM ~LT+~{
读者可根据自己的需要自行添加,但是一个工具包通常只能用来完成对某一特定平台的工作,
&D)K gp*Hr#lI,J3y-o0把对多个平台编译的工具放进同一个工具包反而会显得紊乱。木铎校园 BBS 社区H8n{9df.B8k#o
在Linux上创建响应工具包时,可以用gcc的–static参数编译源代码,或者用ldd检查动态连接库,
%oz P$Y1]LV0在响应工具包存储介质上建立库文件目录,并拷贝所有工具需要的动态连接库的副本,最后设置环境变量。木铎校园 BBS 社区I N(D2Z$e_zG"s0J
这个过程有点类似于创建一个Linux的优盘启动盘。木铎校园 BBS 社区ve)m1^$q(X
.fU6tk x;e0============木铎校园 BBS 社区n#\G6gP
获取易失数据木铎校园 BBS 社区@;`3Dr E
============
*z#g/lXU#KV0易失的数据包括:当前打开的套接字,进程列表,RAM内容,非链接文件的位置。木铎校园 BBS 社区.L6}x6z+\J
*unix特性: unix允许进程正在执行时将其删除!木铎校园 BBS 社区 f&mxw\
非链接文件是访问该文件的进程中止时被标记为删除的文件。当系统关闭时(正常关机或突然断电非正常关机),
#bmNJw#q Mq0标记为删除的文件都将消失。因此在找到被标记为删除的文件之前不能关机!
&Ew zu'TM^H0
%t5^2}!_c5wGJK0=================
F(uEYNi*D0执行可信赖的shell
/E LD ?5cn1BmM&]0=================
#f`TM6~!P!x0使用我们自己准备的响应工具包,装载该介质的文件系统,
+[,` C7D0_)p!mq8\0mount –t auto /dev/sda1 /mnt/usb 或木铎校园 BBS 社区T:s|`,QD
mount –t iso9660 /dev/cdrom /mnt/cdrom木铎校园 BBS 社区bRwT'`4pt
按下Ctrl+Alt+F1~F6,从控制台以root身份登陆。木铎校园 BBS 社区yk@]V1W?X5p
请一定要区分原环境变量中的命令和当前响应工具包的相同名字的命令集,防止潜在的二进制特洛伊木马攻击。木铎校园 BBS 社区]US m;H
-p'c5sy{(?0==================
+O7HX"bB.?0查看登陆系统的用户木铎校园 BBS 社区OKz d9Ix
==================
/uB3J%`N7z.G~K0[root@ay4z3ro foo]# w木铎校园 BBS 社区iWW(L[_5u*q"h7ID
19:50:48 up 43 min, 2 users, load average: 0.00, 0.00, 0.00木铎校园 BBS 社区6TJ gd0P4xI/z
USER TTY LOGIN@ IDLE JCPU PCPU WHAT
s!|~zb"q U_5H)z0root :0 19:08 ?xdm? 11.10s 0.43s gnome-session
}KR'of1@4E0root pts/0 19:08 1.00s 0.21s 0.01s w
2@kg;k(c0输出标题行显示了当前系统时间,该系统已运行的时间,当前登陆用户数,最近1分钟,5分钟和15分钟内的平均系统负载。
^+sV;f#wtW0USER字段显示当前登陆的用户名。TTY字段显示了会话的控制终端,tty表示从控制台登陆,pts/typ则可以表示通过一个网络连接,木铎校园 BBS 社区2r%XM?Za
因为X是个C/S模式的应用程序,所以我在GNOME下开的shell窗口显示为pts。如果不从本地登陆,输出中还有FROM字段,
:lt*F&CL._:?0表示建立会话的源地址的域名或IP。LOGIN@显示该连接的本地开始时间。IDLE字段显示了自上一个进程运行以来的时间长度。
Few'];[f@0JCPU显示与tty或pts关联的全部进程所使用的时间。PCPU字段显示了WHAT列中当前进程所使用的CPU时间。WHAT列显示用户当前运行的进程。
&pqi%L[bS a([U0木铎校园 BBS 社区wTGx0ms+ej)j
================
.];t:wI9M/`h0查看系统进程列表
Ux.EQ:Rc#P h0================
Dk:Aas%d4f/MO0H0Solaris中使用ps –eaf,而在FreeBSD和Linux中则使用ps –aux.
;i,\rgq q8V0[root@ay4z3ro foo]# ps aux
Z [)xh7m0USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND木铎校园 BBS 社区fAg\I6WT%q
root 1 0.1 0.2 1356 496 ? S 19:07 0:04 init木铎校园 BBS 社区}d$L"X.^5[s1w
root 2 0.0 0.0 0 0 ? SW 19:07 0:00 [keventd]木铎校园 BBS 社区&Ozp F1z0ix.D.B
root 3 0.0 0.0 0 0 ? SWN 19:07 0:00 [ksoftirqd_CPU0]
q:L%V!G |}@_0root 4 0.0 0.0 0 0 ? SW 19:07 0:00 [kswapd]木铎校园 BBS 社区[ fM[8m'Q
root 5 0.0 0.0 0 0 ? SW 19:07 0:00 [bdflush]
&I*uVq L!eL0root 6 0.0 0.0 0 0 ? SW 19:07 0:00 [kupdated]木铎校园 BBS 社区(JCA+Yr)lsR
root 7 0.0 0.0 0 0 ? SW< 19:07 0:00 [mdrecoveryd]木铎校园 BBS 社区 m rD\/w"K0L3_
root 11 0.0 0.0 0 0 ? SW 19:07 0:00 [kjournald]木铎校园 BBS 社区 V$Ra7Y)afL
root 114 0.0 0.5 2108 1304 ? S 19:07 0:00 devfsd /dev
y [a,\3x!P0root 209 0.0 0.0 0 0 ? SW 19:07 0:00 [khubd]木铎校园 BBS 社区 r8U'f+g.`&xdb}/T
root 338 0.0 0.0 0 0 ? SW 19:07 0:00 [kjournald]
z^QF-V0rpc 620 0.0 0.2 1496 520 ? S 19:07 0:00 [portmap]木铎校园 BBS 社区)n5v&nuLgGHgc`&Q:^
root 636 0.0 0.2 1452 624 ? S 19:07 0:00 syslogd -m 0
8FS6BM0j:[H`8zz E.v5M0…………………(以下省略)木铎校园 BBS 社区-z {?]-]*j@
Ps命令输出中的START字段显示了程序开始运行的时间,对于查出攻击时间很有帮助。有时仅通过时间就能识别可疑进程。木铎校园 BBS 社区d+hN.rL
Linux下还可以通过strings –f /proc/[0-9]*/cmdline来查看系统中运行进程的完整命令行参数,但是这个并不完全可信。
7\ A,ot @6nJK Obn0因为攻击者甚至不需要插入内核模块,而只在应用层的编码中加入语句就能欺骗我们。
im5NBIM"O0木铎校园 BBS 社区6~5s:M-P{Da)Qb4h[
===============
3?-M(Fj5c~8x ZhI0检测LKM Rootkit
b){"LFy3f&A-f:w0===============木铎校园 BBS 社区^5T6f;^J*o"\
内核模块后门,还有什么比这个更臭屁的呢?Solaris,Linux和几乎所有的UNIX都支持LKM(Loadable Kernel Modules),木铎校园 BBS 社区P1F K9X[fT
用普通的方法无法检测其存在,这给应急响应带来了极大的挑战性。对于我们来说,解决的办法是找到那些lkm rootkit,木铎校园 BBS 社区sP0x#t \)x"J4SM
并熟悉,解剖他们。有时lkm rootkit虽然被成功装载,但在系统的某些细节上会出现“异常”,甚至可能使系统在运行一段时间后彻底崩溃。木铎校园 BBS 社区zX1PJ%T%n b[6z
还有,lkm虽然活动在ring0核心态,但是攻击者往往会在系统的某处留下痕迹,比如攻击者为了让系统每次关闭或重启后能自动装入他安置的
/D!]aqt:c{ |6A0内核后门,可能会改写/etc/modules.conf或/etc/rc.local.
l^1_{X4j@1s I7t2a,A0kstat/ksec是检测lkm非常方便的工具,前者用于Linux,后者用于*BSD.木铎校园 BBS 社区Q4H O^ B6ep9u
[root@ay4z3ro kstat]# ./kstat
r-Fx,} ]K$c6a%O4NMJB0木铎校园 BBS 社区+x?5j:Fej"B] `R
Usage: ./kstat [-i iff] [-P] [-p pid] [-M] [-m addr] [-s]木铎校园 BBS 社区4?] UEbY0e+v q,G#D
-i iff may be specified as 'all' or as name (e.g. eth0)
e0yTVK Pa)wG\0 displays info about the queried interface
3sf8a#f1~\`5p`a0-P displays all processes木铎校园 BBS 社区9K3p;l+Y,^ @y6pv
-p pid is the process id of the queried task木铎校园 BBS 社区\\{|V t B2yt
-M displays the kernel's LKMs' linked list
"O,m)[cd!xL!W6]0-m addr is the hex address of the queried module木铎校园 BBS 社区;Z N8{@d Y
displays info about the module to be found at addr
4ih4r/Ft,h9`0-s displays info about the system calls' table
Dt s-R~Kthd-c0其中-s参数最有用,它显示了系统调用入口的信息,能检测市面上最流行的knark和adore这两个内核后门,
;^sU-z_4FN/D E]0但理论上他并不能检测出所有的lkm rootkit.木铎校园 BBS 社区:E,u _iRj7B[%N
Kstat/ksec站点:http://www.s0ftpj.org木铎校园 BBS 社区d_N"K}8MW^
其实熟悉内核攻击的人都知道Kstat单纯检查sys_call_table[]的方式如今已经
8}!W.x!mb9vaC!P0被攻击的一方完全超越,e4gle很早也写过这类文章。
](A7d4KQ`*q_0有兴趣可以看看2002焦点峰会jbtzhm的《内核后门实现及其检测》
'al/lOp1[/g0现在linuxforum安全版版主madsys在Phrack61上有篇文章:
X2In/rD|%N7j0Finding hidden kernel modules (the extrem way)--链接: 木铎校园 BBS 社区(Ml}O Ae
http://www.linuxforum.net/forum/gshowflat.php?Cat=&Board=security&Number=434871&page=0&view=collapsed&sb=5&o=all&fpart= 木铎校园 BBS 社区[)?|jeyx Yr
T7V.y%F8@G}}0木铎校园 BBS 社区%m Su9z:We6oy(w
======================
/c7IUs(Sc0检测开放端口和关联进程木铎校园 BBS 社区{3F6cS3R/D Wa!GW.r
======================木铎校园 BBS 社区a)Zi-M|b L yN
[root@ay4z3ro foo]# netstat –anp木铎校园 BBS 社区jh`._X6Tu+LK
Active Internet connections (servers and established)木铎校园 BBS 社区y:cS)E0V
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name 木铎校园 BBS 社区4E#{$E/c a)E&ZXv6j}At(]/L
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN 620/ 木铎校园 BBS 社区5[RV9tx
tcp 0 0 0.0.0.0:6000 0.0.0.0:* LISTEN 908/X
.bUDhVd0tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 880/sshd
Z.O"f,X;Z0udp 0 0 0.0.0.0:111 0.0.0.0:* 620/
'fw)j`p#J%o0Active UNIX domain sockets (servers and established)
S$t6^sn\ LB!H0Proto RefCnt Flags Type State I-Node PID/Program name Path木铎校园 BBS 社区jZ5~uJ(O?
unix 2 [ ACC ] STREAM LISTENING 2753 756/ /tmp/.font-unix/fs-1
$p$e*Z-Wb _B0……(以下省略)
K.R5Wq1`D sA.i$_e3}0在Solaris,HP-UX,AIX,FreeBSD,Linux上可以使用lsof工具列举所有运行进程及其所打开的文件描述符,其中包括常规文件,
l%T1l\"Mj1k9C:B0库文件,目录,UNIX流,套接字等。如果只想显示网络套接字的进程:木铎校园 BBS 社区 @XzO4oZF,z
[root@ay4z3ro foo]# lsof –i木铎校园 BBS 社区/__G8V(K!f
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
b6qa%J,W}0portmap 620 rpc 3u IPv4 2598 UDP *:sunrpc
H7q'a6rE9C0portmap 620 rpc 4u IPv4 2609 TCP *:sunrpc (LISTEN)
k3uj| E#p:_5M$yP[0sshd 880 root 3u IPv4 2885 TCP *:ssh (LISTEN)木铎校园 BBS 社区'qr ^H3[ @!f4W
X 908 root 1u IPv4 2945 TCP *:x11 (LISTEN)木铎校园 BBS 社区C(t:md{4t0enUC
"\ I`?Q/QH0其中特别需要注意的是奇怪的进程和已打开的原始套接字。
)l%}A L(Y*l~4t0
B#q.wjK8Zl^y@0================================木铎校园 BBS 社区E`0EUk
寻找系统中是否运行一个非法嗅探器
Pj!?&A?2`'Ozy0================================
]F(PY;WB-h0为了达到这个目的,我们需要检查网卡是否处于混杂(promiscuous)模式:木铎校园 BBS 社区HeO_YB_j-i#wE&M]
[root@ay4z3ro foo]# ifconfig –i eth0 | grep PROMISC木铎校园 BBS 社区,wRhQx`0{eN
PROMISC标志并不会在所有的*NIX上出现,通过lsof+ps命令可以判断系统是否正运行一个嗅探器。或者通过第三方的工具,比如AntiSniff。木铎校园 BBS 社区-^ @)W%rQ9m`
Tb/cW(x3^LH'r([0=================木铎校园 BBS 社区3Kn_i+C,}
检查/proc文件系统
6J B#Qx#JLv1sg6`0=================木铎校园 BBS 社区6eW5F$M(V
在/proc/$PID/目录下对于调查比较有意义的是:exe链接,fd子目录,cmdline文件。
^|0p'sJ(F q0[root@ay4z3ro 880]# ls -al
zt%kA.p F]0total 0木铎校园 BBS 社区6o6_EA1]!d
dr-xr-xr-x 3 root root 0 Sep 20 19:53 ./
!C$B'MC(o!b0G0dr-xr-xr-x 62 root root 0 Sep 20 15:07 ../
&R~!e?N(Q `'Ns0-r--r--r-- 1 root root 0 Sep 20 19:54 binfmt木铎校园 BBS 社区^d0O0u[9N*Q4IY
-r--r--r-- 1 root root 0 Sep 20 19:54 cmdline木铎校园 BBS 社区 b,p"i2g2Z:X?O.y.Ib
lrwxrwxrwx 1 root root 0 Sep 20 19:54 cwd -> //
OS [,z9WV5a k o0-r-------- 1 root root 0 Sep 20 19:54 environ
^#oC)QQ0lrwxrwxrwx 1 root root 0 Sep 20 19:54 exe -> /usr/sbin/sshd*
'sR'w2] b5k KD9F0dr-x------ 2 root root 0 Sep 20 19:54 fd/
C*A9KDtq|/k0-r--r--r-- 1 root root 0 Sep 20 19:54 maps木铎校园 BBS 社区)W9`7I4_|+C.J5a9q0J
-rw------- 1 root root 0 Sep 20 19:54 mem木铎校园 BBS 社区n\)sw8l4rqefQ
-r--r--r-- 1 root root 0 Sep 20 19:54 mounts
x"]:LXu(un0lrwxrwxrwx 1 root root 0 Sep 20 19:54 root -> //木铎校园 BBS 社区 J!s6R$MO+s @[_U
-r--r--r-- 1 root root 0 Sep 20 19:54 stat木铎校园 BBS 社区7z/];?G1i
-r--r--r-- 1 root root 0 Sep 20 19:54 statm木铎校园 BBS 社区A3@c UZ${f!P^
-r--r--r-- 1 root root 0 Sep 20 19:54 status木铎校园 BBS 社区 iW@i{f
木铎校园 BBS 社区)H+E4@.Y)Fw
Exe链接允许我们恢复被删除的文件,只要这些文件仍然运行。为获得“已删除”可执行文件的备份,只需要使用cp命令在该文件系统上
@(QY@W)A0创建一个拷贝就行。通过检查fd子目录,可以识别该进程打开的所有文件。如果对unix环境下的编程有所了解的话,很容易就能发现木铎校园 BBS 社区 aTRPbDN*v
是在读写一个文件还是打开一个网络连接。cmdline文件的内容是该进程的完整命令行。以下语句是攻击者的欺骗手段,木铎校园 BBS 社区'saaT#n@cH7\%b
strcpy(argv[0],”any_string”);木铎校园 BBS 社区'~Z L'PcX
这样该文件就显示了一种假象,即使如此,我们仍有必要检查此文件。木铎校园 BBS 社区G,]3o1]4k2y3@f4?+a
木铎校园 BBS 社区xpq/X5da
==================================
!u*a!Q+V/W8n0获取所有文件的创建,修改和访问时间木铎校园 BBS 社区4si4i"n'K
==================================木铎校园 BBS 社区O/] \ u3o z!FU(g
ls –alRu > /mnt/usb/access
CH ]$]R$D1ML8Z0ls –alRc > /mnt/usb/modification木铎校园 BBS 社区zj8vT0{S
ls –alR > /mnt/usb/creation木铎校园 BBS 社区&cv1fh%c
lihCc1| nA0============
0FM;u_kYDz!s0获取系统日志木铎校园 BBS 社区0z9DJ#d?+I|g6a-C9Mj|
============
2re w ]i0大多数UNIX的日志在/var/log和/var/adm目录下,各种UNIX派生系统日志的具体位置有所不同。木铎校园 BBS 社区@gf!RJg
在此之前,有必要了解针对特定系统的日志存贮位置。木铎校园 BBS 社区A(A@$Vq!v
比较重要的二进制日志文件:木铎校园 BBS 社区6VZ1G7oKs4`Wg
utmp,用w工具访问;木铎校园 BBS 社区[D bH a|f0i
wtmp,用last工具访问;木铎校园 BBS 社区5a,G8I$e@'W
lastlog,用lastlog工具访问;
NV{:l3f1B9q0 进程记账日志,用astcomm工具访问
6ei{H~m0 常见的ASCII文本日志文件:木铎校园 BBS 社区9gB-@[e
apache日志--/var/log/httpd/access_log;
R&S#bm8X0y0 ftp日志—xferlog;
(o7OGpiCamu.B0 命令历史记录文件;
;Vhs2w*v_9G0 /var/log/messages;木铎校园 BBS 社区1i![)Lo`[!m/q{#u%u
检查/etc/syslog.conf以及其他守护进程的配置文件以确定其余日志的位置。木铎校园 BBS 社区p3o$b+P9mz(]
%m(h-X8|N lN"@c0================
\ ?fJM"LM4_-m0获取重要配置文件木铎校园 BBS 社区k[Xq:Hd3]*z
================
1uYt-[+[1P:hp0 检查各配置文件查找后门位置,未授权的信任关系和未授权的用户ID。
E&K:d[{ am*m.h&nk0 /etc/passwd,查找未授权的用户帐号和权限。初级的入侵者会添加uid=0的用户,
([fe;jhWX0有人也会把系统中一个不起眼的原本没有shell的普通账户改成可登陆获得shell执行命令,木铎校园 BBS 社区-r]'i)b0E v
然后他可以通过一个suid位的ksh或其他的安置在本地的后门马上得到rootshell.
.K/ak$dqIL9~%W0 /etc/shadow,确保每个用户都有密码认证;当然攻击者给自己的账户加一个md5 hash其实也是非常简单的事。
v#@REA _)D;p0 /etc/groups,查找权限的升级和访问范围的扩大。木铎校园 BBS 社区+VS7C9XB[`(G
/etc/hosts,列出本地DNS条目。木铎校园 BBS 社区\ ~k5Q(u*n\4S
/etc/hosts.equiv,检查信任关系。木铎校园 BBS 社区4a&_M xi P%f)I
~/.rhosts,检查基于用户的信任关系,”++”这种很滥的后门相信大家都知道。
al9C#vw?:Y3gi1G x2A |0 /etc/hosts.allow && /etc/hosts.deny 检查tcpwrapper的规则。木铎校园 BBS 社区 @(l/c;a:Yf oHd
/etc/rc*,检查启动文件。木铎校园 BBS 社区%Uh)j7t5V1X
Crontab文件,列出计划事件。
%`3Q WeNIvc-X5U0 /etc/inetd.conf,列出端口所监听的服务。
