我可以在接受新连接时设置TCP_NODELAY,如下所示:
fd = accept(listener, (struct sockaddr *)&sin, &slen);
if (fd < 0) {
perror("accept");
return;
}
if (fd > FD_SETSIZE) {
perror("fd > FD_SETSIZE\n");
return;
}
int onex = 1 ;
setsockopt(fd,IPPROTO_TCP,TCP_NODELAY,&onex,sizeof(onex));
并且还可以在连接到服务器后设置TCP_NODELAY:
bzero(&addr,sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_port = htons(port_to_order);
addr.sin_addr.s_addr = inet_addr(ipaddr);
if(connect(iConnCenter,(struct sockaddr *)&addr,sizeof(addr)) < 0){
printf(" to DBServer.exe socket to iConn error:== [%d]\n",port_to_order );
return -1 ;
}
int onex = 1 ;
setsockopt(iConnCenter,IPPROTO_TCP,TCP_NODELAY,&onex,sizeof(onex));
我有一个案例,我不能拥有连接的fd, 它是一个没有fd信息的库函数调用,以下是示例:
TraderApi* pTrader = TraderApi::CreateTraderApi();
TraderSpi spi(pTrader) ;
pTrader->Init(g_frontaddr,&spi);
然后使用pTrader-&gt; ReqService(structA)来发送数据,在这种情况下, 我没有机会获得连接fd,所以我不能 设置TCP_NODELAY。
我想知道在这种情况下,如何设置TCP_NODELAY?是否有配置文件或者我可以为此应用程序或此操作系统中发生的所有连接设置TCP_NODELAY?
该应用程序在运行RedHat 3.10.x86_64的框中。
编辑:
我用Google搜索并在
找到了list-open-fd.c的源代码示例https://github.com/ONsec-Lab/scripts/blob/master/list-open-fd.c
for( fd=0; fd<65535; fd++) {
if( fstat( fd, &st) == -1) {
continue;
}
switch (st.st_mode & S_IFMT) {
case S_IFBLK: printf("fd %d is block device\n", fd); break;
case S_IFCHR: printf("fd %d is character device\n", fd); break;
case S_IFDIR: printf("fd %d is directory\n", fd); break;
case S_IFIFO: printf("fd %d is FIFO/pipe\n", fd); break;
case S_IFLNK: printf("fd %d is symlink\n", fd); break;
case S_IFREG: printf("fd %d is regular file\n", fd); break;
case S_IFSOCK: printf("fd %d is socket\n", fd); break;
default: printf("fd %d is unknown?\n", fd); break;
}
} //for
我想我可以通过使用mode = IFSOCK检查fd来获得pTrader-&gt; Init创建的fd。
答案 0 :(得分:1)
如果TraderAPI
正在调用Linux套接字API,那么您可以使用自己的实现来拦截调用,这些实现将在底层API创建套接字后设置TCP_NODELAY
。您可能需要通过共享库提供截获的呼叫,并通过LD_PRELOAD
加载。
要调用真正的套接字API,您可以在dlopen
和libc.so
上使用dlsym
您正在拦截的套接字API并存储函数指针。然后在需要调用真实API时调用它们。