18 12
发新话题
打印

[建站问题] 服务器安全 防范拒绝服务攻击妙招儿

服务器安全 防范拒绝服务攻击妙招儿

服务器安全 防范拒绝服务攻击妙招儿前网络中有一种攻击让网络管理员最为头疼,那就是拒绝服务攻击,简称DOS和DDOS。它是一种滥用资源性的攻击,目的就是利用自身的资源通过一种放大或不对等的方式来达到消耗对方资源的目的。同一时刻很多不同的IP对服务器进行访问造成服务器的服务失效甚至死机。
# C/ |" }% _5 A. N4 l  今天就笔者公司管理服务器的经验为各位读者介绍几个简单有效的防范拒绝服务攻击的方法,虽然不能彻底防护,但在与DDOS的战斗中可以最大限度降低损失。4 y0 x, y. M8 ~# j
  A$ p- W7 f8 I, u
  1、如何发现攻击
* Y: s2 l0 X2 V" v, G' ]3 b3 [, p* H% }5 U
  在服务器上可以通过CPU使用率和内存利用率简单有效的查看服务器当前负载情况,如果发现服务器突然超负载运作,性能突然降低,这就有可能是受攻击的征兆。不过也可能是正常访问网站人数增加的原因。如何区分这两种情况呢?按照下面两个原则即可确定受到了攻击。3 o/ \) l% O" F3 ^6 b
* L* t( J& z" b0 R
  (1)网站的数据流量突然超出平常的十几倍甚至上百倍,而且同时到达网站的数据包分别来自大量不同的IP。7 S" p! _# K# v) X% {) b5 N, ^

, O3 F7 l! {. h% d  (2)大量到达的数据包(包括TCP包和UDP包)并不是网站服务连接的一部分,往往指向你机器任意的端口。比如你的网站是Web服务器,而数据包却发向你的FTP端口或其它任意的端口。
6 N# a5 M+ p* E4 t" N2 F4 v, X/ A$ P3 O7 B* m# {$ u
  2、BAN IP地址法, _# m+ k2 ]4 t6 a& L+ B. H% x) y

/ Q1 p) u0 K& Y, b  确定自己受到攻击后就可以使用简单的屏蔽IP的方法将DOS攻击化解。对于DOS攻击来说这种方法非常有效,因为DOS往往来自少量IP地址,而且这些IP地址都是虚构的伪装的。在服务器或路由器上屏蔽攻击者IP后就可以有效的防范DOS的攻击。不过对于DDOS来说则比较麻烦,需要我们对IP地址分析,将真正攻击的IP地址屏蔽。
4 |: O& y  b- M7 p, b2 D
/ |0 o. g- e% S( }) L# Y  不论是对付DOS还是DDOS都需要我们在服务器上安装相应的防火墙,然后根据防火墙的日志分析来访者的IP,发现访问量大的异常IP段就可以添加相应的规则到防火墙中实施过滤了。
1 b5 o; U) Y. S/ _: Y  H
9 q6 q  K  H5 m: B: |# h/ _  当然直接在服务器上过滤会耗费服务器的一定系统资源,所以目前比较有效的方法是在服务器上通过防火墙日志定位非法IP段,然后将过滤条目添加到路由器上。例如我们发现进行DDOS攻击的非法IP段为211.153.0.0 255.255.0.0,而服务器的地址为61.153.5.1。那么可以登录公司核心路由器添加如下语句的访问控制列表进行过滤。
0 |5 f4 E6 n7 _" W
( B& M- Y. {1 U6 D  cess-list 108 deny tcp 211.153.0.0 0.0.255.255 61.135.5.1 0.0.0.0,
! s& i9 q! w+ [# e( p. q
: |7 o7 a! Q& Y- }1 P  I+ ^" x  这样就实现了将211.153.0.0 255.255.0.0的非法IP过滤的目的。- S% }3 P. e2 ^- e- i; x
. R5 H6 Q" o. y; _- R$ r
  小提示:在访问控制列表中表示子网掩码需要使用反向掩码,也就是说0.0.255.255表示子网掩码为255.255.0.0 。5 k3 L+ m6 l3 i7 [

1 u& }) n; B  p0 ]+ P  3、增加SYN缓存法 : H+ i- m6 c% y2 k/ k. q

