- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
写入器程序使用固定缓冲区的多次写入发送几 MB(几乎没有延迟)。处理程序在 EPOLLOUT | 中注册。 EPOLLET
标志。
write(...)
调用返回了一些 ~3 EAGAIN(写入在下一个事件中重新开始)和 ~30 虚假 EPOLLOUT(在所有写入完成并且数据被认为已发送之后)。 好像没那么简单EPOLLOUT 在缓冲区从已满变为“可用空间”时生成。与 MTU 大小的相关性很有趣。问题:
1) 除非最后一次写入以 EAGAIN 代码结束,否则禁用 EPOLLOUT - 是正确的模式吗?
2) 更大的缓冲区或 MTU 建议传输更大的数据 block 产生更少的 TCP/IP 缓冲区更新和更少的事件。实践表明相反。任何人都可以对此有所了解吗?
最佳答案
EPOLLOUT 表示缓冲区中有空间。这并不意味着只是从无空间到有空间的过渡。您应该仅在从发送中获得 EAGAIN 后才使用它。否则,您只会得到毫无意义的 EPOLLOUT 事件流,因为发送缓冲区中几乎总是有空间。
关于您的 (1),是的,这才是正确的使用方式。只要写到你获得 EAGAIN,然后使用 EPOLLIUT 告诉你什么时候可以再次写。
关于c++ - EPOLLOUT | EPOLLET、虚假唤醒和 MTU,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21395074/
我试图弄清楚接受 OpenID 登录的网站如何无法通过简单的主机文件更新来指向伪造的 OpenID 提供商。 假设我想侵入 Joe Smith 的帐户,在这个例子中,假设他的 OpenID 提供商是
#include #include #include #include #include #include #include #include #include #include #define P
根据此讨论 - "RESTful API - Correct behavior when spurious/not requested parameters are passed in the req
如果编译为 Cand C++ 源代码,这个简单的代码片段会使用 g++ 4.7.0 生成“函数调用中缺少标记”警告。我相信这是编译器的错误,因为最终的 NULL值(value)就在那里。 #inclu
我读到,有时 && 运算符用于“短路”JavaScript,使其相信返回值 0 是 0 而不是 NaN,因为 0 在 JavaScript 中是一个虚假数字。我一直在四处寻找,想弄清楚这一切意味着什么
我正在使用 Borland(又名“Embarcodegearland”)C++Builder 2007 编译器,它有一个小错误,系统头文件中的某些 static const 项可能导致虚假的 "xyz
我是一名优秀的程序员,十分优秀!