- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的客户端-服务器应用程序有问题。由于我几乎没有理智的想法来解决它,我正在寻求帮助。我现在已经偶然发现了大约三到四次所描述的情况。提供的数据来自上次失败,当时我已经打开了所有可能的日志记录、消息转储等。
系统说明
1) 客户。在 Windows 下工作。我假设它的工作没有问题(从日志来看)
2) 服务器。在 Linux (RHEL 5) 下工作。这是我有问题的服务器。
3) 客户端和服务器之间维持两条连接:一条命令,一条用于数据发送。两者都是异步工作的。两个连接都存在于一个线程和一个 boost::asio::io_service
.
4) 从客户端发送到服务器的数据是由'\0'分隔的消息。
5) 数据负载约为 50 Mb/小时,全天 24 小时。
6) 使用 boost::asio::async_read_until
在服务器端读取数据带有相应的分隔符
问题
- 两天系统按预期工作
- 第三天在 18:55
服务器从客户端读取最后一条消息,然后停止读取它们。日志中没有关于新数据的信息。
- 来自 18:55
至09:00
(14 小时) 客户报告没有错误。所以它成功发送了数据(大约 700 Mb)并且没有出现错误。
- 在 08:30
我开始调查一个问题。服务器进程处于事件状态,服务器和客户端之间的连接也处于事件状态。
- 在 09:00
我使用 gdb
附加到服务器进程.服务器处于 sleep 状态,等待来自系统的一些信号。我相信我不小心按了 Ctrl + C 并且可能有一些消息。
- 后来在日志中我发现了类似“系统调用中断”的消息。之后,与客户端的两个连接都被删除了。客户端重新连接,服务器开始正常工作。
- 服务器处理的第一条消息的时间戳为 18:57
在客户端。所以在重新开始正常工作后,服务器并没有丢弃所有到 09:00
的消息。 ,它们被存储在某个地方,然后相应地处理它们。
我尝试过的事情
- 上面的模拟场景。当服务器转储所有传入消息时,我编写了一个小脚本,将自己呈现为客户端并将所有消息再次发送回服务器。服务器丢弃了 out of memory
错误,但不幸的是,这是因为数据负载高(这次大约是 3 Gb/小时),而不是因为同样的错误。因为是星期五晚上,我没有时间正确地重复实验。
- 尽管如此,我还是通过 Valgrind 运行服务器来检测可能的内存泄漏。没有发现任何严重的问题(除了服务器由于高负载而被丢弃的事实),没有巨大的内存泄漏。
问题
- 客户端发送而服务器没有得到的这些 700 Mb 数据在哪里?为什么当服务器重新启动连接时它们是持久的并且没有丢失?
- 在我看来,问题与服务器没有收到来自 boost::asio::io_service
的消息有关。 .缓冲区被数据填充,但没有调用读取处理程序。这可能是操作系统方面的问题吗?异步调用可能有问题?如果是这样,如何检查?
- 我可以做些什么来检测问题的根源?正如我所说,我已经没有理智的想法了,而且每个实验的时间成本都很高(大约需要两到三天才能使系统达到所描述的状态),所以我需要尽可能多地对实验进行检查我可以。
对于我可以用来解决错误的任何想法,我将不胜感激。
更新:好的,似乎错误是同步的write
留在异步客户端-服务器交互的中间。由于两个连接都存在于一个线程中,因此此同步 write
由于某种原因阻塞了线程,并且命令和数据连接上的所有交互都停止了。因此,我将其更改为异步版本,现在它似乎可以工作了。
最佳答案
As i said I've run out of sane ideas and each experiment costs very much in terms of time (it takes about two or three days to get the system to described state)
关于c++ - 异步服务器在没有明显原因的情况下停止从客户端获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7860654/
我需要您在以下方面提供帮助。近一个月来,我一直在阅读有关任务和异步的内容。 我想尝试在一个简单的 wep api 项目中实现我新获得的知识。我有以下方法,并且它们都按预期工作: public Htt
我的可执行 jar 中有一个模板文件 (.xls)。不需要在运行时我需要为这个文件创建 100 多个副本(稍后将唯一地附加)。用于获取 jar 文件中的资源 (template.xls)。我正在使用
我在查看网站的模型代码时对原型(prototype)有疑问。我知道这对 Javascript 中的继承很有用。 在这个例子中... define([], function () { "use
影响我性能的前三项操作是: 获取滚动条 获取偏移高度 Ext.getStyle 为了解释我的应用程序中发生了什么:我有一个网格,其中有一列在每个单元格中呈现网格。当我几乎对网格的内容做任何事情时,它运
我正在使用以下函数来获取 URL 参数。 function gup(name, url) { name = name.replace(/[\[]/, '\\\[').replace(/[\]]/,
我最近一直在使用 sysctl 来做很多事情,现在我使用 HW_MACHINE_ARCH 变量。我正在使用以下代码。请注意,当我尝试获取其他变量 HW_MACHINE 时,此代码可以完美运行。我还认为
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 9 年前。 要求提供代码的问题必须表现出对所解决问题的最低限度的理解。包括尝试过的解决方案、为什么
由于使用 main-bower-files 作为使用 Gulp 的编译任务的一部分,我无法使用 node_modules 中的 webpack 来require 模块code> dir 因为我会弄乱当
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我使用 Gridlayout 在一行中放置 4 个元素。首先,我有一个 JPanel,一切正常。对于行数变大并且我必须能够向下滚动的情况,我对其进行了一些更改。现在我的 JPanel 上添加了一个 J
由于以下原因,我想将 VolumeId 的值保存在变量中: #!/usr/bin/env python import boto3 import json import argparse import
我正在将 MSAL 版本 1.x 更新为 MSAL-browser 的 Angular 。所以我正在尝试从版本 1.x 迁移到 2.X.I 能够成功替换代码并且工作正常。但是我遇到了 acquireT
我知道有很多关于此的问题,例如 Getting daily averages with pandas和 How get monthly mean in pandas using groupby但我遇到
This is the query string that I am receiving in URL. Output url: /demo/analysis/test?startDate=Sat+
我正在尝试使用 javascript 中的以下代码访问 Geoserver 层 var gkvrtWmsSource =new ol.source.ImageWMS({ u
API 需要一个包含授权代码的 header 。这就是我到目前为止所拥有的: var fullUrl = 'https://api.ecobee.com/1/thermostat?json=\{"s
如何获取文件中的最后一个字符,如果是某个字符,则删除它而不将整个文件加载到内存中? 这就是我目前所拥有的。 using (var fileStream = new FileStream("file.t
我是这个社区的新手,想出了我的第一个问题。 我正在使用 JSP,我成功地创建了 JSP-Sites,它正在使用jsp:setParameter 和 jsp:getParameter 具有单个字符串。
在回答 StoreStore reordering happens when compiling C++ for x86 @Peter Cordes 写过 For Acquire/Release se
我有一个函数,我们将其命名为 X1,它返回变量 Y。该函数在操作 .on("focusout", X1) 中使用。如何获取变量Y?执行.on后X1的结果? 最佳答案 您可以更改 Y 的范围以使其位于函
我是一名优秀的程序员,十分优秀!