我有一个有多个客户端的服务器。模拟网络拥塞严重。我发现服务器在收到三次握手的 ACK 段后重置了一些 TCP 连接。但是当网络状况良好时不会发生这种情况。
我发现三次握手的ACK比SYN-ACK要晚3.5s左右收到。 是不是因为三次握手SYN-ACK超时?如果SYN-ACK超时,为什么不重新发送SYN-ACK。
感谢您的任何建议。
最佳答案
这看起来与 SYN cookies 有关.
当 Linux 主机接收到过多的 SYN 流量时,它会激活 SYN cookies 机制。
当启用 SYN cookie 时,服务器通过发出一个 SYN-ACK 段来响应 SYN,其中包含在 TCP sequence 字段中编码的特定数据。在该字段中,它对时间戳、MSS 和两个端点(本地和远程 IP 和端口)的加密哈希以及时间戳进行编码。
这样做是为了让服务器此时不必存储有关连接的任何信息,它只需发送答案并忘记它。
然后,当客户端用它的 ACK 应答时,服务器检查 ack 字段中的散列(客户端的 ack 是服务器的序列)。如果正确,它会创建与存储在该字段中的数据的连接。
SYN cookie 解释了为什么服务器在超时时不重新发送 SYN-ACK 数据包。
但是,为什么收到ACK后就重置呢?
也许客户端(或服务器)位于修改端口的 NAT 后面,并且 NAT 也变得拥塞,因此它无法将最终的 ACK 链接到先前的 SYN,并分配一个新的源端口。当服务器收到它时,它会重置连接(是否启用 SYN cookie 无关紧要)。
或者服务器进程可能没有以连接到达的速度接受连接,内核队列已满,新的队列以这种方式被丢弃。
关于tcp - 收到三次握手的ACK后立即重置TCP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33026669/
简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und
有人知道在发布新版本的Ruby和Rails时收到电子邮件的方法吗?他们有邮件列表,RubyonRails有一个推特,但我不想听到那些随之而来的喧嚣,我只想知道什么时候发布新版本,尤其是那些有安全修复的版本。 最佳答案 从therailsblog获取提要.http://weblog.rubyonrails.org/feed/atom.xml 关于ruby-on-rails-如何在发布新的Ruby或Rails版本时收到通知?,我们在StackOverflow上找到一个类似的问题:
我刚刚更新了我的gem,当我尝试运行Guard时,出现以下错误:Guard::RSpecDEPRECATIONWARNING:The:clioptionisdeprecated.Pleasecustomizethenew:cmdoptiontofityourneed.这是我的Guard文件:guard'rspec',cli:'--drb'dowatch(%r{^spec/.+_spec\.rb$})watch(%r{^lib/(.+)\.rb$}){|m|"spec/lib/#{m[1]}_spec.rb"}watch('spec/spec_helper.rb'){"spec"}#Ra
我试图制作一个可执行文件,它通过Thin作为守护进程启动Sinatra应用程序。我正在使用此代码通过Sinatra应用程序调用Thin:#!/usr/bin/envrubyrequire'thin'require'app.rb'server=::Thin::Server.new('127.0.0.1',9999,App)server.log_file='tmp/thin.log'server.pid_file='tmp/thin.pid'server.daemonize这是我执行脚本时得到的日志输出:>>WritingPIDtotmp/thin.pid>>Exiting!服务器正常启动
在RSpec测试中,我创建了一个记录,其中包含多个内存值。foo.reload对对象的属性按预期工作,但内存的属性仍然存在。到目前为止,它通过完全重新创建对象来工作:foo=Foo.find(123)但在我的例子中,查找记录的逻辑实际上更复杂。什么是完全重新加载记录并删除所有内存值的好方法? 最佳答案 好的方法是您已有的方法:完全重新创建对象。您不能以任何简单的“Rails”方式“重新加载”对象的内存值,因为内存属性不是Rails或ActiveRecord的功能。两者都不知道您是如何内存方法的。
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发送确认报
在我的用户模型中我有:acts_as_authenticdo|c|c.perishable_token_valid_for=30.minutesend在我的应用程序Controller中,我有标准样板代码:defcurrent_user_sessionreturn@current_user_sessionifdefined?(@current_user_session)@current_user_session=UserSession.findenddefcurrent_userreturn@current_userifdefined?(@current_user)@current_u
如何在Ruby中从内存中完全删除一个类?我正在处理两个文件:#foo.rbrequire'expensive_library'classFoo和:#foo_tests.rbrequire'foo'require'test/unit'classfoo_testsExpensiveLibrary很贵;加载需要超过15秒。这对于在开发过程中重复运行测试来说太长了(测试套件的其余部分用时不到1秒)。我通过启动Pry并编写一个函数来加载这两个文件并调用Test::Unit:Autorunner.run来解决昂贵库的加载时间问题。这在第一次运行的测试中仍然有15秒的暂停,但随后的测试运行每次运行不
在我的ramaze应用程序上显示£符号时,我收到“不兼容的字符编码:CP850和UTF-8”。我怎样才能摆脱这个错误?我的head标签中有UTF-8元标签。当我用键盘输入£符号时会发生这种情况。看。我已将以下代码放入我的ruby文件中,但没有解决问题。#encoding:UTF-8Encoding.default_external='utf-8'Encoding.default_internal=Encoding::UTF_8 最佳答案 尝试强制编码以查看是否可以解决问题:your_string.force_encoding(:
我尝试重现http://railscasts.com/episodes/346-wizard-forms-with-wicked轨道广播。我尝试通过四步向导创建报告。我生成Controllerreport_steps将resources:report_steps添加到routes.rb创建步骤View现在我尝试调用它(就像在railscats中通过在浏览器的地址栏中键入localhost:3000/report_steps/step1一样)并接收:RoutingErroruninitializedconstantReportStepsController::Wicked问题是什么?我使