服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

基础--认识了解ddos攻击以及防范措施

dos(denial of service拒绝服务)和ddos(distributed denial of service分布式拒绝服务)攻击是大型网站和网络服务器的安全威胁之一,2000年2月,yahoo、亚马逊、cnn被攻击等事例,曾被刻在重大安全事件的历史中。

  商业利益的驱使,促成ddos攻击不断

  随着internet互联网络带宽的增加和多种ddos黑客工具的不断发布,ddos拒绝服务攻击的实施越来越容易,ddos攻击事件正在成上升趋势。 

  在我国,ddos攻击多数来自美国,占39%,而中国是拒绝服务攻击的主要目标,占63%。这是亚太及日本地区互联网安全威胁报告中的一部分数据。中国成为ddos攻击的主要目标。据介绍,凡是能导致合法用户不能够访问正常网络服务的行为都属“拒绝服务攻击”。

   出于商业竞争、打击报复和网络敲诈等多种因素,导致很多idc托管机房、商业站点、游戏服务器、聊天网络等网络服务商长期以来一直被ddos攻击所困扰,随之而来的是客户投诉、同虚拟主机用户受牵连、法律纠纷、商业损失等一系列问题,因此,解决ddos攻击问题成为网络服务商必须考虑的头等大事。 

  到底什么是ddos?你被ddos了吗? 

  ddos是英文distributed denial of service的缩写,意即“分布式拒绝服务”,那么什么又是拒绝服务(denial of service)呢?可以这么理解,凡是能导致合法用户不能够访问正常网络服务的行为都算是拒绝服务攻击。也就是说拒绝服务攻击的目的非常明确,就是要阻止合法用户对正常网络资源的访问,从而达成攻击者不可告人的目的。 
  虽然同样是拒绝服务攻击,但是ddos和dos还是有所不同,ddos的攻击策略侧重于通过很多“僵尸主机”(被攻击者入侵过或可间接利用的主机)向受害主机发送大量看似合法的网络包,从而造成网络阻塞或服务器资源耗尽而导致拒绝服务,分布式拒绝服务攻击一旦被实施,攻击网络包就会犹如洪水般涌向受害主机,从而把合法用户的网络包淹没,导致合法用户无法正常访问服务器的网络资源,因此,拒绝服务攻击又被称之为“洪水式攻击”,常见的ddos攻击手段有syn flood、ack flood、udp flood、icmp flood、tcp flood、connections flood、script flood、proxy flood等;而dos则侧重于通过对主机特定漏洞的利用攻击导致网络栈失效、系统崩溃、主机死机而无法提供正常的网络服务功能,从而造成拒绝服务,常见的dos攻击手段有teardrop、land、jolt、igmp nuker、boink、smurf、bonk、oob等。 
  就这两种拒绝服务攻击而言,危害较大的主要是ddos攻击,原因是很难防范,至于dos攻击,通过给主机服务器打补丁或安装防火墙软件就可以很好地防范,后文会详细介绍怎么对付ddos攻击。 

  ddos的表现形式 

  ddos的表现形式主要有两种,一种为流量攻击,主要是针对网络带宽的攻击,即大量攻击包导致网络带宽被阻塞,合法网络包被虚假的攻击包淹没而无法到达主机;另一种为资源耗尽攻击,主要是针对服务器主机的攻击,即通过大量攻击包导致主机的内存被耗尽或cpu被内核及应用程序占完而造成无法提供网络服务。 

  如何判断网站是否遭受了流量攻击呢?可通过ping命令来测试,若发现ping超时或丢包严重(假定平时是正常的),则可能遭受了流量攻击,此时若发现和你的主机接在同一交换机上的服务器也访问不了了,基本可以确定是遭受了流量攻击。当然,这样测试的前提是你到服务器主机之间的icmp协议没有被路由器和防火墙等设备屏蔽,否则可采取telnet主机服务器的网络服务端口来测试,效果是一样的。不过有一 
  点可以肯定,假如平时ping你的主机服务器和接在同一交换机上的主机服务器都是正常的,突然都ping不通了或者是严重丢包,那么假如可以排除网络故障因素的话则肯定是遭受了流量攻击,再一个流量攻击的典型现象是,一旦遭受流量攻击,会发现用远程终端连接网站服务器会失败。 

  相对于流量攻击而言,资源耗尽攻击要容易判断一些,假如平时ping网站主机和访问网站都是正常的,发现突然网站访问非常缓慢或无法访问了,而ping还可以ping通,则很可能遭受了资源耗尽攻击,此时若在服务器上用netstat -na命令观察到有大量的syn_received、time_wait、fin_wait_1等状态存在,而established很少,则可判定肯定是遭受了资源耗尽攻击。还有一种属于资源耗尽攻击的现象是,ping自己的网站主机ping不通或者是丢包严重,而ping与自己的主机在同一交换机上的服务器则正常,造成这种原因是网站主机遭受攻击后导致系统内核或某些应用程序cpu利用率达到100%无法回应ping命令,其实带宽还是有的,否则就ping不通接在同一交换机上的主机了。 

