setsockopt()函数和getsockopt()函数 |
您所在的位置:网站首页 › getsockopt函数 › setsockopt()函数和getsockopt()函数 |
setsockopt()函数功能介绍
int setsockopt(int sock, int level, int optname, const void *optval, socklen_t optlen); 功能描述: 获取或者设置与某个套接字关联的选项。选项可能存在于多层协议中,它们总会出现在最上面的套接字层。当操作套接字选项时,选项位于的层和选项的名称必须给出。为了操作套接字层的选项,应该 将层的值指定为SOL_SOCKET。为了操作其它层的选项,控制选项的合适协议号必须给出。例如,为了表示一个选项由TCP协议解析,层应该设定为协议 号TCP。 getsockopt()函数功能介绍getsockopt()函数功能是获取一个套接口选项。 原型: int getsockopt(int sock, int level, int optname, void *optval, socklen_t *optlen);
参数: sock:将要被设置或者获取选项的套接字。 level:选项所在的协议层。 optname:需要访问的选项名。 optval:对于getsockopt(),指向返回选项值的缓冲。对于setsockopt(),指向包含新选项值的缓冲。 optlen:对于getsockopt(),作为入口参数时,选项值的最大长度。作为出口参数时,选项值的实际长度。对于setsockopt(),现选项的长度。
返回说明: 成功执行时,返回0。失败返回-1,errno被设为以下的某个值 EBADF:sock不是有效的文件描述词 EFAULT:optval指向的内存并非有效的进程空间 EINVAL:在调用setsockopt()时,optlen无效 ENOPROTOOPT:指定的协议层不能识别选项 ENOTSOCK:sock描述的不是套接字
参数详细说明: level指定控制套接字的层次.可以取三种值: 1)SOL_SOCKET:通用套接字选项. 2)IPPROTO_IP:IP选项. 3)IPPROTO_TCP:TCP选项. optname指定控制的方式(选项的名称),我们下面详细解释 optval获得或者是设置套接字选项.根据选项名称的数据类型进行转换 SOL_SOCKET说明 选项名称 说明 数据类型 ======================================================================== SO_BROADCAST 允许发送广播数据 int SO_DEBUG 允许调试 int SO_DONTROUTE 不查找路由 int SO_ERROR 获得套接字错误 int SO_KEEPALIVE 保持连接 int SO_LINGER 延迟关闭连接 struct linger SO_OOBINLINE 带外数据放入正常数据流 int SO_RCVBUF 接收缓冲区大小 int SO_SNDBUF 发送缓冲区大小 int SO_RCVLOWAT 接收缓冲区下限 int SO_SNDLOWAT 发送缓冲区下限 int SO_RCVTIMEO 接收超时 struct timeval SO_SNDTIMEO 发送超时 struct timeval SO_REUSERADDR 允许重用本地地址和端口 int SO_TYPE 获得套接字类型 int SO_BSDCOMPAT 与BSD系统兼容 int IPPROTO_IP说明 ======================================================================== IP_HDRINCL 在数据包中包含IP首部 int IP_OPTINOS IP首部选项 int IP_TOS 服务类型 IP_TTL 生存时间 int IPPRO_TCP说明 ======================================================================== TCP_MAXSEG TCP最大数据段的大小 int TCP_NODELAY 不使用Nagle算法 int ======================================================================== 返回说明: 成功执行时,返回0。失败返回-1,errno被设为以下的某个值 EBADF:sock不是有效的文件描述词 EFAULT:optval指向的内存并非有效的进程空间 EINVAL:在调用setsockopt()时,optlen无效 ENOPROTOOPT:指定的协议层不能识别选项 ENOTSOCK:sock描述的不是套接字
SO_RCVBUF和SO_SNDBUF每个套接口都有一个发送缓冲区和一个接收缓冲区,使用这两个套接口选项可以改变缺省缓冲区大小。 // 接收缓冲区 int nRecvBuf=32*1024; //设置为32K setsockopt(s,SOL_SOCKET,SO_RCVBUF,(const char*)&nRecvBuf,sizeof(int)); //发送缓冲区 int nSendBuf=32*1024;//设置为32K setsockopt(s,SOL_SOCKET,SO_SNDBUF,(const char*)&nSendBuf,sizeof(int)); 注意: 当设置TCP套接口接收缓冲区的大小时,函数调用顺序是很重要的,因为TCP的窗口规模选项是在建立连接时用SYN与对方互换得到的。对于客户,O_RCVBUF选项必须在connect之前设置;对于服务器,SO_RCVBUF选项必须在listen前设置。
结合原理说明: 1.每个套接口都有一个发送缓冲区和一个接收缓冲区。 接收缓冲区被TCP和UDP用来将接收到的数据一直保存到由应用进程来读。 TCP:TCP通告另一端的窗口大小。 TCP套接口接收缓冲区不可能溢出,因为对方不允许发出超过所通告窗口大小的数据。 这就是TCP的流量控制,如果对方无视窗口大小而发出了超过窗口大小的数据,则接 收方TCP将丢弃它。 UDP:当接收到的数据报装不进套接口接收缓冲区时,此数据报就被丢弃。UDP是没有流量控制的;快的发送者可以很容易地就淹没慢的接收者,导致接收方的UDP丢弃数据报。 2.我们经常听说tcp协议的三次握手: 第一次:客户端发送连接请求给服务器,服务器接收; 第二次:服务器返回给客户端一个确认码,附带一个从服务器到客户端的连接请求,客户机接收,确认客户端到服务器的连接. 第三次:客户机返回服务器上次发送请求的确认码,服务器接收,确认服务器到客户端的连接. 我们可以看到: 1. tcp的每个连接都需要确认. 2. 客户端到服务器和服务器到客户端的连接是独立的. 我们再想想tcp协议的特点:连接的,可靠的,全双工的,实际上tcp的三次握手正是为了保证这些特性的实现
int getsockopt(int socket, int level, int option_name,void *restrict option_value, socklen_t *restrict option_len); 功能:获取一个套接字的选项 参数: socket:文件描述符 level:协议层次 SOL_SOCKET 套接字层次 IPPROTO_IP ip层次 IPPROTO_TCP TCP层次 option_name:选项的名称(套接字层次) SO_BROADCAST 是否允许发送广播信息 SO_REUSEADDR 是否允许重复使用本地地址 SO_SNDBUF 获取发送缓冲区长度 SO_RCVBUF 获取接收缓冲区长度 SO_RCVTIMEO 获取接收超时时间 SO_SNDTIMEO 获取发送超时时间 option_value:获取到的选项的值 option_len:value的长度 返回值: 成功:0 失败:-1 int opt_val; socklen_t opt_len = sizeof(opt_val); if(getsockopt(sockfd, SOL_SOCKET, SO_SNDBUF, &opt_val, &opt_len) < 0) { perror("fail to getsockopt"); } printf("send_buf = %dk\n", opt_val / 1024);最后打印获取发送缓存区的大小; |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |