c++ - TCP 接收使用率 100% CPU

标签 c++ multithreading sockets tcp cpu-usage

我通过tcp读取高频数据,代码如下

 while (1) {
    lrev = recv(fd, buff, 80, MSG_WAITALL);
    dowork();
 }

我正在通过一个线程运行这段代码,并将这个线程分配给一个特定的 CPU 核心。我可以看到特定核心使用 100% CPU。是因为 while(1) 循环吗?延迟目的是好是坏?

我的进程有 5 个线程,每个线程都在单独的核心上运行。我的总 CPU 使用率约为 400%。

谢谢

最佳答案

  • 我可以看到特定核心使用 100% CPU。是因为 while(1) 循环吗?

我们看不到您的所有代码,但是一段时间 (1) 处理非阻塞函数 通常会在其绑定(bind)的 CPU 上以 100% 的速度旋转

  • 对于延迟目的来说是好是坏?

对于延迟非常敏感的系统,这通常是好的(如果你想最小化数据包到达网卡和你开始处理它之间的时间/延迟)

但是您的调用接收 MSG_WAITALL might block ,这对您的延迟不利

This flag requests that the operation block until the full request is satisfied.

判断它是好是坏的唯一明确答案是:测量所有场景中的延迟。

编辑:

正如@Captain Obvlious 所评论的,您必须检查recv 返回的值

关于c++ - TCP 接收使用率 100% CPU,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23977053/

相关文章:

linux - 是否有系统调用或某种方式知道 Linux 中文件描述符的类型(例如常规文件 fd、套接字 fd、信号 fd、计时器 fd)?

c++ - dlopen : St9bad_alloc 错误

c++ - zmq::proxy 示例不起作用 ()

c# - 让多个线程轮询同一个串口的正确方法是什么?

c++ - operator new 是否在 THREAD 堆上分配?

c++ - C++ 中 HTTP GET 方法的速度

c++ - 为不明确的重载函数调用创建默认值

C++:用于超重对象的方便的基于指针数组的值迭代器

java - 如何通过使用暂停然后恢复或替代方案来同步线程之间的共享数据

c++ - 我可以用 C++ 编写基于以太网的网络程序吗?