Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4029164
  • 博文数量: 366
  • 博客积分: 9916
  • 博客等级: 中将
  • 技术积分: 7195
  • 用 户 组: 普通用户
  • 注册时间: 2011-05-29 23:27
个人简介

简单!

文章分类

全部博文(366)

文章存档

2013年(51)

2012年(269)

2011年(46)

分类: C/C++

2012-02-07 15:43:40

      在linux进行非阻塞的socket接收数据时经常出现Resource temporarily unavailable,errno代码为11(EAGAIN),这表明你在非阻塞模式下调用了阻塞操作,在该操作没有完成就返回这个错误,这个错误不会破坏socket的同步,不用管它,下次循环接着recv就可以。 对非阻塞socket而言,EAGAIN不是一种错误。在VxWorks和Windows上,EAGAIN的名字叫做EWOULDBLOCK。

      另外,如果出现EINTR即errno为4,错误描述Interrupted system call,操作也应该继续。

      最后,如果recv的返回值为0,那表明连接已经断开,我们的接收操作也应该结束。

阅读(29203) | 评论(2) | 转发(2) |
给主人留下些什么吧!~~

scq2099yt2013-06-24 11:20:03

如果客户端搞破坏一直不读数据,那么服务器该如何处理EAGAIN?

txgc_wm2012-02-08 18:29:11

 在Linux中使用非阻塞的socket的情形下。

(一)发送时

  当客户通过Socket提供的send函数发送大的数据包时,就可能返回一个EGGAIN的错误。该错误产生的原因是由于send 函数中的size变量大小超过了tcp_sendspace的值。tcp_sendspace定义了应用在调用send之前能够在kernel中缓存的数据量。当应用程序在socket中设置了O_NDELAY或者O_NONBLOCK属性后,如果发送缓存被占满,send就会返回EAGAIN的错误。

  为了消除该错误,有三种方法可以选择:
  1.调大tcp_sendspace,使之大于send中的size参数
  ---no -p -o tcp_sendspace=65536

  2.在调用send前,在setsockopt函数中为SNDBUF设置更大的值

  3.使用write替代send,因为write没有设置O_NDELAY