live555学习笔记15-RTCPInstance类小结

来源:互联网 发布:linux没有rpm命令 编辑:程序博客网 时间:2024/05/21 11:27

十五:RTCPInstance类小结


RTCPInstance是对rtcp通信的封装.RTCP主要是功能是统计包的收发为流量控制提供依据.RTCPInstance统计数据的取得仅依赖于RTPSink的一些函数(因为RTPSink发送RTP包),所以RTCPInstance与其它类(GroupSock,RTPInterface等基础类除外)基本关系不大,封装的比较完整.


RTCPInstance靠RTPInterface提供网络通讯支持,所以它既支持rtcp over udp,又支持rtcp over tcp.
RTCPInstance接收到的包在函数static void incomingReportHandler(RTCPInstance* instance, int /*mask*/)中处理.
最值得关注的是这个成员函数:void setSpecificRRHandler(netAddressBits fromAddress, Port fromPort,TaskFunc* handlerTask, void* clientData).它的作用是让调用者可以设置回调函数,调用者就可以在收到RR包时做出一定的动作.参数fromAddress和fromPort指明要对哪个客户端的RR包做出响应.
利用这个机制的例子是RTSPServer::RTSPClientSession.它会把自己的RRHandler函数经过层层传递,最终传给RTCPInstance.于是RTSPServer::RTSPClientSession就可以在每次收到对应的客户端的RR包时调用它传入的函数,这个函数是void RTSPServer::RTSPClientSession::noteClientLiveness(RTSPClientSession* clientSession).此函数只是以下函数的过渡:

[cpp] view plaincopyprint?
  1. void RTSPServer::RTSPClientSession::noteLiveness()  
  2. {  
  3. #ifdef DEBUG  
  4.     fprintf(stderr, "Liveness indication from client at %s\n", our_inet_ntoa(fClientAddr.sin_addr));  
  5. #endif  
  6.     if (fOurServer.fReclamationTestSeconds > 0) {  
  7.         envir().taskScheduler().rescheduleDelayedTask(fLivenessCheckTask,  
  8.                 fOurServer.fReclamationTestSeconds * 1000000,  
  9.                 (TaskFunc*) livenessTimeoutTask, this);  
  10.     }  
  11. }  

可以看到,每收到一次指定客户端的RR包,就重置一下livenessTimeoutTask()的运行时间,如果livenessTimeoutTask()一旦运行,看一下livenessTimeoutTask():

[cpp] view plaincopyprint?
  1. void RTSPServer::RTSPClientSession::livenessTimeoutTask(RTSPClientSession* clientSession)  
  2. {  
  3.     // If this gets called, the client session is assumed to have timed out,  
  4.     // so delete it:  
  5. #ifdef DEBUG  
  6.     fprintf(stderr, "RTSP client session from %s has timed out (due to inactivity)\n", our_inet_ntoa(clientSession->fClientAddr.sin_addr));  
  7. #endif  
  8.     delete clientSession;  
  9. }  

那么RTSPServer::RTSPClientSession就会自杀(真是想不开啊).也就是说fOurServer.fReclamationTestSeconds * 1000000是超时时间(默认好像是60秒).


如果你想监视一个客户端,最好的方式就是向RTCPInstance注册RRHandle.
原创粉丝点击