免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: dreamice
打印 上一主题 下一主题

讨论一下:如何限制单个IP在指定时间内的连接数限制 [复制链接]

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
21 [报告]
发表于 2009-03-18 21:41 |只看该作者
白金兄提到iptables的可以作为参考不

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
22 [报告]
发表于 2009-03-18 22:23 |只看该作者
原帖由 Godbach 于 2009-3-18 21:41 发表
白金兄提到iptables的可以作为参考不


慢慢研究,呵呵

论坛徽章:
0
23 [报告]
发表于 2009-03-19 07:54 |只看该作者
说到流量限制,我觉得这样实现起来可能更简单。
你可以用connlimit限制最多并行连接为5个。当完成一个连接,把connlimit限制连接数--,等待一定时间(比如15分钟),再将connlimit限制连接数++。

[ 本帖最后由 richardhesidu 于 2009-3-19 08:08 编辑 ]

论坛徽章:
0
24 [报告]
发表于 2009-03-19 09:37 |只看该作者
原帖由 richardhesidu 于 2009-3-19 07:54 发表
说到流量限制,我觉得这样实现起来可能更简单。
你可以用connlimit限制最多并行连接为5个。当完成一个连接,把connlimit限制连接数--,等待一定时间(比如15分钟),再将connlimit限制连接数++。

问题就是如何判断“当完成一个连接”
由于自身并非终端 socket,所以很难断定这个 stream 的状态
netfilter 中 conntrack 对 TCP 的判断都有错误的情况,更何况 UDP 这种无连接协议呢?

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
25 [报告]
发表于 2009-03-19 09:40 |只看该作者
原帖由 platinum 于 2009-3-19 09:37 发表

问题就是如何判断“当完成一个连接”
由于自身并非终端 socket,所以很难断定这个 stream 的状态
netfilter 中 conntrack 对 TCP 的判断都有错误的情况,更何况 UDP 这种无连接协议呢?


可否简化为只判断SYN包

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
26 [报告]
发表于 2009-03-19 09:43 |只看该作者
原帖由 Godbach 于 2009-3-19 09:40 发表


可否简化为只判断SYN包


UDP如何判断syn包?

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
27 [报告]
发表于 2009-03-19 09:53 |只看该作者
原帖由 dreamice 于 2009-3-19 09:43 发表


UDP如何判断syn包?

呵呵,我指的只是TCP的报文

论坛徽章:
0
28 [报告]
发表于 2009-03-19 10:13 |只看该作者
原帖由 platinum 于 2009-3-19 09:37 发表

问题就是如何判断“当完成一个连接”
由于自身并非终端 socket,所以很难断定这个 stream 的状态
netfilter 中 conntrack 对 TCP 的判断都有错误的情况,更何况 UDP 这种无连接协议呢?

嗯,这我倒没考虑到。
如果在应用层协议来跟踪连接状态的话,也就没有必要到传输层来限制连接了,直接在应用层做就可以了。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
29 [报告]
发表于 2009-03-19 10:15 |只看该作者
原帖由 dreamice 于 2009-3-19 09:43 发表


UDP如何判断syn包?

呵呵,我指的只是TCP的报文

论坛徽章:
0
30 [报告]
发表于 2009-03-19 10:22 |只看该作者
不知道是不是我理解错了。如果要限制指定时间内的连接数,跟踪连接状态是必须的吧。同样也有何判断“当完成一个连接”的问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP