TCP是面向连接的协议,连接的建立和释放是每一次面向连接的通信中必不可少的过程。TCP连接的管理就是使连接的建立和释放都能正常地进行。
TCP连接的建立—三次握手建立TCP连接

① 若主机A中运行了一个客户进程,当它需要主机B的服务时,就发起TCP连接请求,并在所发送的分段中用SYN=1表示连接请求,并产生一个随机发送序号x,如果连接成功,A将以x作为其发送序号的初始值:seq=x。主机B收到A的连接请求报文,就完成了第一次握手。
SYN=1表示连接请求随机发送序号x,如果连接成功,A将以x作为其发送序号的初始值:seq=x② 主机B如果同意建立连接,则向主机A发送确认报文,用SYN=1和ACK=1表示同意连接,用ack=x+1表明正确收到A的序号为x的连接请求,同时也为自己选择一个随即发送序号seq=y作为它的发送序号的初始值。主机A收到主机B的请求应答报文,完成第二次握手。
SYN=1和ACK=1表示同意连接ack=x+1表明正确收到A的序号为x的连接请求随即发送序号seq=y作为它的发送序号的初始值③ 主机A收到主机B的确认后,还要向主机B发出确认,用ACK=1表示同意连接,用ack=y+1表明收到B对连接的应答,同时发送A的第一个数据seq=x+1。主机B收到主机A的确认报文,完成第三次握手。此时双方就可以使用协定好的参数以及各自分配的资源进行正常的数据通信了。
ACK=1表示同意连接ack=y+1表明收到B对连接的应答,同时发送A的第一个数据seq=x+1为了确认双方的接收能力和发送能力都正常。
通过第三次握手,主要目的是为了防止已失效的连接请求报文段突然又传送到了主机B,因而产生错误。
所谓“失效的连接请求报文段”是指一端(如A)发出的连接请求,由于没有在允许的时间内传送到目的方(如B),使得发送方不得不又发送一个新的连接请求报文段。
而在新的连接请求建立并传送完数据将连接释放后,出现了一种情况,即主机A发出的第一个连接请求报文段迟迟到达了B。本来,这是一个已经失效的报文段,但主机B收到此失效的连接请求报文段后,就误认为是主机A又发出一次新的连接请求,于是向主机A发出确认报文段,同意建立连接。主机A由于并没有要求建立连接,因此不会理睬主机B的确认,也不会向主机B发送数据。但主机B却以为传输连接就这样建立了,并一直等待主机A发来数据。主机B的许多资源就这样白白浪费了。
采用三次握手机制可以防止上述现象的发生。在上述情况下,主机A就不会理睬主机B发来的确认,也不会向主机B发出确认报文,连接也就建立不起来。
TCP连接的拆除—用四次握手释放TCP连接

① 在数据传输结束后,通信双方都可以释放连接。在上图,主机A的应用进程先向其TCP发出连接释放请求,并不再发送数据。TCP通知对方要释放从A到B这个方向的连接,便发送FIN=1的报文段给主机B,其序号u等于已传送过的数据的最后一个字节的序号加1。这时A处于等待B确认的状态。
② 主机B的TCP收到释放连接的通知后,即发出确认,其确认序号ack=u+1,而这个报文段自己的序号是v,等于主机B已经传送过的数据的最后一个字节的序号加1,同时通知高层的应用进程。这样,从A到B的连接就释放了,连接处于半关闭状态,即主机A已经没有数据要发送了,但主机B若发送数据,A仍要接收。也就是说,从B到A这个方向的连接并未关闭,可能还要等待一段时间。等待是因为若主机B还有一些数据要发往主机A,则可以继续发送,主机A只要收到数据,仍应向主机B发送确认。
③ 在主机B向主机A的数据发送结束后,其应用进程就通知TCP释放连接。主机B发出的连接释放报文段必须将FIN置1,先假设B的序号为w(在半关闭状态下主机B可能又发送了一些数据),同时还必须重复上次已发送过的确认序号ack=u+1。这时主机B进入等待A的确认状态。
④ 主机A收到B的连接释放报文段后,必须对此发出确认,在确认报文段中将ACK置1,给出确认序号ack=w+1,而自己的序号是seq=u+1。从B到A的连接被释放掉。主机A的TCP再向其应用进程报告,整个连接已经全部释放。
TCP 使用四次挥手的原因是因为 TCP 的连接是全双工的,所以需要双方分别释放到对方的连接,单独一方的连接释放,只代 表不能再向对方发送数据,连接处于的是半释放的状态。
最后一次挥手中,客户端会等待一段时间再关闭的原因,是为了防止发送给服务器的确认报文段丢失或者出错,从而导致服务器 端不能正常关闭。
这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
网络编程套接字网络编程基础知识理解源`IP`地址和目的`IP`地址理解源MAC地址和目的MAC地址认识端口号理解端口号和进程ID理解源端口号和目的端口号认识`TCP`协议认识`UDP`协议网络字节序socket编程接口`sockaddr``UDP`网络程序服务器端代码逻辑:需要用到的接口服务器端代码`udp`客户端代码逻辑`udp`客户端代码`TCP`网络程序服务器代码逻辑多个版本服务器单进程版本多进程版本多线程版本线程池版本服务器端代码客户端代码逻辑客户端代码TCP协议通讯流程TCP协议的客户端/服务器程序流程三次握手(建立连接)数据传输四次挥手(断开连接)TCP和UDP对比网络编程基础知识
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU
我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我
给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in
给定两个大小相等的数组,如何找到不考虑位置的匹配元素的数量?例如:[0,0,5]和[0,5,5]将返回2的匹配项,因为有一个0和一个5共同;[1,0,0,3]和[0,0,1,4]将返回3的匹配项,因为0有两场,1有一场;[1,2,2,3]和[1,2,3,4]将返回3的匹配项。我尝试了很多想法,但它们都变得相当粗糙和令人费解。我猜想有一些不错的Ruby习惯用法,或者可能是一个正则表达式,可以很好地回答这个解决方案。 最佳答案 您可以使用count完成它:a.count{|e|index=b.index(e)andb.delete_at
是否可以在不实际下载文件的情况下检查文件是否存在?我有这么大的(~40mb)文件,例如:http://mirrors.sohu.com/mysql/MySQL-6.0/MySQL-6.0.11-0.glibc23.src.rpm这与ruby不严格相关,但如果发件人可以设置内容长度就好了。RestClient.get"http://mirrors.sohu.com/mysql/MySQL-6.0/MySQL-6.0.11-0.glibc23.src.rpm",headers:{"Content-Length"=>100} 最佳答案
我在这方面尝试了很多URL,在我遇到这个特定的之前,它们似乎都很好:require'rubygems'require'nokogiri'require'open-uri'doc=Nokogiri::HTML(open("http://www.moxyst.com/fashion/men-clothing/underwear.html"))putsdoc这是结果:/Users/macbookair/.rvm/rubies/ruby-2.0.0-p481/lib/ruby/2.0.0/open-uri.rb:353:in`open_http':404NotFound(OpenURI::HT