C++,Linux,套接字发送性能

C++, Linux, socket send performance

本文关键字:性能 套接字 Linux C++      更新时间:2023-10-16

(原始问题列在下面(事实证明,我遇到了"消费者缓慢"的问题。由于我无法控制服务器程序,因此我尝试设置 setsockopt(m_sock,
IPPROTO_TCP,
TCP_NODELAY,
(字符 *( 和标志,
sizeof(int((;

但我仍然到了写入套接字需要几秒钟的地步。我错过了什么吗?原始问题:我创建了一个套接字

m_sock = socket(AF_INET, SOCK_STREAM, 0);

将其设置为非阻止:

int opts = fcntl ( m_sock, F_GETFL );
opts = ( opts | O_NONBLOCK ); 
fcntl ( m_sock, F_SETFL,opts );

然后发送

send(m_sock, v_pData, v_iDataSize, MSG_NOSIGNAL);

我发送大约 200 字节 ,每秒 5 次大约 2 分钟后,它会创建一个大的缓冲区和发送数据的大延迟。有没有办法提高发送性能?

第一次编辑:我正在添加更多关于如何创建和使用套接字的代码:

m_sock = socket ( AF_INET,
        SOCK_STREAM,
        0 );
if ( ! is_valid() )
  return false;
int on = 1;
if ( setsockopt ( m_sock, SOL_SOCKET, SO_REUSEADDR, ( const char* ) &on, sizeof ( on ) ) == -1 )
return false;

server = gethostbyname(host.c_str());
if (server == NULL) {   
    return false;
}
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
bcopy((char *)server->h_addr, 
     (char *)&serv_addr.sin_addr.s_addr,
     server->h_length);
serv_addr.sin_port = htons(portno);
set_non_blocking(true);// Code for set_non_blocking mentioned above

connect(m_sock,(struct sockaddr *) &serv_addr,sizeof(serv_addr))  ;

我使用以下方法写入套接字:

iOut = send(m_sock, v_pData, v_iDataSize, MSG_NOSIGNAL); 
特别是如果你

使用非阻塞 I/O(例如O_NONBLOCK(,你应该使用一些多路复用系统调用(如 .e.g. poll(2( 或较旧和过时的 select(2) (来确保您的套接字确实是

可读或可写的(即在可读时在 read(2( 或 recv(2( 上成功,或者在可写时在写 (2( 或发送 (2( 上成功(。

当然,如果您有多个套接字,则需要多路复用多个套接字。

简而言之,你需要一个事件循环(你可以使用提供一个的库,例如libevent或libev......(,或者像poll这样的多路复用系统调用有自己的循环......即使只有一个双向套接字,您也需要多路复用其输入和输出(具有阻塞或非阻塞 I/O(。

阅读一些好书,例如高级Linux编程以及一些 Linux 套接字教程和 Unix 网络编程书籍。

您的问题不够精确,无法回答。您应该提供更多代码,或者至少提供有关可疑系统调用的相关strace跟踪。

你可以看到内格尔算法在起作用。

只需设置TCP_NODELAY套接字选项:

int value = 1;
setsockopt(m_sock, IPPROTO_TCP, TCP_NODELAY, (void*)&value, sizeof(value));

我认为您不需要O_NONBLOCK,但这在很大程度上取决于您的用例。