RTP Tools

RTP Tools (Version 1.20)

https://wiki.wireshark.org/RTP_statistics

Here is a small example:

  • Install JMF (JMstudio is included)
  • Download rtptools
  • Open the RTP capture file with Wireshark
  • Select the proper UDP and force its decoding as RTP: Menu Analyze >> Decode As... RTP.
  • Menu Statistics(Wireshark 1.0) or Telephony >> RTP >> Show all streams. Select the one of your interest, and press button Save As... into a "rtpdump" formatted file.
  • Start JMstudio
  • Menu File >> Open RTP Session and insert your local IP address (it didn‘t work with 127.0.0.1 for me) like this:
  • Press button "Open" - now JMstudio waits for the stream
  • Open a terminal and type:
  [email protected]$ rtpplay -T -f /path/to/your/captured.rtpdump 192.168.0.23/1234

You should now hear what you‘ve captured. Note:JMstudio does not support every codec, but some commonly used for RTP (worked perfect for me to listen to a captured kphone-session using GSM as codec).

Description

The rtptools distribution consists of a number of small applications that can be used for processing RTP data.

rtpplay
Play back RTP sessions recorded by rtpdump
rtpsend
Generate RTP packets from textual description, generated by hand or rtpdump
rtpdump
Parse and print RTP packets, generating output files suitable for rtpplay and rtpsend
rtptrans
RTP translator between unicast and multicast networks; also translates between VAT and RTP formats.

Installation

Sources for a variety of platforms and binaries for Windows are available from http://www.cs.columbia.edu/IRT/rtptools/download.

The RTP tools should compile on any Posix-compliant platform supporting sockets, as well as Windows/NT/95/98/2000 (Win32). They have been tested on SunOS 4.1, SunOS 5.x (Solaris), Linux, NT 4.0, SGI Irix, and HP-UX. Edit the directories and libraries at the top of Makefile and type make. The compiler must support ANSI C: gcc does, Sun‘s old /usr/ucb/cc does not.

Note: You must use the sun4 architecture for SunOS 4.1.x and sun5 for SunOS 5.x (Solaris). You will get system call errors if you do not.

For Unix systems, type
./configure; make
To install RTP tools on WIN32 machine, please follow the following steps:
*.dsp files are project files. *.dsw file and workspace file. 
User can open the workspace file and use ‘batch compile‘ to compile all the projects.

  1. In Visual C++ 6.0, open workspace file rtptools.dsw.
  2. In VC menu Build, use Batch Build to build all the tools.
  3. All the rtptools will be created under "debug\" directory.

For quite a character, who desire to compile on Borland C++ Builder, please open dump_bcb.bpr, play_bcb.bpr, send_bcb.bpr and trans_bcb.bpr under bcb directory. Only pressing ctr-F9 needed for compilation, and the tool will be generated on the same directory.

General Usage Hints

Network addresses can be either multicast or unicast addresses, unless stated otherwise. They may be specified in dotted-decimal notation (e.g., 224.2.0.1) or as a host name (e.g., lupus.fokus.gmd.de). Port numbers must be given as decimal numbers in the range of 1 to 65535. Network addresses are specified as destination/port/ttl. The time-to-live (ttl) value is optional and only applies to multicast.

For all commands, the flag -h or -? will print a short usage summary.

Unless otherwise noted, input is taken from stdin, and output sent to stdout. The extension .rtp is suggested for files generated in rtpdump -F dump format.

rtpplay

