UC故事 2011/12/09 总结与计划(续5)


1. 近日总结


* 各种不同的Event

CEventAsyncConnect(m2n)

CEventOnConnectIndication(n2m)               Q:这个event特别多,周期性的?   知道了,因为连server不通,反复尝试。

CEventStartListen

CEventCancelConnect


CRtEventDeleteT

CRtEventDisconnect

CRtEventHttpClientAsyncOpen

CRtEventOnDisconnect

CRtEventOnReceive

CRtEventOnSend

CRtEventSendData

CRtEventStopT

CRtEventSync (m2n=  Main Thread to Network Thread )

CRtEventThread

......


2. 问题汇总

Q:在接收server端数据的时候,是否直接从network thread引用conference实例,不用通过向main thread PostEvent() ?

(只需在CConference.HandleXXX设断点,看在哪个线程上运行即可?)


Q:系统里有多少种CRtEvent?


3. 跟踪CRtEventSync/CRtEventStartListen(在new ConfConference里完成的东东)

* network thread

STACK TRACE:

CRtAcceptorTcp::StartListen(IRtAcceptorConnectorSink * 0x00ed92bc, const CRtInetAddr & {...}) line 45
CEventStartListen::OnEventFire() line 161 + 60 bytes
CRtEventSync::OnEventFire() line 35 + 18 bytes
CRtEventQueueBase::ProcessOneEvent(IRtEvent * 0x00ed9390) line 229 + 12 bytes
CRtEventQueueBase::ProcessEvents(const std::list<IRtEvent *,std::allocator<IRtEvent *> > & {...}) line 217
CRtReactorBase::ProcessHandleEvent(void * 0xffffffff, long 256, int 0, int 1, int 0) line 324 + 18 bytes
CRtReactorWin32Message::Win32SocketWndProc(HWND__ * 0x000507ba, unsigned int 1058, unsigned int 4294967295, long 256) line 114
USER32! 77d18734()
USER32! 77d18816()
USER32! 77d189cd()
USER32! 77d196c7()
CRtReactorWin32Message::RunEventLoop() line 261 + 15 bytes
CRtThreadReactor::OnThreadRun() line 67 + 19 bytes
CRtThread::ThreadProc(void * 0x00ed7ef0) line 151 + 13 bytes
_threadstartex(void * 0x00ed7fa0) line 227 + 13 bytes
KERNEL32! 7c80b729()

CODE:

CRtAcceptorTcp::StartListen(...)  {

   ......

    nRet = ::bind(
        (RT_SOCKET)m_Socket.GetHandle(),
        reinterpret_cast<const struct sockaddr *>(aAddrListen.GetPtr()),
        aAddrListen.GetSize());

   ......

}


3. 杂问

Q:wireshark的display filter,tcp.port != xxxx 为何不生效,而tcp.port == yyyy 会生效?

Q:client连不上serevr,显示”重新连接中......“,VC Debug错误信息如下:

.....  无法立即完成一个非阻挡性套接字操作

翛改client的端口


Q:controller无法启动

$20111209 15:23:06.953 4360/4556 ERROR: CRtAcceptorTcp::StartListen, bind() failed! addr=172.16.1.10 port=443 err=10048:通常每个套接字地址(协议/网络地址/端口)只允许使用一次。
 this=0x1674ab8

修改client与controller的端口


Q:会议已经结束

结果:role设成attendee了。


Q:client显示重连

重启所有server, OK !





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值