DDOS防御----CENTOS 内核TCP参数优化

0x01 环境

attact作为攻击发起方,安装有hping
server作为被攻击方,修改内核TCP参数。使用操作系统CENTOS7 

0x02 步骤

一、发起攻击

修改TCP最大SYN连接数
使用attact机发起TCP SYN攻击

注意修改IP与端口,端口一定要是服务器上开放的TCP端口

hping3 -S --flood --rand-source 192.168.164.136 -p 80

登录server服务器,查看当前受攻击情况
systemctl start httpd		//启动http服务
netstat -an | grep SYN 			//查看SYN半连接
netstat -an | grep SYN | wc -l		//统计SYN半连接数,默认为128*2

登录server,查看服务器默认设置
cat /proc/sys/net/ipv4/tcp_max_syn_backlog 		//默认为128
cat /proc/sys/net/core/somaxconn 			//默认为128
cat /proc/sys/net/ipv4/tcp_synack_retries		//默认为5
cat /proc/sys/net/ipv4/tcp_syncookies		//默认为1,表示开启
参数解释
tcp_max_syn_backlog表示TCY_SYN连接数
somaxconn表示每个应用端口listen的队列

系统实际上会将上述两个值取较小值*2,来作为上限值,所以我们要修改这两个值

参数解释
tcp_synack_retries表示收到SYN后发送SYN+ACK的重传次数,默认为5
tcp_syncookies表示启用SYNCOOKIES功能,默认1即启用

vi /etc/sysctl.conf,加入下面参数,并保存

net.ipv4.tcp_max_syn_backlog = 1024		
net.ipv4.tcp_synack_retries =2
net.core.somaxconn = 1024
保存文件后,执行以下命令,生效

sysctl -p

修改apached的listenbacklog

vi /etc/httpd/conf.modules.d/00-mpm.conf

加入下面行
ListenBacklog 1024
重启HTTP应用

systemctl restart httpd

查看当前队列数。需要注意的是,每个应用会有自己默认的最大队列。如SSH是128,APACHE是511,这个值,会与和我们设置的somaxconn取最小值。

查看当前端口的队列值,即SEND-Q
ss -lnt

再次发起攻击
hping3 -S --flood --rand-source 192.168.164.136 -p 80

再次查看状态

netstat -an | grep SYN | wc -l		//统计SYN半连接数,这里应该为2048

二、DDOS防御—使用iptables限制SYN连接速度

登录server,启用iptables
systemctl stop firewalld.service		\\停止firewall
systemctl disable firewalld.service		\\禁止firewall开机启动
yum -y install iptables-services		\\安装 iptables-service
systemctl start iptables		\\启动IPTABLES服务

配置iptables
iptables -N syn-flood		//新建一个表
iptables -I INPUT -p tcp --syn -j syn-flood		//匹配syn到syn-flood
iptables -I syn-flood -p tcp -m limit --limit 3/s --limit-burst 6 -j RETURN		//syn限速,超出后返回
iptables -A syn-flood -j REJECT		//拒绝其它

配置后的iptables 显示如下

iptables -nL

Chain INPUT (policy ACCEPT 0 packets, 0 bytes)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 syn-flood  tcp  --  *      *       0.0.0.0/0            0.0.0.0/0            tcp flags:0x17/0x02
  111  8244 ACCEPT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            state RELATED,ESTABLISHED
    0     0 ACCEPT     icmp --  *      *       0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     all  --  lo     *       0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     tcp  --  *      *       0.0.0.0/0            0.0.0.0/0            state NEW tcp dpt:22
    2   569 REJECT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            reject-with icmp-host-prohibited

Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 REJECT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            reject-with icmp-host-prohibited

Chain OUTPUT (policy ACCEPT 19 packets, 1892 bytes)
 pkts bytes target     prot opt in     out     source               destination         

Chain syn-flood (1 references)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 RETURN     tcp  --  *      *       0.0.0.0/0            0.0.0.0/0            limit: avg 3/sec burst 6
    0     0 REJECT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            reject-with icmp-port-unreachable

再使用 hping3发起SYN攻击,查看服务器SYN连接

三、DDOS防御—使用iptables限制同一源IP连接数

以80端口为例,开启服务器的http服务

systemctl start http

配置iptables如下
iptables -I INPUT  -p tcp -m tcp --dport 80 -j ACCEPT     //允许访问80端口
iptables -I INPUT  -p tcp --dport 80 -m connlimit --connlimit-above 15 -j REJECT  //拒绝大于15个连接的IP
使用Attact机器发起模拟攻击

slowhttptest -c 1000 -B -g -i 10 -r 200 -u http://192.168.164.136 -x 1024 -p 3

攻击后,分别使用attact和其它计算机访问http://192.168.164.136,观察能否正常访问

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值