我可以在接受新连接的同时设置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-> 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-> Init创建的fd。
如果TraderAPI
正在调用Linux套接字API,则可以使用您自己的实现来拦截这些调用,该实现将TCP_NODELAY
在基础API创建套接字之后进行设置。您可能需要通过共享库提供被拦截的呼叫,并通过进行加载LD_PRELOAD
。
要调用真正的套接字API,可以使用dlopen
onlibc.so
和dlsym
要拦截的套接字API并存储函数指针。然后在需要调用真实API时调用它们。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句