Sağlam Başlık Sıkıştırma - Robust Header Compression

Sağlam Başlık Sıkıştırma (ROHC) sıkıştırmak için standart bir yöntemdir IP, UDP, UDP-Lite, RTP, ve TCP başlıkları İnternet paketler.

Başlık sıkıştırması ihtiyacı

Akış uygulamalarında IP, UDP ve RTP ek yükü 40'tır bayt için IPv4 veya 60 bayt için IPv6. İçin VoIP Bu, gönderilen toplam veri miktarının yaklaşık% 60'ına karşılık gelir. Bu tür büyük genel giderler, kapasitenin genellikle bir sorun olmadığı, ancak aşırı yüklendiği yerel kablolu bağlantılarda tolere edilebilir. geniş alan ağları ve bant genişliğinin kıt olduğu kablosuz sistemler.[1]

ROHC, sınırlı kapasiteye sahip bağlantıdan önce bir kompresör ve bu bağlantıdan sonra bir sıkıştırıcı yerleştirerek bu 40 bayt veya 60 bayt ek yükü tipik olarak yalnızca bir veya üç bayta sıkıştırır. Sıkıştırıcı, büyük ek yükü yalnızca birkaç bayta dönüştürürken, gevşetici bunun tersini yapar.

ROHC sıkıştırma şeması, IETF gibi diğer sıkıştırma şemalarından farklıdır RFC 1144 ve RFC 2508, kablosuz bağlantılar gibi paket kayıp oranının yüksek olduğu bağlantılarda iyi performans göstermesi nedeniyle.

Ana ROHC sıkıştırma prensipleri

ROHC protokolü, aşağıdaki başlıklarda bilgi fazlalığından yararlanır:

  • tek bir ağ paketi (örneğin, IP ve UDP başlıklarındaki yük uzunlukları)
  • tek bir akışa ait birkaç ağ paketi (ör. IP adresleri)

Fazla bilgi yalnızca ilk paketlerde iletilir. Sonraki paketler değişken bilgileri içerir, örn. tanımlayıcılar veya sıra numaraları. Bu alanlar, daha fazla bit tasarrufu sağlamak için sıkıştırılmış bir biçimde iletilir.

Daha iyi performans için, paketler sıkıştırılmadan önce akış olarak sınıflandırılır. Bu sınıflandırma, paketler arası artıklıktan yararlanır. Sınıflandırma algoritması, ROHC protokolünün kendisi tarafından tanımlanmaz, ancak ekipman satıcısının uygulamasına bırakılır. Bir paket akışı sınıflandırıldıktan sonra, en iyi uyan sıkıştırma profiline göre sıkıştırılır. Sıkıştırma profili, ağ üstbilgilerindeki farklı alanları sıkıştırmanın yolunu tanımlar. Aşağıdakiler dahil çeşitli sıkıştırma profilleri mevcuttur:

  • Sıkıştırılmamış
  • Yalnızca IP
  • UDP / IP
  • UDP-Lite / IP
  • ESP / IP
  • RTP / UDP / IP
  • RTP / UDP-Lite / IP
  • TCP / IP

Operasyon modları

Göre RFC 3095 ROHC şemasının aşağıdaki gibi üç çalışma modu vardır:

  • Tek yönlü mod (U modu)
  • Çift Yönlü İyimser mod (O modu)
  • Çift Yönlü Güvenilir mod (R modu)

Hem kompresör hem de dekompresör U modunda başlar. Kullanılabilir bir dönüş bağlantısı mevcutsa, O-moduna geçebilirler ve dekompresör, kompresöre O-modu belirtilerek olumlu bir alındı ​​gönderir. R moduna geçiş de aynı şekilde gerçekleştirilir.

Tek Yönlü Mod (U Modu)

Tek yönlü çalışma modunda, paketler yalnızca tek bir yönde gönderilir: kompresörden dekompresöre. Bu mod, bu nedenle ROHC'yi, dekompresörden kompresöre bir dönüş yolunun mevcut olmadığı veya istenmeyen olduğu bağlantılar üzerinden kullanılabilir hale getirir. Olası dekompresyon hatalarının üstesinden gelmek için, sıkıştırıcı, açıcıya akış bağlamının periyodik yenilemelerini gönderir.

Çift Yönlü İyimser Mod (O-Modu)

İki Yönlü İyimser mod, Tek Yönlü moda benzer, tek fark, bir geri bildirim kanalının, sıkıştırıcıdan kompresöre hatadan kurtarma istekleri ve (isteğe bağlı olarak) önemli içerik güncellemelerinin onaylarını göndermek için kullanılmasıdır. O modu, sıkıştırma verimliliğini en üst düzeye çıkarmayı amaçlar ve geri bildirim kanalının seyrek kullanımını hedefler.

Çift Yönlü Güvenilir Mod (R Modu)

Çift Yönlü Güvenilir modu, önceki iki moddan birçok yönden farklılık gösterir. En önemli farklar, geri besleme kanalının daha yoğun kullanımı ve hem kompresörde hem de dekompresörde, çok yüksek artık bit hata oranları dışında, kompresör ve dekompresör arasındaki bağlam senkronizasyonunun kaybını önleyen daha sıkı bir mantıktır.

Kompresör / dekompresör durumları

Kompresör / dekompresör durumları kavramı, işletim modlarına ortogonaldir. Mod ne olursa olsun, hem kompresör hem de dekompresör üç durumundan birinde çalışır. Temelde sonlu durum makineleridir. Gelen her paket, kompresör / dekompresörün dahili durumunu değiştirmesine neden olabilir. Her durum, tanımlanmış bir davranışı ve sıkıştırma seviyesini ifade eder.