rtpplay [-T] [-v] [-f file] [-p profile] [-s sourceport] [-b begin] [-e enddestination/port[/ttl]

rtpplay reads RTP session data, recorded by rtpdump -F dump from either the file or stdin, if file is not specified, sending it to network address destination and port port with a time-to-live value of ttl.

If the flag -T is given, the timing between packets corresponds to the arrival timing rather than the RTP timestamps. Otherwise, for RTP data packets, the timing given by the RTP timestamps is used, smoothing interarrival jitter and restoring packet sequence. RTCP packets are still sent with their original timing. This may cause the relative order of RTP and RTCP packets to be changed.

The source port(localport) for outgoing packets can be set with the -s flag. A random port is chosen if this flag is not specified.

The whole file is played unless the begin or end times are specified. Times are measured in seconds and fractions from the beginning of the recording.

The RTP clock frequency is read from the profile file if given; the default profile (RFC 1890) is used if not. The profile file contains lines with two fields each: the first is the numeric payload type, the second the clock frequency. The values read from the profile file are silently ignored if the -T flag is used.

If you want to loop a particular file, it is easiest to put the rtpplay command in a shell script.

The -v flag has rtpplay display the packets generated on stdout.

rtpplay uses the hsearch (3C) library, which may not be available on all operating systems.

rtpdump

rtpdump [-F format] [-t duration] [-x bytes] [-f file] [-o outputfileaddress/port

rtpdump listens on the address and port pair for RTP and RTCP packets and dumps a processed version to outputfile if specified or stdout otherwise.

If file is specified, the file is used instead of the network address. If no network address is given, file input is expected from stdin. The file must have been recorded using the rtpdump dump format.

The recording duration is measured in minutes.

From each packet, only the first bytes of the payload are dumped (only applicable for "dump" and "hex" formats).

Supported formats are:

format text/binary description
dump binary dump in binary format, suitable for rtpplay. The format is as follows: The file starts with#!rtpplay1.0 address/port\n

The version number indicates the file format version, not the version of RTP tools used to generate the file. The current file format version is 1.0.

This is followed by one binary header (RD_hdr_t) and one RD_packet_t structure for each received packet. All fields are in network byte order. The RTP and RTCP packets are recorded as-is.

typedef struct {
  struct timeval start;  /* start of recording (GMT) */
  u_int32 source;        /* network source (multicast address) */
  u_int16 port;          /* UDP port */
} RD_hdr_t;

typedef struct {
  u_int16 length;    /* length of packet, including this header (may
                        be smaller than plen if not whole packet recorded) */
  u_int16 plen;      /* actual header+payload length for RTP, 0 for RTCP */
  u_int32 offset;    /* milliseconds since the start of recording */
} RD_packet_t;
header like "dump", but don‘t save audio/video payload
payload only audio/video payload
ascii text parsed packets (default), suitable for rtpsend:

844525628.240592 RTP len=176 from=131.136.234.103:46196 v=2 p=0 x=0
   cc=0 m=0 pt=5 (IDVI,1,8000) seq=28178 ts=954052737 ssrc=0x124e2b58
844525628.243123 RTCP len=128 from=139.88.27.43:53154
 (RR ssrc=0x125bd36f p=0 count=1 len=7
(ssrc=bc64b658 fraction=0.503906 lost=4291428375 last_seq=308007791
  jit=17987961 lsr=2003335488 dlsr=825440558)
 )
 (SDES p=0 count=1 len=23
  (src=0x125bd36f CNAME="[email protected]" NAME="Michael Baldizzi
  (NASA LeRC)" TOOL="vat-4.0a8" EMAIL="[email protected]" )
 )
hex like ascii, but with hex dump of payload
rtcp like ascii, but only RTCP packets
short RTP or vat data in tabular form: [-]time ts [seq], where a - indicates a set marker bit. The sequence number seq is only used for RTP packets.

844525727.800600 954849217 30667
844525727.837188 954849537 30668
844525727.877249 954849857 30669
844525727.922518 954850177 30670

rtpsend

rtpsend sends an RTP packet stream with configurable parameters. This is intended to test RTP features. The RTP or RTCP headers are read from a file, generated by hand, a test program or rtpdump (format "ascii").

rtpsend [-a] [-l] [-s sourceport] [-f filedestination/port[/ttl]

Packets are sent with a time-to-live value ttl.

If data is read from a file instead of stdin, the -l(loop) flag resends the same sequence of packets again and again.

The source port(localport) for outgoing packets can be set with the -s flag. A random port is chosen if this flag is not specified.

If the -a flag is specified, rtpsend includes a router alert IP option in RTCP packets. This is used by the YESSIR resource reservation protoccol.

The file file contains the description of the packets to be sent. Within the file, each entry starts with a time value, in seconds, relative to the beginning of the trace. The time value must appear at the beginning of a line, without white space. Within an RTP or RTCP packet description, parameters may appear in any order, without white space around the equal sign. Lines are continued with initial white space on the next line. Comment lines start with #. Strings are enclosed in quotation marks.

<time> RTP
   v=<version>
   p=<padding>
   x=<extension>
   m=<marker>
   pt=<payload type>
   ts=<time stamp>
   seq=<sequence number>
   ssrc=<SSRC>
   cc=<CSRC count>
   csrc=<CSRC>
   data=<hex payload>
   ext_type=<type of extension>
   ext_len=<length of extension header>
   ext_data=<hex extension data>
   len=<packet size in bytes(including header)>
<time> RTCP (SDES v=<version>
              (src=<source> cname="..." name="...")
              (src=<source> ...)
            )
            (SR v=<version>
              ssrc=<SSRC of data source>
              p=<padding>
              count=<number of sources>
              len=<length>
              ntp=<NTP timestamp>
              psent=<packet sent>
              osent=<octets sent>
                (ssrc=<SSRC of source>
                 fraction=<loss fraction>
                 lost=<number lost>
                 last_seq=<last sequence number>
                 jit=<jitter>
                 lsr=<last SR received>
                 dlsr=<delay since last SR>
                )
            )

rtptrans

rtptrans [host]/port[/ttl] [host]/port[/ttl] [...]

rtptrans RTP/RTCP packets arriving from one of the addresses to all other addresses. Addresses can be a multicast or unicast. TTL values for unicast addresses are ignored. (Actually, doesn‘t check whether packets are RTP or not.)

Additionally, the translator can translate VAT packets into RTP packets. VAT control packets are translated into RTCP SDES packets with a CNAME and a NAME entry. However, this is only intended to be used in the following configuration: VAT packets arriving on a multicast connection are translated into RTP and sent over a unicast link. RTP packets are not (yet) translated into VAT packets and and all packets arriving on unicast links are not changed at all. Therefore, currently mainly the following topology is supported: multicast VAT -> translator -> unicast RTP; and on the way back it should lokk like this multicast VAT <- translator <- unicast VAT. This means that the audio agent on the unicast link should be able use both VAT and RTP.

Authors

The rtptools were written by Henning Schulzrinne, with enhancements by Ping Pan and Akira Tsukamoto. rtptrans was written by Dorgham Sisalem and enhanced by Steve Casner.

时间: 2024-10-08 13:57:33

RTP Tools的相关文章

RTP包的结构

live555中数据的发送最后是要使用RTP协议发送的,下面介绍一下RTP包格式. RTP packet RTP是基于UDP协议的,RTP服务器会通过UDP协议,通常每次会发送一个RTP packet.客户端通过解析RTP packet,读取其中的数据然后进行播放了. RTP packet的结构如下: RTP Header:RTP 包的头部 contributing sources:个数为0-n个,所以可以为空.具体定义参考rfc3550 RTP payload:即RTP要传输的数据 RTP H

自己动手写RTP服务器——关于RTP协议

转自:http://blog.csdn.net/baby313/article/details/7353605 本文会带领着你一步步动手实现一个简单的RTP传输服务器,旨在了解RTP流媒体传输协议以及一些关于多媒体编解码的知识. 关于RTP协议的必备知识 要动手实现一个协议,当然首先需要阅读该协议的文档.RTP协议的文档,有rfc1889.rfc1890.rfc3550,其中rfc3550是现在的版本,另外两个是过期版.这个协议可以在ietf的官网找到:http://tools.ietf.org

H264 NAL RTP打包

1. 网络抽象层单元类型 (NALU) NALU是H264用于网络传输的单元类型,一个完整的NALU单元一般是以0x000001或者0x00000001开始,其后跟的则是NALU头和NALU的数据:我们在网络传输的时候,会去掉开始的0x000001或者0x00000001的标志:一般需要将这些标志替换为RTP payload的头部(1个字节): 其中NALU数据就是RBSP数据: NALU 头由一个字节组成, 它的语法如下: +---------------+ |0|1|2|3|4|5|6|7|

H.264视频的RTP荷载格式

Status of This Memo This document specifies an Internet standards track protocol for the   Internet community, and requests discussion and suggestions for   improvements.  Please refer to the current edition of the "Internet   Official Protocol Stand

自己写RTPserver——大约RTP协议

自己写RTPserver--大约RTP协议 本文将带领你一步一步地实现一个简单的手RTP变速器server,旨在了解RTP流媒体传输协议以及有关多媒体编解码器的一些知识. RTP协议的必备知识 要动手实现一个协议,当然首先须要阅读该协议的文档. RTP协议的文档,有rfc1889.rfc1890.rfc3550.当中rfc3550是如今的版本号,另外两个是过期版.这个协议能够在ietf的官网找到:http://tools.ietf.org/html/rfc3550 RTP packet RTP是

Wireshark Lua: 一个从RTP抓包里导出H.264 Payload,变成264裸码流文件(xxx.264)的Wireshark插件

Wireshark Lua: 一个从RTP抓包里导出H.264 Payload,变成264裸码流文件(xxx.264)的Wireshark插件 在win7-64, wireshark Version 2.0.2 (v2.0.2-0-ga16e22e from master-2.0)是可用的,老版本1.0.x未找到对应的tools选项卡

Hibernate Tools for Eclipse的使用

Hibernate Tools的官方网站:http://hibernate.org/tools/Step1.安装好Hibernate Tools,建立一个Dynamic web project,工程名为"test".Step2.以Mysql为示例,建立相应的测试数据库及表,如下所示: [sql] view plain copy mysql> use test; Database changed mysql> show tables; +----------------+ |

VMware Tools的安装及其作用(redhat5.5为例)

VMware Tools是VMware虚拟机中自带的一种增强工具,相当于VirtualBox中的增强功能(Sun VirtualBox Guest Additions),是VMware提供的增强虚拟显卡和硬盘性能.以及同步虚拟机与主机时钟的驱动程序. 只有在VMware虚拟机中安装好了VMware Tools,才能实现主机与虚拟机之间的文件共享,同时可支持自由拖拽的功能,鼠标也可在虚拟机与主机之前自由移动(不用再按ctrl+alt),且虚拟机屏幕也可实现全屏化. 在vm上安装完redhat系统后

com.android.tools.build:gradle:X.XX.XX:gradle.jar

在使用Android Studio 这个IDE时,出现com.android.tools.build:gradle:X.XX.XX:gradle.jar 插件无法下载问题 可能的原因就是网速不好或者依赖仓库的下载网址被墙了,可以配置代理试试.比如,android studio 定义的默人依赖仓库为jcenter()仓库.如下 打开项目下的 build.gradle文件,不是Module下 allprojects { repositories { jcenter() } } 网上搜索到一些方法如下