c – 测量网络上的经过时间
我开发了一个服务器和客户端应用程序,用于使用RTSP将视频帧从一端流式传输到另一端.现在,为了收集有助于我改进应用程序的统计数据,我需要测量发送帧和接收帧之间经过的时间.
目前我正在使用以下公式: Client_Receive_Timestamp - Server_Send_Timestamp = Elapsed_Time 问题 在我看来,经过的时间大约是100-200ms.我认为原因是服务器时钟和客户端时钟不同步,差异大约为100-200ms. 题 如何准确测量两个mashines之间的经过时间? 主题Accurately measuring elapsed time between machines建议计算往返延迟.但是,我不能使用此解决方案,因为客户端不请求帧.它只是通过RTSP接收帧. 解决方法
假设
>您只想测量单程旅行的延迟 然后您可以简单地从“接收的时间戳”中减去“发送的时间戳”以获得延迟持续时间. observed error将小于两个时钟误差的总和.如果时间尺度足够小(可能小于一小时),你可以合理地忽略slew效果. 如果ntpd尚未在两台计算机上运行,??并且您具有必要的权限,则可以 $sudo ntpdate -v pool.ntp.org 强制与公共可用时间服务器池同步. 然后你可以使用c 11 high_resolution_clock来计算持续时间: /* hrc.cc */ #include <chrono> #include <iostream> int main(int,char**){ using std::chrono::high_resolution_clock; // send something high_resolution_clock::time_point start = high_resolution_clock::now(); std::cout << "time this" << std::endl ; // receive something high_resolution_clock::time_point stop = high_resolution_clock::now(); std::cout << "duration == " << std::chrono::duration_cast<std::chrono::nanoseconds>(stop-start).count() << "ns" << std::endl ; return 0; } 这是上一个示例在我的系统上的样子: $make hrc && ./hrc c++ hrc.cc -o hrc time this duration == 32010ns (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |