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 !