组织:中国互动出版网(http://www.china-pub.com/) RFC文档中文翻译计划(http://www.china-pub.com/compters/emook/aboutemook.htm) E-mail:ouyang@china-pub.com 译者:孟岩(dreamwords dreamwords@sina.com)李超(licc_li@sina.com) 译文发布时间:2001-6-26 版权:本中文翻译文档版权归中国互动出版网所有。可以用于非商业用途自由转载,但必须保留本文档的翻译及版权信息。
Network Working Group G. Hellstrom Request for Comments: 2793 Omnitor AB Category: Standards Track May 2000
用于文本交谈的RTP负载 (RTP Payload for Text Conversation)
本备忘录的状态 本文档讲述了一种Internet社区的Internet标准跟踪协议,它需要进一步进行讨论和建 议以得到改进。请参考最新版的“Internet正式协议标准” (STD1)来获得本协议的标准化 程度和状态。本备忘录的发布不受任何限制。
版权声明 Copyright (C) The Internet Society (2001).
摘要 本文描述了在RTP包中传输文本交谈内容的方法,关于文本交谈会话内容在ITU-T建议 (T.140[1])中有详细说明。 文本交谈可以用来单独传输或与音视频等交谈工具一起构成多媒体交谈服务。 本RTP负载包含可选的已传输数据包的冗余文本来降低包丢失的风险。冗余码参照RFC 2198。 目录 1.简介 2 1.1 术语 3 2. RTP用法 3 2.1 RTP包头 3 2.2 附加头 4 2.3 T.140 文本结构 4 3. 推荐过程 4 3.1 基本推荐过程 5 3.2 补偿丢包的推荐过程 5 3.3 补偿乱序包的推荐过程 5 3.4 使用冗余时的“静音期”传输 5 4. 范例 6 5.安全性考虑 7 6. MIME MEDIA TYPE REGISTRATIONS 7 6.1 Registration of MIME media type text/t140 7 鸣谢 8 作者地址 8 参考 8 版权说明 9 致谢 9 1.简介 本文定义了一种用于在RTP包中传输文本交谈会话内容的负载格式,文本交谈会话内容 在ITU-T建议(T.140[1])中有详细说明。文本交谈可单独传输或与音视频等交谈工具共同 构成多媒体交谈服务。文本交谈中的文本应尽快传输,或者经过一个小的缓冲延迟。 文本的输入通常是以键盘、手写识别、语音识别或是其它输入方法。字符的输入率通常 为每秒几个字符。这样,期望的字符传输率也较低。通常每个包中只有很少的新字符需要传 输。 在T.140中指定文本和其它T.140元素必须以经过UTF-8变换的ISO 10 646-1 码来传送。 这些有助于实现国际化应用,并且易于处理现代信息技术环境中的文本。本文RTP负载中 的文本编码严格遵守T.140,没有任何附加帧。通常是UTF-8编码的ISO 10646单字符。 T.140要求字符按照原始顺序,没有重复的传输。文本交谈的使用者希望文本传输没有 或尽可能少丢失。当然,如果能标识出丢失的信息,则丢失的可接受程度会高些。 因此,这里介绍了一个基于RTP的机制。它将按照原始顺序,无重复传输,并且提供 丢失检测和指示。它同时也提供一个可选方案,利用重复的冗余数据来降低丢失文本风险。 考虑到包开销通常远远大于T.140内容,传输通道中增加冗余数据造成的负担很小。 1.1 术语 本文中的关键字“必须”,“必须不”,“要求的”,“应该”,“不应该”,“会”,“不会”, “建议”,“或许”,“可选的”在 RFC 2119 [4]中解释。 2. RTP用法 当RTP传输中需要传输T.140文本交谈,应该使用本文所述的负载。 这种负载格式的文本交谈RTP包的格式包括:一个RTP头(在RFC 1889 [2] 中有定义), 其后紧接着是一个T.140数据块(这里被定义为“T140block”)。该负载格式没有附加头。 T140块包括 [1] 中定义的一个或多个T.140码元素。大部分T.140码元素为ISO 10645 [5] 单 字符,但是也有一些是多字符序列。其中每个字符均为UTF-8编码[6]的一个或多个字节。 这说明不管单个字符中有几个字节,每一块必须包含UTF-8码的整数倍。这也说明任何组 合的字符序列(CCS)应该被放到同一块中。 T140块可能会根据RFC 2198 [3] 所定义的负载格式传输冗余数据。这样,RTP头后将 是一或多个冗余数据块头,个数与从携带的冗余T140块数相同,最后是此包的新T140块。 2.1 RTP包头 每个RTP包开始于一个固定的RTP头。下面列出了用于T.140文本流的几个RTP头字 段。 负载类型(PT):RTP负载类型的分配是使用该负载格式的RTP框架特定的。对于利用 动态负载类型号的协议子集,这种负载格式被命名为"T140"(参照第六节)。如果按照RFC 2198使用冗余数据,负载类型中必须指定负载格式("RED")。 顺序号:顺序号必须严格按照每个新传送包以一递增。它用于包丢失和乱序检测,同时 也可以用于获取冗余文本,重组文本和标记丢失文本。 时间戳:RTP时间戳记录了包中主文本块采样时间的近似值。必须使用1000赫兹的时 钟频率。连续包不能使用相同的时间戳。由于包不按固定间隔发送,所以时间戳不能直接被 用于指示包丢失。 2.2 附加头 本负载格式没有定义专门的附加头。 当要按RFC 2198传输冗余数据时,RTP头后紧跟者一个或多个冗余数据块头,每个冗 余数据块都要有一个对应的冗余数据块头。这些头部均提供了时间戳位移和相应的数据块长 度,以及指示了这种负载格式("T140")的负载类型号。 2.3 T.140 文本结构 T.140文本是按T.140协议规定经过UTF-8编码的,没有额外组帧。当用该格式传输冗 余数据时,发送者会选择每个包中要传输的T140block数。数越高则将丢包保护性越好,但 同时也会增加数据传输率。 由于数据包并非按一定的时间间隔产生,如果不提供附加信息,时间戳在包丢失时就无 法标识出该包。冗余数据头并没有提供顺序号,所以必须遵循附加规则才能将丢失主数据所 对应的冗余数据正确的插入T140blocks主数据流中:
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |V=2|P|X| CC=0 |M| T140 PT | 顺序号 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 时间戳 (1000Hz) | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 同步源 (SSRC) 标识符 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ + T.140 编码数据 + | | + +---------------+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
这是一个携带冗余数据的RTP 包的例子
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |V=2|P|X| CC=0 |M| "RED" PT | 主序号 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 原始数据时间戳 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 同步源 (SSRC) 标识符 | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |1| T140 PT | "R" 时间戳位移 | "R" 块长度| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |0| T140 PT | | +-+-+-+-+-+-+-+-+ + | | + "R" T.140 编码冗余数据 + | | + +---------------+ | | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ + | "P" T.140 编码原始数据 | + + + +---------------+ | | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 附图:RTP文本包的例子 5.安全性考虑 既然本负载格式的目的是在文本交谈中携带文本,加密的安全性度量就变得十分重要。 文本传输的数量很少,这样我们可以选择任何加密方法来对T.140会话或者整个RTP包进 行加密。如果数据包中包含了冗余数据,要使用同RFC 2198一样的安全性考虑。 6. MIME Media Type Registrations
本文档描述了一种新的RTP负载名称和相应的MIME类型,T140 (text/t140). 6.1 Registration of MIME media type text/t140 MIME media type name: text MIME subtype name: t140 必需参数: 无 可选参数: 无 编码考虑: 按RFC 2793规定传输T140文本。 安全性考虑:无 互操作考虑: 无 已发行规范: ITU-T建议T.140,RFC 2793. 使用该媒体类型的应用: 文本通信终端和文本会议工具。 附加信息: 无 Magic number(s): 无 文件扩展: 无 Macintosh文件类型码: 无 联系办法: Gunnar Hellstrom e-mail: gunnar.hellstrom@omnitor.se 预期使用: COMMON Author / Change controller: Gunnar Hellstrom | IETF avt WG gunnar.hellstrom@omnitor.se | c/o Steve Casner casner@cisco.com 鸣谢 感谢 Stephen Casner 和 Colin Perkins 在本文写作时给予的细查和建议。 感谢Ericsson公司的Mickey Nasiri提供的实验环境。 感谢Michele Mizarro验证了负载格式的可用性。 作者地址 Gunnar Hellstrom Omnitor AB Alsnogatan 7, 4 tr SE-116 41 Stockholm Sweden Phone: +46 708 204 288 / +46 8 556 002 03 Fax: +46 8 556 002 06 EMail: gunnar.hellstrom@omnitor.se 参考 [1] ITU-T Recommendation T.140 (1998) - Text conversation protocol for multimedia application, with amendment 1, (2000). [2] Schulzrinne, H., Casner, S., Frederick, R. and V. Jacobson, "RTP: A Transport Protocol for Real-Time Applications", RFC 1889, January 1996. [3] Perkins, C., Kouvelas, I., Hardman, V., Handley, M. and J. Bolot, "RTP Payload for Redundant Audio Data", RFC 2198, September 1997. [4] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997. [5] ISO/IEC 10646-1: (1993), Universal Multiple Octet Coded Character Set. [6] Yergeau, F., "UTF-8, a transformation format of ISO 10646", RFC 2279, January 1998. 版权说明 Copyright (C) The Internet Society (2000). All Rights Reserved.
This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this paragraph are included on all such copies and derivative works. However, this document itself may not be modified in any way, such as by removing the copyright notice or references to the Internet Society or other Internet organizations, except as needed for the purpose of developing Internet standards in which case the procedures for copyrights defined in the Internet Standards process must be followed, or as required to translate it into languages other than English.
The limited permissions granted above are perpetual and will not be revoked by the Internet Society or its successors or assigns.
This document and the information contained herein is provided on an "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. 致谢 Funding for the RFC Editor function is currently provided by the Internet Society.
RFC2793―― RTP Payload for Text Conversation 用于文本交谈的RTP负载
1 RFC文档中文翻译计划
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8