免费注册 查看新帖 |

Chinaunix

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

[欢迎进入讨论] 关于syn-proxy的一些问题 [复制链接]

论坛徽章:
0
101 [报告]
发表于 2009-03-17 10:31 |只看该作者
我的一点思路:
In PRO Routing Hook
if(is syn from client)
{
   截获syn包,发送syn+ack
}
if(is ack from client)
{
  截获ack包,验证cookie,注册ip conntrack(其中有cookie值和syn),向server发送syn包
}
if(is syn+ack from server)
{
  截获syn+ack包,发送ack包。更新差值
}

论坛徽章:
0
102 [报告]
发表于 2009-03-17 10:39 |只看该作者
原帖由 richardhesidu 于 2009-3-17 10:31 发表
我的一点思路:
In PRO Routing Hook
if(is syn from client)
{
   截获syn包,发送syn+ack
}
if(is ack from client)
{
  截获ack包,验证cookie,注册ip conntrack(其中有cookie值和syn),向server发送syn包
}
if(is syn+ack from server)
{
  截获syn+ack包,发送ack包。更新差值
}


这个思路有一些问题。
第一,cookie的计算,又添加了2次的csum计算。加上cookie本身就等于3次。
第二,向server发送的syn包,是保存,还是不保存重新生成?一个是内存的消耗,另一个是时间的消耗。
第三,后续所有的连接数据包都要重新计算2个csum。

总体说来,CPU的处理量太大了。

论坛徽章:
0
103 [报告]
发表于 2009-03-17 10:40 |只看该作者
不知道Godbach兄有没有考虑伪造包丢失的问题。
如果由于网路问题,client或sever没有收到,是否得考虑重发。給client发的syn+ack包可能没有问题,因为client会继续发送syn包。而由fw伪造的发给server的syn包和ack包,似乎需要考虑这个问题。

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
104 [报告]
发表于 2009-03-17 10:41 |只看该作者

回复 #103 richardhesidu 的帖子

我觉得,用透明代理的话,就没必要搞那么复杂的考虑了

论坛徽章:
0
105 [报告]
发表于 2009-03-17 10:47 |只看该作者
原帖由 dreamice 于 2009-3-17 10:41 发表
我觉得,用透明代理的话,就没必要搞那么复杂的考虑了


透明代理的问题如下:
1。防火墙本身为网络瓶颈。在大流量攻击下是否能抗得住?
2。代理本身屏蔽了原始client的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
106 [报告]
发表于 2009-03-17 10:51 |只看该作者
第三,后续所有的连接数据包都要重新计算2个csum。

因为后序报文要么修改ACK,要么修改SEQ,重新计算的时候可以考虑用增量计算校验和的方式,计算耗费的资源可以忽略不计。

论坛徽章:
0
107 [报告]
发表于 2009-03-17 10:51 |只看该作者
原帖由 Godbach 于 2009-3-17 10:51 发表

因为后序报文要么修改ACK,要么修改SEQ,重新计算的时候可以考虑用增量计算校验和的方式,计算耗费的资源可以忽略不计。


还有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
108 [报告]
发表于 2009-03-17 10:53 |只看该作者
原帖由 ShadowStar 于 2009-3-17 10:51 发表


还有IP的序列号呢。


一次是fw发送的SYN+ACK,一次是sever发送的SYN+ACK。这两个报文处理在seq上不一样之外,IP的序号也不一样吗?
这两个SYN+ACK应该是对同一个SYN包相应的

论坛徽章:
0
109 [报告]
发表于 2009-03-17 10:55 |只看该作者
原帖由 Godbach 于 2009-3-17 10:53 发表


一次是fw发送的SYN+ACK,一次是sever发送的SYN+ACK。这两个报文处理在seq上不一样之外,IP的序号也不一样吗?
这两个SYN+ACK应该是对同一个SYN包相应的


当然不一样了。你截获了client的SYN,怎么能知道server的IP序列号呢?

论坛徽章:
0
110 [报告]
发表于 2009-03-17 10:55 |只看该作者
还有就是资源回收的问题了。比如ip conntrack的注销。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP