我们正在使用 LoadRunner 在基于 tcp 的多线程服务器应用程序上进行压力测试。最近我们遇到一个恼人的问题:
客户端在一些周期后收到错误报告——“10054 - 连接被对等方重置”。通过抓取客户端的数据包,我们发现客户端收到了来自服务器的RST。
有什么奇怪的是我们没有从服务器端调用任何 close() 或 shutdown()(用于测试目的),客户端仍然收到 RST 数据包和 10054 错误?!!
下面是我抓到的数据包:
这是我的问题,如有任何帮助,我们将不胜感激!
Q1。为什么服务器会向客户端发送 RST ,而它甚至没有从服务器端调用任何 close() 或 shutdown() 到套接字?
Q2。 [重复 Q1,请跳过]当客户端和服务器都没有调用任何 close() 或关闭时,服务器将在什么情况下发送 RST?
Q3。我是否可以重新编译内核并在 TCP 堆栈中打印一些日志?我想知道它发送 RST 数据包时发生了什么。
[更新]
将 listen(BACKLOG) 从 BackLog=100 增加到 BackLog=1000,会将错误从大约 50/小时显着减少到 1~2/10 小时。为什么?
[更新2]
1. 这是一个接受 soap 请求并返回的 gSOAP 服务器
1~2 KB 的数据给客户端。
2. 我们检查了来自客户端的数据包,没有来自服务器的 FIN 标志,这证明服务器从不调用任何 close() 或
关机()。
3. 我们使用 LoadRunner 对 400 个用户进行并行 soap 请求的压力测试,频率为每个请求 80,000 个
小时平均值。
4. Packet 4内容无异常,以下为部分内容
POST /AddressBookController.php HTTP/1.1
Host: 192.168.11.30:10000
User-Agent: gSOAP/2.7
Content-Type: text/xml; charset=utf-8
Content-Length: 1470
Connection: close
Cookie: sessionId=a23b15dcc14bb1d8f9f6bf3c4ed728d90c4c3939143866821152918211
SOAPAction: ""
<?xml version="1.0" encoding="UTF-8"?>
......
最佳答案
Q1. Why would the server send RST to the client while it doesn't even call any close() or shutdown() to the socket?
因为服务器已经决定关闭连接但是客户端继续发送。或者,服务器在仍有未读数据时关闭了它的套接字。
Q2. In what condition will a RST be sent by the server when both the client and server haven't called any close() or shutdown?
这又是同一个问题。
Q3. Is it possible for me to recompile the kernel and print some log in the TCP stack? I want to know what happened when it sends a RST packet.
不,你想知道它发送RST数据包之前发生了什么。
问题似乎出在您的客户身上。它肯定会在某个时候关闭连接。
编辑 在这种情况下,您似乎在数据包 #4 中发送了一些奇怪的东西(非 HTTP),这导致服务器关闭了连接。这是什么?
关于linux - 为什么在没有调用 Close() 或 Shutdown() 时发送 RST?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31808285/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我有一个奇怪的问题:我在rvm上安装了rubyonrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(
它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串