免费注册 查看新帖 |

Chinaunix

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

[C++] TCP/IP三次握手讨论 [复制链接]

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
11 [报告]
发表于 2015-06-11 15:52 |只看该作者
回复 10# cokeboL

其实多级次握手也不是完全没用,比如SCTP用4次握手,连接状态在第二个来回才建立,这样可以防止SYN Flooding,因为你得很精确的连续两次伪造源地址发包才能骗过对方,基本上不可行,但像TCP这样的3次握手,既不够简洁又不够安全,还不如不用。

论坛徽章:
1
2015亚冠之浦和红钻
日期:2015-05-26 14:37:09
12 [报告]
发表于 2015-06-11 20:55 |只看该作者
回复 9# windoze

最后一次的客服端的ack报文不是确认吗?怎么会没用啊?求解释清楚一点。只有收到ack应答,才说明服务器端的syn被客户端接受了啊。。。你为什么说无论多次此都没用呢?
我的理解是,客户端开始发送syn连接报文给服务器,服务器收到之后,发送ack+syn报文,然后等待客服端的ack报文,同时采用超时重传的机制。这样就可以防止最后的客服端的ack报文丢失啊。
求指教

论坛徽章:
1
2015亚冠之浦和红钻
日期:2015-05-26 14:37:09
13 [报告]
发表于 2015-06-11 20:58 |只看该作者
回复 5# cokeboL

最后一次的ack确定报文丢失,服务器可以通过超时重传来解决啊。超过时间没有收到ack报文,服务器就重发syn连接报文给客服端,导致客服端重新发送ack报文。问题不就解决了吗?
   

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
14 [报告]
发表于 2015-06-11 22:12 |只看该作者
本帖最后由 windoze 于 2015-06-11 22:17 编辑

回复 12# kkshaq

客户端只是发了一个ACK而已,它也不知道服务器端到底收到没有,想知道结果必需得让服务器端再发一个ACK过来。
同理服务器端也不知道自己再发的那个ACK客户端到底收到没有,想知到结果必需得让客户端再发一个ACK过来。
……
……
……
……
……
……
然而无论你重复多少次,都并没有什么卵用。


超时重传也不解决问题,因为有可能是对方的回复你没收到,甚至有可能无论你再催多少遍还是收不到。
不信?想象一下两边在用光纤通信,然后一方的激光二极管烧了……

论坛徽章:
9
2015年亚洲杯之卡塔尔
日期:2015-05-07 07:05:542015亚冠之鹿岛鹿角
日期:2015-05-29 14:55:522015亚冠之鹿岛鹿角
日期:2015-06-11 09:55:192015亚冠之山东鲁能
日期:2015-06-19 23:53:042015亚冠之大阪钢巴
日期:2015-06-23 21:03:17操作系统版块每日发帖之星
日期:2015-06-23 22:20:00操作系统版块每日发帖之星
日期:2015-06-27 22:20:002015亚冠之布里斯班狮吼
日期:2015-07-04 03:40:012015亚冠之平阳省
日期:2015-07-12 09:32:55
15 [报告]
发表于 2015-06-12 06:16 |只看该作者
在多数情况下2次握手够了

极端情况下,N次握手都不够

这个第三次握手

就如同 switch(){
      case:;
      default:
      break;
       }

是个逻辑握手!

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
16 [报告]
发表于 2015-06-12 08:57 |只看该作者
回复 13# kkshaq


    任何一个包都可能丢,包括为了确认发的包,所以并没有什么卵用。透过现象看本质,直接抓住最根本的地方来想就清楚了

论坛徽章:
12
巳蛇
日期:2013-09-16 15:32:242015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之约旦
日期:2015-02-11 14:38:37双鱼座
日期:2015-01-05 11:05:47戌狗
日期:2014-12-08 09:41:18戌狗
日期:2014-08-15 09:29:29双子座
日期:2014-08-05 09:17:17卯兔
日期:2014-06-08 15:32:18巳蛇
日期:2014-01-27 08:47:08白羊座
日期:2013-11-28 21:04:15巨蟹座
日期:2013-11-13 21:58:012015年亚洲杯之科威特
日期:2015-04-17 16:51:51
17 [报告]
发表于 2015-06-12 09:34 |只看该作者
楼上几个真能扯,本来不想回,越讨论越扯淡。

假设A向B发起连接,A到B是通的,B到A不通,两次握手的结果是B认为连接成功建立,而A知道连接不成功。
三次握手是让双方确认两边网络都通所需要的最少次数。少于三次,无法确认双方网络都通。

15楼举的例子,恰恰在反驳自己。单向通的网络会卡在前两次握手。如果第三次握手的包丢失,至少证明双方
网络都是通的,只是不稳定。这种情况可以用rst包重新建立连接来解决。

在两次握手就可以建立连接的情况下,意味着服务端收到一个包就要建立一个连接,DoS攻击真是轻松...

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
18 [报告]
发表于 2015-06-12 10:34 |只看该作者
回复 17# zhaohongjian000

那你觉得现在3次握手服务器端是在收到了第几个包的时候建立链接?

论坛徽章:
12
巳蛇
日期:2013-09-16 15:32:242015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之约旦
日期:2015-02-11 14:38:37双鱼座
日期:2015-01-05 11:05:47戌狗
日期:2014-12-08 09:41:18戌狗
日期:2014-08-15 09:29:29双子座
日期:2014-08-05 09:17:17卯兔
日期:2014-06-08 15:32:18巳蛇
日期:2014-01-27 08:47:08白羊座
日期:2013-11-28 21:04:15巨蟹座
日期:2013-11-13 21:58:012015年亚洲杯之科威特
日期:2015-04-17 16:51:51
19 [报告]
发表于 2015-06-12 11:28 |只看该作者
回复 18# windoze


    服务端收到第三个包进入ESTABLISHED状态,虽然因为收到第一个包进入SYNRECVD状态还是可以DoS,但是SYNRECVD状态可以加快回收。
数据开始传输后就不能随便回收了,所以一个包就进入ESTABLISHED状态,抗DoS能力只会更低。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
20 [报告]
发表于 2015-06-12 13:56 |只看该作者
回复 19# zhaohongjian000

刚才回的贴怎么不见了?重发一遍

服务器端虽然在收到第3个包的时候才将链接状态设置为ESTABLISHED,但在收到第一个SYN时就已经分配了链接相关资源,从防SYN flooding这一点而言三次两次没什么差别。
要想防SYN flooding,就得像SCTP那样,第二次收到客户端发来的COOKIE-ECHO包的时候才分配链接相关资源。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP