0

我在 python 中编写了一个 epoll 包装器,它工作得很好,但最近我发现性能对于大包发送并不理想。我查看了代码,发现实际上有很多错误

Traceback (most recent call last):
  File "/Users/dawn/Documents/workspace/work/dev/server/sandbox/single_point/tcp_epoll.py", line 231, in send_now
    num_bytes = self.sock.send(self.response)
error: [Errno 35] Resource temporarily unavailable

并且之前如文件所述将其静音,因此我的发送功能是这样完成的:

def send_now(self):
    '''send message at once'''
    st = time.time()
    times = 0
    while self.response != '':
        try:
            num_bytes = self.sock.send(self.response)
            l.info('msg wrote %s %d : %r size %r',self.ip,self.port,self.response[:num_bytes],num_bytes)
            self.response = self.response[num_bytes:]                    
        except socket.error,e:
            if e[0] in (errno.EWOULDBLOCK,errno.EAGAIN):
                #here I printed it, but I silent it in normal days
                #print 'would block, again %r',tb.format_exc()
                break
            else:
                l.warning('%r %r socket error %r',self.ip,self.port,tb.format_exc())
            #must break or cause dead loop
            break                    
        except:
            #other exceptions
            l.warning('%r %r msg write error %r',self.ip,self.port,tb.format_exc())
            break    
        times += 1
    et = time.time()

我用谷歌搜索它,并说它是由临时网络缓冲区用完引起的那么我怎样才能手动有效地检测到这个错误而不是进入异常阶段呢?

因为它会导致很多时间来处理/处理异常。

4

1 回答 1

1

用于select查看套接字是否已准备好进行读取或写入。

于 2011-06-22T08:07:55.847 回答