CN103746930B - 一种窄带串行链路tcp报文头部压缩的改进方法 - Google Patents
一种窄带串行链路tcp报文头部压缩的改进方法 Download PDFInfo
- Publication number
- CN103746930B CN103746930B CN201410015437.2A CN201410015437A CN103746930B CN 103746930 B CN103746930 B CN 103746930B CN 201410015437 A CN201410015437 A CN 201410015437A CN 103746930 B CN103746930 B CN 103746930B
- Authority
- CN
- China
- Prior art keywords
- link
- module
- compressed packet
- message
- compression
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Landscapes
- Data Exchanges In Wide-Area Networks (AREA)
- Communication Control (AREA)
Abstract
本发明提供一种改进窄带串行链路TCP报文头部压缩方法,该方法包括:链路质量检测模块:定时检查和预测链路质量情况,及时将链路质量情况通告给QoS模块;QoS模块:压缩端是根据当前链路质量情况对报文进行流量整形和限速处理。解压端需保证头部请求报文优先于其他报文。决策模块:决定压缩和解压是否按照改进后的方式处理;改进的压缩模块:对现有的压缩报文基础上进行改进,能够减少1字节的传输;改进的解压模块:对改进后的压缩报文正确地解压,重构IP报文后上送到IP层。本发明的有益增益效果是:通过QoS使压缩端和解压端的上下文尽可能保持一致,通过对原有压缩报文的改进,使现有技术中的CTCP报文能够进一步得到压缩,利用本发明节约带宽,提高传输效率。
Description
技术领域
本发明涉及一种适用于窄带串行链路TCP/IP的报文头部压缩方法。该方法可以实现对TCP/IP协议报文的压缩和解压缩,从而减少链路中传输的开销,节约链路带宽资源。
背景技术
CTCP头压缩遵循RFC1144协议,该方案由LBL实验室的Van Jacobson在1990年2月发明。这是一种在低速串行链路上能够提高TCP/IP头标传输效率的基本压缩方法。它可以将40字节的TCP/IP头标压缩到4字节。该方法采用计时超时的差错恢复机制,因此不适合在来回响应时间较长的链路上使用。
IPHC头压缩遵循RFC2507协议HJ,该方案由瑞典Lulea大学的Dr Stephen,DrMikael等在1999年2月提出。IPHC头压缩是对CTCP稍作改进后的一种常规的IP头标压缩方案,它可以压缩任意的IP、TCP和UDP头。它适合在低速和中速链路上压缩数据业务。
目前的TCP/IP压缩方法都是依据同一个流的数据报头之间的相关性进行压缩的,存在的问题是当发送节点发送的数据报文在链路上丢失,解压端将无法接收到这个压缩报文,也就无法更新上下文。但是压缩端进行压缩处理的过程中已经更新了上下文信息。对于后续报文,压缩端将会根据新的上下文进行压缩,但解压端却仍然使用旧上下文来解压,如果上下文不及时同步,重构的IP报文在一段时间内都不正确。
发明内容
为解决上述问题,本发明提供如下技术方案,该方法包括如下模块:
链路质量检测模块:定时检查和预测链路质量情况,用于决策压缩处理方式及时将链路质量情况通告给QoS模块;QoS模块:在压缩端是根据当前链路质量情况对报文进行流量整形和限速处理。在解压端需保证头部请求报文优先于其他报文,目的尽可能使两端上下文同步。决策模块:决定压缩和解压是标准RFC协议的处理方式还是改进后的方式处理;压缩模块:按照标准协议正确地压缩处理;改进的压缩模块:对现有的压缩报文基础上进行改进,能够减少1字节的传输;解压模块:按照标准RFC正确解压;改进的解压模块:对改进后的压缩报文正确地解压,重构IP报文后上送到IP层。
本发明的有益效果是:通过对链路的监控预测技术和QoS使压缩端和解压端的上下文尽可能保持一致;并对原有压缩报文的改进,使现有技术中的CTCP报文能够进一步得到压缩,节约带宽,提高传输效率。
附图说明
图1、本发明压缩/解压模块分解图。
图2、现有CTCP压缩报文格式。
图3、改进CTCP压缩报文格式。
图4、压缩端流程图。
图5、解压端流程图。
具体实施方式
下面结合附图对本发明实施中的技术方案做出说明。附图用于帮助理解实施例的技术方案。图4和图5是压缩端和解压端的流程图。主要处理步骤如下。
压缩端的处理流程:
步骤1.对于要发送的TCP报文,首先由压缩端的链路检测模块对链路质量进行检测,将
将链路质量情况通告给QoS模块。
步骤2.决策模块决定是否可以按标准RFC处理,如果可以,跳至步骤6;否则,跳至步骤3。
步骤3. 通过CID在上下文列表中查找,如果没有找到该CID的上下文信息,则发送全头部报文。
步骤4. 如果是压缩报文,构造压缩报文。结合图2,虚框内字段是在压缩报文中携带的内容,经过对原有TCP头部压缩报文分析,其中C比特属于必须携带的字段,而U比特和P比特属于不会频繁出现的字段,而I、S、A和W比特是在同一报文流中的不同压缩报文中发生变化的,对于这几个比特的常用变化组合和点对点链路层协议域的类型相结合,将变化比特通过协议域字段携带出去,这样压缩端不需要将变化域字节携带出去,仅仅将变化量携带出去即可。改进后的压缩报文格式参见图3,报文字段位置和原来的压缩报文格式相同。例如I 、S 和A发生变化则将链路层协议字段封装成0x60,该字段同时也标识出哪些比特发生变化,解压端通过协议域进行不同处理。 通过上面处理能够在原来的压缩报文基础上节约一个字节。
步骤5.发送压缩报文。如果更新了压缩端的上下文而没有更新解压端的上下文会导致两端的信息不同步,所以在这里不去更新压缩端上下文信息,而是将上下文信息标识为“不可用”状态,同时通知QoS模块进行流量控制和压缩报文优先级保障处理。等到下一次接收到IP报文,通过重新发送全头部信息来保证压缩端和解压端的上下文同步。
步骤6.按照标准RFC协议进行处理。
解压端的处理流程:
步骤1. 接收到数据帧后,由决策模块是否可以按照标准协议处理,如果可以,按照标准协议处理;否则按照,改进后的方式处理。
步骤2. 如果是全头部帧,记录该CID的上下文,恢复IP协议号后将数据报文上送给IP层。
步骤3. 如果是压缩帧,如果是原有报文格式,按照标准RFC进行处理;否则,如果链路层协议域是新类型,不是根据变化比特码的处理变化量字段,而是根据链路层协议域的类型字段对头部报文进行正确地解析来恢复上下文,重构IP报文并上送到IP层。
Claims (1)
1.一种改进窄带串行链路TCP报文头部压缩方法,其特征在于:通过对链路的监控预测技术和QoS加快压缩端和解压端的上下文同步,并对原有压缩报文格式进行修改,使现有技术中的CTCP报文能够进一步得到压缩;
其中所述的压缩端具体包含:
步骤1.对于要发送的TCP报文,首先由压缩端的链路检测模块对链路质量进行检测,将链路质量情况通告给QoS模块;
步骤2.决策模块决定是否可以按标准RFC处理,如果可以,跳至步骤6;否则,跳至步骤3;
步骤3. 通过CID在上下文列表中查找,如果没有找到该CID的上下文信息,则发送全头部报文;
步骤4. 如果是压缩报文,构造压缩报文,对原有TCP头部压缩报文分析,发现C比特是必须携带的字段,U比特和P比特是不频繁出现的字段,而I、S、A和W比特是同一报文流中的不同字段发生变化的标志位;对原有压缩报文改进,将这几个比特的常用变化组合和点对点链路层协议域的类型相结合,这样压缩端不需要将变化域字节携带出去,仅仅携带链路层协议类型即可,操作方法是:若链路层协议类型字段是0x60时,标识I 、S 和A比特对应的几个比特发生变化,解压端通过协议域进行不同解压处理,通过上面处理能够在原来的压缩报文基础上节约一个字节;
步骤5.发送压缩报文;如果更新了压缩端的上下文而没有更新解压端的上下文会导致两端的信息不同步,所以在这里不去更新压缩端上下文信息,而是将上下文信息标识为“不可用”状态,同时通知QoS模块进行流量控制和压缩报文优先级保障处理,等到下一次接收到IP报文,通过重新发送全头部信息来保证压缩端和解压端的上下文同步;
步骤6.按照标准RFC协议进行处理;
其中所述的解压缩端具体包含:
步骤1. 接收到数据帧后,由决策模块决定是否可以按照标准协议处理,如果可以,按照标准协议处理,否则按照改进后的方式处理;
步骤2. 如果是全头部帧,记录该CID的上下文,恢复IP协议号后将数据报文上送给IP层;
步骤3. 如果是压缩帧,如果是原有报文格式,按照标准RFC进行处理;否则如果链路层协议域是新类型,不是根据变化域而是根据链路层协议域的类型字段对头部报文进行正确地解析来恢复上下文,重构IP报文并上送到IP层。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410015437.2A CN103746930B (zh) | 2014-01-14 | 2014-01-14 | 一种窄带串行链路tcp报文头部压缩的改进方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410015437.2A CN103746930B (zh) | 2014-01-14 | 2014-01-14 | 一种窄带串行链路tcp报文头部压缩的改进方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN103746930A CN103746930A (zh) | 2014-04-23 |
CN103746930B true CN103746930B (zh) | 2017-09-19 |
Family
ID=50503921
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201410015437.2A Active CN103746930B (zh) | 2014-01-14 | 2014-01-14 | 一种窄带串行链路tcp报文头部压缩的改进方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN103746930B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109818901B (zh) * | 2017-11-20 | 2021-04-20 | 华为技术有限公司 | 报文头压缩机制确定方法、设备及系统 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101075937A (zh) * | 2007-07-20 | 2007-11-21 | 华为技术有限公司 | 三层虚拟专用网转发报文的方法、系统和设备 |
CN101159677A (zh) * | 2007-10-25 | 2008-04-09 | 华为技术有限公司 | 一种报文传输方法及网络节点装置 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1506642A1 (en) * | 2002-05-07 | 2005-02-16 | Koninklijke Philips Electronics N.V. | Wireless communication arrangements with packet transmissions |
-
2014
- 2014-01-14 CN CN201410015437.2A patent/CN103746930B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101075937A (zh) * | 2007-07-20 | 2007-11-21 | 华为技术有限公司 | 三层虚拟专用网转发报文的方法、系统和设备 |
CN101159677A (zh) * | 2007-10-25 | 2008-04-09 | 华为技术有限公司 | 一种报文传输方法及网络节点装置 |
Also Published As
Publication number | Publication date |
---|---|
CN103746930A (zh) | 2014-04-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4317403B2 (ja) | ヘッダ圧縮装置及びヘッダ圧縮方法 | |
US9961587B2 (en) | Methods and apparatus for optimizing tunneled traffic | |
US8718098B2 (en) | Method for compressing and decompressing time stamp and equipment thereof | |
US7430617B2 (en) | Method and system for header compression | |
US8065437B2 (en) | Packet header compression system and method based upon a dynamic template creation | |
US20150382240A1 (en) | Methods and apparatus for optimizing tunneled traffic | |
US8817821B2 (en) | Method and device for user datagram protocol packet compression and decompression | |
KR101835340B1 (ko) | 방송 신호 송신 장치, 방송 신호 수신 장치, 방송 신호 송신 방법, 및 방송 신호 수신 방법 | |
CN100591053C (zh) | 一种报文传输方法及网络节点装置 | |
WO2013167013A2 (zh) | 以太网报文头的压缩及解压缩方法、压缩及解压缩设备 | |
CN100433841C (zh) | 用于因特网协议第6版移动子协议MIPv6的鲁棒性头标压缩/解压方法 | |
CN110620637B (zh) | 一种基于fpga的数据解压装置及方法 | |
US20150071307A1 (en) | Communication interface and method for robust header compression of data flows | |
WO2012051883A1 (zh) | 鲁棒性头压缩中一种上下文重用的方法及装置 | |
CN107094144B (zh) | 基带帧的封装方法及解封装方法 | |
CN112335203B (zh) | 处理局域网诊断数据 | |
CN111385263B (zh) | 一种数据包头压缩信息的维护方法及通信设备 | |
CN113364508B (zh) | 一种语音数据的传输控制方法、系统及设备 | |
CN103746930B (zh) | 一种窄带串行链路tcp报文头部压缩的改进方法 | |
WO2015101152A1 (zh) | 基于dfa的http分块传输编码的传输载荷提取方法 | |
CN109039811B (zh) | 用于网络性能监控的网络数据包包头压缩方法及装置 | |
EP3340545A1 (en) | Methods and apparatus for optimizing tunneled traffic | |
Rawat et al. | Designing a header compression mechanism for efficient use of IP tunneling in wireless networks | |
Farouq et al. | Unidirectional and bidirectional optimistic modes IP header compression for real-time video streaming | |
CN101616164B (zh) | 一种传输报文的方法和装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |