twisted 框架 TCP发送问题 self.transport.write() 函数机制

zrd634550666 2013-11-16 11:43:57
如题,在twisted框架中,一个服务器调用发送函数 self.transport.write(),这个wirte的发送机制是什么,
是发送出去的同时存储在消息列队缓存中防止丢失,还是说消息列队满了或者间隔多少时间做发送,客户端成功接收了在清楚缓存,现在搞不懂是调用了就发送出去,存储消息缓存中,还是说可能我反复调用write()会有发不出去的消息!
from twisted.internet.protocol import Protocol
class DragonSlayer(Protocol):
#得到连接
def connectionMade(self):
print 'Got connection from', self.transport.client
#丢失连接
def connectionLost(self, reason):
pass
print self.transport.client, 'disconnected'
#收发数据
def dataReceived(self, data):
self.transport.write(data)


现在给前端推送数据,链接后有一个问题,第一次推送,能收到,第二次推送,客户端没反映,第三次推送,客户端收到两个(包括第二次没收到的那个),这个问题是write()没发出去,还是前端在缓存列队中没接收下来!

求大神解释下write()的发送机制
...全文
1167 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
zrd634550666 2013-11-22
  • 打赏
  • 举报
回复
引用 4 楼 angel_su 的回复:
按faq说法,你换个客户端,或自己简单写一个试试先...
恩,问题就是write()的机制问题,确实是没有发出去,有点类似nagle算法的原因,换成 self.transport.getHandle()。sendall(data)就没问题了!谢谢版主回复!
zrd634550666 2013-11-18
  • 打赏
  • 举报
回复
引用 1 楼 angel_su 的回复:
Why does it take a long time for data I send with transport.write to arrive at the other side of the connection?
在局域网的同一个网关下,理论上不会出现连包!这种情况估计就是代码问题,请问twisted 的TCP这个协议用的socket是什么类型的,self.transport.write(data) 关于这句发送有没有api的方法可以得到缓冲区大小或者发送数据长度,怎么确定是不是发送出去了或者卡在缓冲区之类的方法,新手,不太了解twisted框架的方法!
zrd634550666 2013-11-18
  • 打赏
  • 举报
回复
在局域网的同一个网关下,理论上不会出现连包!这种情况估计就是代码问题,请问twisted 的TCP这个协议用的socket是什么类型的,self.transport.write(data) 关于这句发送有没有api的方法可以得到缓冲区大小或者发送数据长度,怎么确定是不是发送出去了或者卡在缓冲区之类的方法,新手,不太了解twisted框架的方法!
angel_su 2013-11-18
  • 打赏
  • 举报
回复
按faq说法,你换个客户端,或自己简单写一个试试先...

37,744

社区成员

发帖
与我相关
我的任务
社区描述
JavaScript,VBScript,AngleScript,ActionScript,Shell,Perl,Ruby,Lua,Tcl,Scala,MaxScript 等脚本语言交流。
社区管理员
  • 脚本语言(Perl/Python)社区
  • WuKongSecurity@BOB
加入社区
  • 近7日
  • 近30日
  • 至今

试试用AI创作助手写篇文章吧