全球主机交流论坛

标题: 如果某个IP一分钟内连接80端口次数超过100次,就禁止这个IP [打印本页]

作者: gdtv    时间: 2010-3-15 15:18
标题: 如果某个IP一分钟内连接80端口次数超过100次,就禁止这个IP
怎样可以实现?
作者: haoqiumi    时间: 2010-3-15 15:24
线程?
作者: gdtv    时间: 2010-3-17 14:56
顶顶
作者: wzwen    时间: 2010-3-17 15:14
听说要在iptable里写规则
作者: freebsd    时间: 2010-3-17 15:21
nginx 里可以实现限制单个IP的连接数。

或者用脚本分析日志,把单位时间内过多连接的IP送入防火墙屏蔽名单
作者: 美国VPS    时间: 2010-3-17 16:01
一般需要指望第三方的模块,apache和nginx都有类似的,也许能满足你的要求
作者: 美国VPS    时间: 2010-3-17 16:02
穿针引线一下:

ngx_http_limit_zone_module
本模块可以针对条件,进行会话的并发连接数控制。(例如:限制每个IP的并发连接数。)
__配置示例__
http {
: limit_zone   one  $binary_remote_addr  10m;

: ...

: server {

: ...

: location /download/ {
: limit_conn   one  1;
: }
指令

[#limit_zone limit_zone]
[#limit_conn limit_conn]
limit_zone

语法:limit_zone zone_name $variable the_size
默认值:no
作用域:http

本指令定义了一个数据区,里面记录会话状态信息。
$variable 定义判断会话的变量;the_size 定义记录区的总容量。
例子:
limit_zone   one  $binary_remote_addr  10m;
定义一个叫“one”的记录区,总容量为 10M,以变量 $binary_remote_addr 作为会话的判断基准(即一个地址一个会话)。

您可以注意到了,在这里使用的是 $binary_remote_addr 而不是 $remote_addr。
$remote_addr 的长度为 7 至 15 bytes,会话信息的长度为 32 或 64 bytes。而 $binary_remote_addr 的长度为 4 bytes,会话信息的长度为 32 bytes。

当区的大小为 1M 的时候,大约可以记录 32000 个会话信息(一个会话占用 32 bytes)。

limit_conn

语法:limit_conn zone_name the_size

默认值:no

作用域:http, server, location
指定一个会话最大的并发连接数。当超过指定的最发并发连接数时,服务器将返回 "Service unavailable" (503)。
例子:
limit_zone   one  $binary_remote_addr  10m;

: server {
: location /download/ {
: limit_conn   one  1;
: }
定义一个叫“one”的记录区,总容量为 10M,以变量 $binary_remote_addr 作为会话的判断基准(即一个地址一个会话)。限制 /download/ 目录下,一个会话只能进行一个连接。简单点,就是限制 /download/ 目录下,一个IP只能发起一个连接,多过一个,一律503。
作者: gdtv    时间: 2010-3-17 16:58
回复5楼和7楼:
limit_conn是限制并发连接数,不能实现"一分钟内连接次数超过100",也就是说不能限制单位时间内的连接数

用limit_conn的话,如果限制为1,当一个页面有多个图片时,图片就显示不了了
作者: 诡谲    时间: 2010-3-17 17:50
标题: DOS- Deflate:帮助您有效减轻 DOS 攻击伤害
看这里.两篇一起看.

http://icodex.org/2010/03/powerf ... olicy-firewall-apf/
http://icodex.org/2010/03/help-y ... s-with-dos-deflate/

切莫照搬.自己修改.
------------------------------ DOS- Deflate ---------------------------------
yum -y install vixie-cron crontabs
chkconfig crond on
service crond start

cd /usr/local/src
wget http://www.rfxn.com/downloads/apf-current.tar.gz
tar -zxf apf-current.tar.gz
cd apf-9.7-1/
sh ./install.sh

cd /usr/local/src
wget http://www.inetbase.com/scripts/ddos/install.sh
sh ./install.sh




欢迎光临 全球主机交流论坛 (https://fd.vvwvv.eu.org/) Powered by Discuz! X3.4