概述
1,不需要等发送缓冲区的数据发送完,直接关闭socket,这个在close(socket)中使用。
socklen_t optlen;
struct linger sLinger;
optlen = sizeof(struct linger);
if(setsockopt(pTCP->tcpSock, SOL_SOCKET, SO_LINGER, (const char*)&sLinger, optlen) < 0)
{
err_handler();
}
2,发送缓冲区的设置,网上大多数用32k,防止循环发送?但其实实现的要比设置的大很多,经过测试为2倍,所以16k足矣。
optval = 16*1024;
optlen = sizeof(int);
if(setsockopt(pTCP->tcpSock, SOL_SOCKET, SO_SNDBUF, (const char*)&optval, optlen) < 0){
err_handler();
}
3,连接服务器的最大时间设置为20s,这个应发送时间超时时间。是写操作,和connect无关。
struct timeval timeo;
timeo.tv_sec = 20;
timeo.tv_usec = 0;
optlen = sizeof(timeo);
if(setsockopt(pTCP->tcpSock, SOL_SOCKET, SO_SNDTIMEO, &timeo, optlen) < 0){
err_handler();
}
4,心跳,tcp命令都是有心跳的,在心跳包处发一个空数据帧,
开启心跳监测,默认的太久了,不现实。
int keepAlive = 1;
setsockopt(pTCP->tcpSock, SOL_SOCKET, SO_KEEPALIVE, (void *)&keepAlive, sizeof(keepAlive));
在keepIdle秒内,没有任何数据来往,则进行监测
发包的时间间隔为keepInterval秒,探测尝试的次数为keepCount次,如果第一次探测包收到响应了,第二次就不发了(有的是tcp_keepalive_probes)
setsockopt(pTCP->tcpSock, SOL_TCP, TCP_KEEPIDLE, (void*)&keepIdle, sizeof(keepIdle));
setsockopt(pTCP->tcpSock, SOL_TCP, TCP_KEEPINTVL, (void *)&keepInterval, sizeof(keepInterval));
setsockopt(pTCP->tcpSock, SOL_TCP, TCP_KEEPCNT, (void *)&keepCount, sizeof(keepCount));
最后
以上就是包容丝袜为你收集整理的setsockopt的几个常用用法笔记的全部内容,希望文章能够帮你解决setsockopt的几个常用用法笔记所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复