当前主要有三种流行的ddos攻击: 

  1、syn/ack flood攻击:这种攻击方法是经典最有效的ddos方法,可通杀各种系统的网络服务,主要是通过向受害主机发送大量伪造源ip和源端口的syn或ack包,导致主机的缓存资源被耗尽或忙于发送回应包而造成拒绝服务,由于源都是伪造的故追踪起来比较困难,缺点是实施起来有一定难度,需要高带宽的僵尸主机支持。少量的这种攻击会导致主机服务器无法访问,但却可以ping的通,在服务器上用netstat -na 

  命令会观察到存在大量的syn_received状态,大量的这种攻击会导致ping失败、tcp/ip栈失效,并会出现系统凝固现象,即不响应键盘和鼠标。普通防火墙大多无法抵御此种攻击。 



  2、tcp全连接攻击:这种攻击是为了绕过常规防火墙的检查而设计的,一般情况下,常规防火墙大多具备过滤teardrop、land等dos攻击的能力,但对于正常的tcp连接是放过的,殊不知很多网络服务程序(如:iis、apache等web服务器)能接受的tcp连接数是有限的,一旦有大量的tcp连接,即便是正常的,也会导致网站访问非常缓慢甚至无法访问,tcp全连接攻击就是通过许多僵尸主机不断地与受害服务器建立大量 的tcp连接,直到服务器的内存等资源被耗尽而被拖跨,从而造成拒绝服务,这种攻击的特点是可绕过一般防火墙的防护而达到攻击目的,缺点是需要找很多僵尸主机,并且由于僵尸主机的ip是暴露的,因此容易被追踪。 

  3、刷script脚本攻击:这种攻击主要是针对存在asp、jsp、php、cgi等脚本程序,并调用mssqlserver、mysqlserver、oracle等数据库的网站系统而设计的,特征是和服务器建立正常的tcp连接,并不断的向脚本程序提交查询、列表等大量耗费数据库资源的调用,典型的以小博大的攻击方法。一般来说,提交一个get或post指令对客户端的耗费和带宽的占用是几乎可以忽略的,而服务器为处理此请求却可能要从上万条记录中去查出某个记录,这种处理过程对资源的耗费是很大的,常见的数据库服务器很少能支持数百个查询指令同时执行,而这对于客户端来说却是轻而易举的,因此攻击者只需通过proxy代理向主机服务器大量递交查询指令,只需数分钟就会把服务器资源消耗掉而导致拒绝服务,常见的现象就是网站慢如蜗牛、asp程序失效、php连接数据库失败、数据库主程序占用cpu偏高。这种攻击的特点是可以完全绕过普通的防火墙防护,轻松找一些proxy代理就可实施攻击,缺点是对付只有静态页面的网站效果会大打折扣,并且有些proxy会暴露攻击者的ip地址。 

完全抵御住ddos攻击是不可能的

  对付ddos是一个系统工程,想仅仅依靠某种系统或产品防住ddos是不现实的,可以肯定的是,完全杜绝ddos目前是不可能的,但通过适当的措施抵御90%的ddos攻击是可以做到的,基于攻击和防御都有成本开销的缘故,若通过适当的办法增强了抵御ddos的能力,也就意味着加大了攻击者的攻击成本,那么绝大多数攻击者将无法继续下去而放弃,也就相当于成功的抵御了ddos攻击。 

  以下几点是防御ddos攻击几点: 

  1、采用高性能的网络设备 
  首先要保证网络设备不能成为瓶颈,因此选择路由器、交换机、硬件防火墙等设备的时候要尽量选用知名度高、口碑好的产品。再就是假如和网络提供商有特殊关系或协议的话就更好了,当大量攻击发生的时候请他们在网络接点处做一下流量限制来对抗某些种类的ddos攻击是非常有效的。 

  3、充足的网络带宽保证 

  网络带宽直接决定了能抗受攻击的能力,假若仅仅有10m带宽的话,无论采取什么措施都很难对抗现在的synflood攻击,当前至少要选择100m的共享带宽,最好的当然是挂在1000m的主干上了。 

  但需要注意的是,主机上的网卡是1000m的并不意味着它的网络带宽就是千兆的,若把它接在100m的交换机上,它的实际带宽不会超过100m,再就是接在100m的带宽上也不等于就有了百兆的带宽,因为网络服务商很可能会在交换机上限制实际带宽为10m,这点一定要搞清楚。 

  4、安装专业抗ddos防火墙

    专业抗ddos防火墙采用内核提前过滤技术、反向探测技术、指纹识别技术等多项专利技术来发现和提前过滤ddos非法数据包,做到了智能抵御用户的dos攻击。但也不能100%阻止对ddos非法数据包准确检查。