: J* ?& [( {$ T/ `# ?+ ?2 S
5 t4 `) J- ~; A+ o$ m  上面提到的BAN IP法虽然可以有效的防止DOS与DDOS的攻击但由于使用了屏蔽IP功能,自然会误将某些正常访问的IP也过滤掉。所以在遇到小型攻击时不建议大家使用上面介绍的BAN IP法。我们可以通过修改SYN缓存的方法防御小型DOS与DDOS的攻击。该方法在笔者所在公司收效显著。
) a) y$ w" B( n2 p2 M$ S5 R/ c, O" D! Q+ `  C! ~! f8 |
  修改SY缓存大小是通过注册表的相关键值完成的。我墙魑欢琳呓樯茉赪INDOWS2003和2000中的修改方法。9 Y  {" I' ^2 ?+ Q6 I$ }( K

" W7 T* z2 H* g  (1)WIN2003下拒绝访问攻击的防范:
8 D3 N& u, Z) ^+ |) q" H" C6 N, D( E+ a" f4 E/ @
  第一步:“开始->运行->输入regedit”进入注册表编辑器。& F/ ^- d0 m! Q; Y/ G
! r) S4 Q0 j/ X+ T5 x
  第二步:找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services,在其下的有个SynAttackProtect键值。默认为0将其修改为1可更有效地防御SYN攻击。
7 R8 t# d2 E+ N7 d# U6 Q
% }; g! f1 ?5 v5 j* j  P  小提示:该参数可使TCP调整SYN-ACKS的重新传输。将SynAttackProtect设置为1时,如果系统检测到存在SYN攻击,连接响应的超时时间将更短。
2 f! O( y5 \/ K, G  \: ]' S- s. u8 h1 P( T% O% q# n" W4 a1 f  I( a
  第三步:将HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services下EnableDeadGWDetect键值,将其修改为0。该设置将禁止SYN攻击服务器后强迫服务器修改网关从而使服务暂停。% ]' |& Q9 q, a+ e8 z
4 S! j% {4 E# N+ }/ |; p
  第四步:将HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services下EnablePMTUDiscovery键值,将其修改为0。这样可以限定攻击者的MTU大小,降低服务器总体负荷。: ]0 b' v: Y6 S! Q6 I
9 u$ I7 e8 P$ l& |
  第五步:将HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services下KeepAliveTime设置为300,000。将NoNameReleaseOnDemand设置为1。
0 H1 g, d4 h* r4 Z6 `
' w7 X" o4 u) O; S0 I+ e0 r* p9 H2 B  (2)WIN2000下拒绝访问攻击的防范:0 O: \) a9 u9 J; r

' s+ y6 h) r/ a" s! H* g/ B  在WIN2000下拒绝访问攻击的防范方法和2003基本相似,只是在设置数值上有些区别。我们做下简单介绍。; u: @$ Z0 x' F8 o

8 K2 \" R  {1 j( H. w  第一步:将SynAttackProtect设置为2。/ l: w9 i) Q, ?& m
, e% n" {  q/ y
  第二步:将EnableDeadGWDetect设置为0。
- v8 ^1 p  W1 n( G7 P' Z* W% z6 S
# m: O( @, e2 Z4 }  第三步:将EnablePMTUDiscovery设置为0。2 z4 r7 F. h# m0 n9 }! H& ~
( ^1 m0 D* E2 g) \6 p
  第四步:将KeepAliveTime设置为300000。& }, f$ T5 a6 F$ B% ?) R

1 {# \- i# L2 \! _  第五步:将NoNameReleaseOnDemand设置为1。
5 g" c7 L% K( A& v8 w2 \( X* K: Q$ j# M2 ]6 {, e( y. S4 g3 b
  总结:经过上面介绍的察觉攻击法,BAN IP法和最后的修改注册表法可以有效的防范DOS与DDOS的攻击。不过由于DDOS攻击的特点,实际上没有一台服务器能够彻底防范它,即使安装了专业的防范DDOS的硬件防火墙也不能百分之百的避免损失。今天介绍的几个方法只是免费的防范手段,实际中能起到一定的效果。

TOP

多谢分享

TOP

TOP

TOP

TOP

TOP

TOP

TOP

TOP

TOP

 18 12
发新话题