您好,欢迎来到思海网络,我们将竭诚为您提供优质的服务! 诚征网络推广 | 网站备案 | 帮助中心 | 软件下载 | 购买流程 | 付款方式 | 联系我们 [ 会员登录/注册 ]
促销推广
客服中心
业务咨询
有事点击这里…  531199185
有事点击这里…  61352289
点击这里给我发消息  81721488
有事点击这里…  376585780
有事点击这里…  872642803
有事点击这里…  459248018
有事点击这里…  61352288
有事点击这里…  380791050
技术支持
有事点击这里…  714236853
有事点击这里…  719304487
有事点击这里…  1208894568
有事点击这里…  61352289
在线客服
有事点击这里…  531199185
有事点击这里…  61352288
有事点击这里…  983054746
有事点击这里…  893984210
当前位置:首页 >> 技术文章 >> 文章浏览
技术文章

Linux系统下防DDOS攻击的方法

添加时间:2011-1-26  添加: admin 

  用squid也是利用端口映射的功能,可以将80端口转换一下,其实一般的DDOS攻击可以修改/proc/sys/net/ipv4/tcp_max_syn_backlog里的参数就行了,默认参数一般都很小,设为8000以上,一般的DDOS攻击就可以解决了。如果上升到timeout阶段,可以将/proc/sys/net/ipv4/tcp_fin_timeout设小点。

  大家都在讨论DDOS,个人认为目前没有真正解决的方法,只是在缓冲和防御能力上的扩充,跟黑客玩一个心理战术,看谁坚持到最后,网上也有很多做法,例如syncookies等,就是复杂点。

  sysctl -w net.ipv4.icmp_echo_ignore_all=1

  echo 1 > /proc/sys/net/ipv4/tcp_syncookies

  sysctl -w net.ipv4.tcp_max_syn_backlog="2048"

  sysctl -w net.ipv4.tcp_synack_retries="3"

  iptables -A INPUT -i eth0 -p tcp --syn -j syn-flood

  # Limit 12 connections per second (burst to 24)

  iptables -A syn-flood -m limit --limit 12/s --limit-burst 24 -j RETURN

  这个地方可以试着该该:

  iptbales -A FORWARD -p tcp --syn -m limit --limit 1/s -j ACCEPT

  虚拟主机服务商在运营过程中可能会受到黑客攻击,常见的攻击方式有SYN,DDOS等。

  通过更换IP,查找被攻击的站点可能避开攻击,但是中断服务的时间比较长。比较彻底

  的解决方法是添置硬件防火墙。不过,硬件防火墙价格比较昂贵。可以考虑利用Linux

  系统本身提供的防火墙功能来防御。

  1. 抵御SYN

  SYN攻击是利用TCP/IP协议3次握手的原理,发送大量的建立连接的网络包,但不实际

  建立连接,最终导致被攻击服务器的网络队列被占满,无法被正常用户访问。

  Linux内核提供了若干SYN相关的配置,用命令:

  sysctl -a | grep syn

  看到:

  net.ipv4.tcp_max_syn_backlog = 1024

  net.ipv4.tcp_syncookies = 0

  net.ipv4.tcp_synack_retries = 5

  net.ipv4.tcp_syn_retries = 5

  tcp_max_syn_backlog是SYN队列的长度,tcp_syncookies是一个开关,是否打开SYN Cookie

  功能,该功能可以防止部分SYN攻击。tcp_synack_retries和tcp_syn_retries定义SYN

  的重试次数。

  加大SYN队列长度可以容纳更多等待连接的网络连接数,打开SYN Cookie功能可以阻止部分

  SYN攻击,降低重试次数也有一定效果。

  调整上述设置的方法是:

  增加SYN队列长度到2048:

  sysctl -w net.ipv4.tcp_max_syn_backlog=2048

  打开SYN COOKIE功能:

  sysctl -w net.ipv4.tcp_syncookies=1

  降低重试次数:

  sysctl -w net.ipv4.tcp_synack_retries=3

  sysctl -w net.ipv4.tcp_syn_retries=3

  为了系统重启动时保持上述配置,可将上述命令加入到/etc/rc.d/rc.local文件中。

  2. 抵御DDOS

  DDOS,分布式拒绝访问攻击,是指黑客组织来自不同来源的许多主机,向常见的端口,如80,

  25等发送大量连接,但这些客户端只建立连接,不是正常访问。由于一般Apache配置的接受连接

  数有限(通常为256),这些“假” 访问会把Apache占满,正常访问无法进行。

  Linux提供了叫ipchains的防火墙工具,可以屏蔽来自特定IP或IP地址段的对特定端口的连接。

  使用ipchains抵御DDOS,就是首先通过netstat命令发现攻击来源地址,然后用ipchains命令阻断

  攻击。发现一个阻断一个。

  *** 打开ipchains功能

  首先查看ipchains服务是否设为自动启动:

  chkconfig --list ipchains

  输出一般为:

  ipchains 0ff 1ff 2n 3n 4n 5n 6ff

  如果345列为on,说明ipchains服务已经设为自动启动

  如果没有,可以用命令:

  chkconfig --add ipchains

  将ipchains服务设为自动启动

  其次,察看ipchains配置文件/etc/sysconfig/ipchains是否存在。如果这一文件不存在,ipchains

  即使设为自动启动,也不会生效。缺省的ipchains配置文件内容如下:

  # Firewall configuration written by lokkit

  # Manual customization of this file is not recommended.

  # Note: ifup-post will punch the current nameservers through the

  # firewall; such entries will *not* be listed here.

  :input ACCEPT

  :forward ACCEPT

  utput ACCEPT

  -A input -s 0/0 -d 0/0 -i lo -j ACCEPT

  # allow http,ftp,smtp,ssh,domain via tcp; domain via udp

  -A input -p tcp -s 0/0 -d 0/0 pop3 -y -j ACCEPT

  -A input -p tcp -s 0/0 -d 0/0 http -y -j ACCEPT

  -A input -p tcp -s 0/0 -d 0/0 https -y -j ACCEPT

  -A input -p tcp -s 0/0 -d 0/0 ftp -y -j ACCEPT

  -A input -p tcp -s 0/0 -d 0/0 smtp -y -j ACCEPT

  -A input -p tcp -s 0/0 -d 0/0 ssh -y -j ACCEPT

  -A input -p tcp -s 0/0 -d 0/0 domain -y -j ACCEPT

  -A input -p udp -s 0/0 -d 0/0 domain -j ACCEPT

  # deny icmp packet

  #-A input -p icmp -s 0/0 -d 0/0 -j DENY

  # default rules

  -A input -p tcp -s 0/0 -d 0/0 0:1023 -y -j REJECT

  -A input -p tcp -s 0/0 -d 0/0 2049 -y -j REJECT

  -A input -p udp -s 0/0 -d 0/0 0:1023 -j REJECT

  -A input -p udp -s 0/0 -d 0/0 2049 -j REJECT

  -A input -p tcp -s 0/0 -d 0/0 6000:6009 -y -j REJECT

  -A input -p tcp -s 0/0 -d 0/0 7100 -y -j REJECT

  如果/etc/sysconfig/ipchains文件不存在,可以用上述内容创建之。创建之后,启动ipchains服务:

  /etc/init.d/ipchains start

  *** 用netstat命令发现攻击来源

  假如说黑客攻击的是Web 80端口,察看连接80端口的客户端IP和端口,命令如下:

  netstat -an -t tcp | grep ":80" | grep ESTABLISHED | awk '{printf "%s %s/n",$5,$6}' | sort

  输出:

  161.2.8.9:123 FIN_WAIT2

  161.2.8.9:124 FIN_WAIT2

  61.233.85.253:23656 FIN_WAIT2

  ...

  第一栏是客户机IP和端口,第二栏是连接状态

  如果来自同一IP的连接很多(超过50个),而且都是连续端口,就很可能是攻击。

  http://bbs.92bbs.net/read-tid-31313.html

  如果只希望察看建立的连接,用命令:

  netstat -an -t tcp | grep ":80" | grep ESTABLISHED | awk '{printf "%s %s/n",$5,$6}' | sort

  *** 用ipchains阻断攻击来源

  用ipchains阻断攻击来源,有两种方法。一种是加入到/etc/sysconfig/ipchains里,然后重启动

  ipchains服务。另一种是直接用ipchains命令加。屏蔽之后,可能还需要重新启动被攻击的服务,

  是已经建立的攻击连接失效

  * 加入/etc/sysconfig/ipchains

  假定要阻止的是218.202.8.151到80的连接,编辑/etc/sysconfig/ipchains文件,在utput ACCEPT

  行下面加入:

  -A input -s 218.202.8.151 -d 0/0 http -y -j REJECT

  保存修改,重新启动ipchains:

  /etc/init.d/ipchains restart

  如果要阻止的是218.202.8的整个网段,加入:

  -A input -s 218.202.8.0/255.255.255.0 -d 0/0 http -y -j REJECT

 

关键字:Linux 防DDOS 攻击

分享到:

顶部 】 【 关闭
版权所有:佛山思海电脑网络有限公司 ©1998-2024 All Rights Reserved.
联系电话:(0757)22630313、22633833
中华人民共和国增值电信业务经营许可证: 粤B1.B2-20030321 备案号:粤B2-20030321-1
网站公安备案编号:44060602000007 交互式栏目专项备案编号:200303DD003  
察察 工商 网安 举报有奖  警警  手机打开网站