ROHC algoritması, bir temel çerçeve ve daha sonra bir IP paket akışını temsil etmek için birkaç farklı çerçeve gönderilmesi açısından video sıkıştırmaya benzer. Bu, temel çerçeveler kaybolmadığı sürece ROHC'nin en yüksek sıkıştırma durumunda birçok paket kaybına dayanmasına izin verme avantajına sahiptir.

Kompresör durumları

Kompresörün durum makinesi aşağıdaki üç durumu tanımlar:

  • Başlatma ve Yenileme (IR) durumu
  • Birinci Derece (FO) durumu
  • İkinci Derece (SO) durumu

Farklı kompresör durumlarında işlemler

Başlatma ve Yenileme (IR) durumunda, sıkıştırıcı yeni oluşturulmuş veya sıfırlanmıştır ve tam paket başlıkları gönderilir. Birinci Sıra (FO) durumunda, kompresör bağlantının her iki tarafında statik alanları (IP adresleri ve bağlantı noktası numaraları gibi) algıladı ve sakladı. Kompresör ayrıca FO durumunda dinamik paket alanı farklılıkları gönderir. Dolayısıyla, FO durumu esasen statik ve sözde dinamik sıkıştırmadır. İkinci Derece (SO) durumunda, sıkıştırıcı, RTP sıra numaraları gibi tüm dinamik alanları bastırır ve diğer tarafın öngörülü bir şekilde bir sonraki beklenen paketin başlıklarını oluşturmasına ve doğrulamasına neden olmak için yalnızca mantıksal bir sıra numarası ve kısmi bir sağlama toplamı gönderir. Genel olarak, FO durumu tüm statik alanları ve çoğu dinamik alanı sıkıştırır. SO durumu, bir sıra numarası ve sağlama toplamı kullanarak tüm dinamik alanları öngörülü olarak sıkıştırıyor.

Kompresör durumları arasındaki geçişler

Yukarıdaki durumlar arasındaki geçişler, kompresör:

  • çok fazla varyasyon içeren bir paketi sıkıştırır
  • dekompresörden olumlu / olumsuz bir geri bildirim alır
  • bağlamı periyodik olarak yeniler

İkinci Derece ROHC başlıkları - 1 baytlık başlıklar

Tipik bir ROHC uygulaması, terminali, 40 baytlık IPv4 / UDP / RTP veya 60 baytlık IPv6 / UDP / RTP (yani VoIP) için 1 baytlık bir ROHC başlığının ikame edilebildiği İkinci Derece durumuna getirmeyi amaçlayacaktır. başlık. Bu durumda, 8 bitlik ROHC başlığı üç alan içerir:

  • 1 bitlik paket tipi bayrak (yalnızca daha uzun ROHC başlıkları için '1' olarak ayarlanır)
  • 4 bitlik bir sıra numarası (temel çerçeveden -1 ... +14 paket aralığı ile)
  • 3 bitlik bir CRC

Dekompresör durumları

Dekompresörün durum makinesi aşağıdaki üç durumu tanımlar:

  • Bağlam Durumu Yok
  • Statik Bağlam Durumu
  • Tam Bağlam Durumu

Yukarıdaki durumlar arasındaki geçişler, dekompresör:

  • bir paketi başarıyla açar
  • birkaç paketi açmada başarısız

Sağlamlık

Sıra numarası (SN) alanının boyutu, devam etmek için kompresörün sıfırlanması gerekmeden önce ROHC'nin kaybedebileceği paket sayısını yönetir. W-LSB algoritması, SN'yi sağlam bir şekilde sıkıştırmak için kullanılır. 1 ve 2 baytlık ROHC paketlerindeki sıra numarasının boyutu, sırasıyla ya 4 bit (-1 / + 14 kare ofseti) ya da 6 bittir (-1 / + 62 kare ofseti), böylece ROHC en fazla 62 kayıp tolere edebilir 1-2 bayt başlığa sahip çerçeveler.

Ek sıkıştırma profilleri

RFC 3095 genel bir sıkıştırma mekanizması tanımlar. Belirli protokol başlıklarına ayrılmış yeni sıkıştırma profilleri tanımlanarak genişletilebilir. Yeni protokolleri sıkıştırmak için yeni RFC'ler yayınlandı:

  • RFC 3843 IP başlıkları veya IP tünelleri için bir sıkıştırma profili tanımlar.
  • RFC 4019 UDP-Lite / IP ve RTP / UDP-Lite / IP başlıkları için bir sıkıştırma profili tanımlar.
  • RFC 6846 TCP / IP başlıkları için bir sıkıştırma profili tanımlar.

Daha yeni ROHC RFC'ler

Yayınlanan iki yeni RFC var RFC 4995 ve RFC 5225 ROHC'yi yorumlamaya ve uygulamaya çalışırken bazılarının karşılaştığı kafa karışıklığını gidermek için. İlk belge bir ROHC çerçevesini tanımlarken, ikincisi yerleşik ROHC profillerinin daha yeni sürümlerini tanımlar.

Ayrıca bakınız

Referanslar

  1. ^ Michael Dosch ve Steve Kilisesi. "Yayın Stüdyosunda VoIP". Axia Audio. Arşivlenen orijinal 2011-10-07 tarihinde. Alındı 2011-06-21.

Dış bağlantılar