Wprowadzenie do telefonii VoIP



Podobne dokumenty
A. Ciarkowski, KSM WETI PG. Transmisja multimediów w sieciach IP Protokoły Voice/Video over Data Usługi multimedialne

Bezpieczny system telefonii VoIP opartej na protokole SIP

Transmisja danych multimedialnych. mgr inż. Piotr Bratoszewski

1. Wprowadzenie Środowisko multimedialnych sieci IP Schemat H

Przesył mowy przez internet

Wymagania i zalecenia dla usługi głosowej w Sieci FreePhone. MASH.PL Wymagania i zalecenia dla usługi głosowej w Sieci FreePhone Strona 1

Ilość sztuka 1 PBX/IP Opis minimalnych wymagań 1 W zakresie sprzętowym 1.1 Porty: - Min 1 port WAN - RJ-45 (10/100Base-TX, automatyczne wykrywanie)

Wideokonferencje MGR INŻ. PAWEŁ SPALENIAK

Telefonia Internetowa VoIP

Bezpieczeństwo VoIP SIP & Asterisk. Autor: Leszek Tomaszewski ltomasze@elka.pw.edu.pl

Sieci Komputerowe Modele warstwowe sieci

Wykład 4: Protokoły TCP/UDP i usługi sieciowe. A. Kisiel,Protokoły TCP/UDP i usługi sieciowe

jest protokołem warstwy aplikacji, tworzy on sygnalizację, aby ustanowić ścieżki komunikacyjne, a następnie usuwa je po zakończeniu sesji

TELEFONIA W SIECI IP

Krajowe Sympozjum Telekomunikacji i Teleinformatyki KSTiT Autorzy: Tomasz Piotrowski Szczepan Wójcik Mikołaj Wiśniewski Wojciech Mazurczyk

VoIP - integracja i skalowalność. Piotr Misiowiec, Dyrektor Centrum Szkoleniowego CLICO Sp. z o.o., CCSI

Testy współpracy. Asterisk z techniką WebRTC

Budowa głosowych usług operatorskich z zastosowaniem protokołu SIP. Piotr Wojciechowski (CCIE #25543) Starszy Konsultant ds. Sieci PLNOG 2010, Kraków

KONCEPCJA APLIKACJI VoIP WYKORZYSTUJĄCEJ MECHANIZMY IPSec

Dr Michał Tanaś(

Uwaga!!! Założono, że router jest poprawnie podłączony i skonfigurowany do obsługi dostępu do Internetu.

Planowanie telefonii VoIP

USŁUGI DODATKOWE W SIECIACH BEZPRZEWODOWYCH VoIP oraz multimedia w sieciach WiFi problemy

TELEFONIA INTERNETOWA

Marek Parfieniuk, Tomasz Łukaszuk, Tomasz Grześ. Symulator zawodnej sieci IP do badania aplikacji multimedialnych i peer-to-peer

Bramka VoIP FXS GXW4004 / GXW4008

2007 Cisco Systems, Inc. All rights reserved.

Protokoły sieciowe - TCP/IP

Podstawowe protokoły transportowe stosowane w sieciach IP cz.2

DR INŻ. ROBERT WÓJCIK DR INŻ. JERZY DOMŻAŁ

Wprowadzenie...13 CzÍúÊ I. PSTN...17 Rozdzia 1. Przeglπd sieci PSTN i jej porûwnanie z Voice over IP...19

Sygnalizacja Kontrola bramy Media

Połączenia VoIP z firmą Slican

ZiMSK. Konsola, TELNET, SSH 1

Dr Michał Tanaś(

Profesjonalne Platformy VOIP. Dariusz Dwornikowski

Sygnalizacja Kontrola bramy Media

Podstawowe protokoły transportowe stosowane w sieciach IP cz.1

Sieci komputerowe - warstwa transportowa

ZAŁOŻENIA PROTOKOŁU RTP

Pomiary w technice studyjnej. TESTY PESQ i PEAQ

Stos protokołów TCP/IP (ang. Transmission Control Protocol/Internet Protocol)

Grzegorz Gliński. 1. Opis wykonanego ćwiczenia

Technologia VoIP Podstawy i standardy

Transmisja multimediów. mgr inż. Adam Kurowski, KSM WETI PG Wykład z przedmiotu Systemy i Terminale Multimedialne, Sem. 6

PBS. Wykład Zabezpieczenie przełączników i dostępu do sieci LAN

pasja-informatyki.pl

Sterowanie ruchem w sieciach szkieletowych

Transmisja danych multimedialnych. mgr inż. Piotr Bratoszewski

Seminarium. Wojciech Mazurczyk

Sieci komputerowe. Protokoły warstwy transportowej. Wydział Inżynierii Metali i Informatyki Przemysłowej. dr inż. Andrzej Opaliński.

Rok akademicki: 2012/2013 Kod: IIN SK-n Punkty ECTS: 4. Kierunek: Informatyka Specjalność: Systemy komputerowe

Programowanie Sieciowe 1

ZiMSK. VLAN, trunk, intervlan-routing 1

Akademickie Centrum Informatyki PS. Wydział Informatyki PS

MODEL WARSTWOWY PROTOKOŁY TCP/IP

Adres strony internetowej, na której Zamawiający udostępnia Specyfikację Istotnych Warunków Zamówienia:

Kurs Ethernet przemysłowy konfiguracja i diagnostyka. Spis treści. Dzień 1

Implementacja protokołu komunikacyjnego

Podstawy Transmisji Danych. Wykład IV. Protokół IPV4. Sieci WAN to połączenia pomiędzy sieciami LAN

NGN/IMS-Transport (warstwa transportowa NGN/IMS)

Plan wykładu. 1. Sieć komputerowa 2. Rodzaje sieci 3. Topologie sieci 4. Karta sieciowa 5. Protokoły używane w sieciach LAN 6.

Pomiary jakości w dostępie do Internetu

PLNOG październik 2010

Adresy w sieciach komputerowych

Bramka VoIP (Voice over IP gateway) Implementacja VoIP w routerach DrayTek

CISCO SPA303-G2. KoTeIn Karol Młyńczak Al. Wojska Polskiego 40/ Pruszków NIP: REGON:

Wykład Nr Sieci bezprzewodowe 2. Monitorowanie sieci - polecenia

TCP/IP. Warstwa łącza danych. mgr inż. Krzysztof Szałajko

Rys. 1. Wynik działania programu ping: n = 5, adres cyfrowy. Rys. 1a. Wynik działania programu ping: l = 64 Bajty, adres mnemoniczny

(12) TŁUMACZENIE PATENTU EUROPEJSKIEGO (19) PL (11) PL/EP (96) Data i numer zgłoszenia patentu europejskiego:

TCP/IP. Warstwa aplikacji. mgr inż. Krzysztof Szałajko

Brinet sp. z o.o. wyłączny przedstawiciel DrayTek w Polsce

PLNOG 2009r. Wyzwania i dobre praktyki w budowaniu oferty i infrastruktury głosowej. Przemysław Mujta Crowley Sebastian Zaprzalski Datera

Podstawy Informatyki. Inżynieria Ciepła, I rok. Wykład 13 Topologie sieci i urządzenia

Podstawy sieci komputerowych

Akademickie Centrum Informatyki PS. Wydział Informatyki PS

Transmisja głosu w sieci IP - VoIP

transmitowanego głosu

Plan Prezentacji Wprowadzenie Telefonia IP a bezpieczeństwo istotne usługi ochrony informacji i komunikacji w sieci Klasyczna architektura bezpieczeńs

Akademickie Centrum Informatyki PS. Wydział Informatyki PS

Zastosowania PKI dla wirtualnych sieci prywatnych

Protokół IPsec. Patryk Czarnik

ORGANIZACJA ZAJĘĆ WSTĘP DO SIECI

Sieci VPN SSL czy IPSec?

Monitoring wizyjny w sieciach IP. Funkcjonalności kamer IP, projekt, funkcjonowanie i aspekty prawne monitoringu wizyjnego.

Księgarnia PWN: Mark McGregor Akademia sieci cisco. Semestr szósty

MASKI SIECIOWE W IPv4

Protokoły internetowe

Zapewnianie bezbłędności transmisji steganograficznej (Blok tematyczny S2B: Jakość sieci i usług)

Kurs Ethernet przemysłowy konfiguracja i diagnostyka. Spis treści. Dzień 1/2

Protokół DHCP. DHCP Dynamic Host Configuration Protocol

Wykład 2: Budowanie sieci lokalnych. A. Kisiel, Budowanie sieci lokalnych

SYSTEM ŁĄCZNOŚCI PROSTO Z PUDEŁKA

Usługi IMP i konferencyjne

Zarządzanie ruchem i jakością usług w sieciach komputerowych

Sieci komputerowe Warstwa transportowa

DR INŻ. ROBERT WÓJCIK DR INŻ. JERZY DOMŻAŁ

Sieci komputerowe. Wykład 1: Podstawowe pojęcia i modele. Marcin Bieńkowski. Instytut Informatyki Uniwersytet Wrocławski

Strumieniowanie danych

Transkrypt:

Wprowadzenie do telefonii VoIP Teoria vs real life M. Żyromski, A. Ciarkowski Wirtualna Polska S.A. 1

Plan prezentacji Wprowadzenie Zagadnienia sieciowe Protokoły Transmisja mediów w telefonii VoIP 2

VoIP z czym to się je? VoIP Voice over IP Grupy zastosowań pc2phone, phone2pc pc2pc phone2phone 3

Schemat ogólny PC Internet Brama PSTN Telefon Telefon IP PC 4

VoIP wyzwania i problemy Opóźnienia Jitter NATy, firewalle Echo Straty danych Bezpieczeństwo 5

Zagadnienia sieciowe - plan Wybór protokołu transportowego (UDP vs TCP) NATy problemy, sposoby przechodzenia 6

UDP UDP vs TCP TCP Nagłówek 8B Bezpołączeniowy Brak mechanizmu retransmisji i kontroli przepływu Mniejsze opóźnienia Straty Zaburzenia sekwencyjności Nagłówek 20B Połączeniowy Mechanizm retransmisji i kontroli przepływu Większe Opóźnienia Brak strat Zachowanie sekwencyjności Możliwość zagłodzenia ruchu TCP przez UDP Konfiguracja sieci może uniemożliwiać ruch UDP 7

Narzuty protokołu Nagłowek warstwy sieciowej (IP) Nagłówek warstwy transportowej (UDP, TCP) Nagłówek warstwy aplikacyjnej (np. RTP) dane ramki (payload) Przykład: bitrate 16kbps, ramka 20ms Ramka = 40B + nagłówek RTP = 52B + nagłówek UDP = 60B + nagłówek IP = 80B Rzeczywisty bitrate: 32kbps 8

700% Narzuty protokołu 600% narzut [%] 500% 400% 300% UDP, 20ms TCP, 20ms UDP, 10ms TCP, 10ms 200% 100% 0% 0 5000 10000 15000 20000 25000 30000 35000 40000 bitrate [bps] 9

NAT Ograniczona pula adresów IPv4 konieczność stosowania translacji Jakie utrudnienia wprowadza NAT w komunikacji VoIP? P2P Komunikacja w stronę klienta 10

Typy NATów (1) 11 Źródło: wikipedia.org

Typy NATów (2) 12 Źródło: wikipedia.org

STUN (RFC 3489) Simple Traversal of UDP through NATs Umożliwia klientowi uzyskanie informacji o NACie, za którym się znajduje Typ NATa Publiczny (NATowany) adres IP Nie umożliwia obejścia NATów symetrycznych, nie działa dla TCP Serwer STUN posiada dwa adresy IP Detekcja wg maszyny stanów 13

Relaying TURN (Traversal Using Relay NAT) Serwer pełni rolę proxy Działa dla wszystkich typów NATów, także dla TCP Spory koszt utrzymania serwera Rozproszona sieć proxy Skype: ordinary host & super nodes skomplikowane mechanizmy zarządzania siecią 14

UPnP / IGD Internet Gateway Device protocol Wchodzi w skład rodziny protokołów Universal Plug and Play Router/NAT wspierający IGD udostępnia klientowi: Poznanie adresu zewnętrznego Przeglądanie, dodawanie, usuwanie i modyfikacje wiązań NAT 15

NAT informacje dodatkowe Inne sposoby obejścia: komunikacja w drugą stronę komunikacja po sieci LAN, o ile to możliwe Czas życia wiązań Inteligentne NATy: wnikanie w protokół i modyfikacje pakietów w locie brak możliwości tworzenia wiązań dla sesji w ramach LAN 16

Protokoły - plan IAX2 SIP/SDP/RTP 17

IAX2 Inter-Asterisk Exchange, wersja 2 Stworzony w celu łączenia internetowych centralek PBX Asterisk Podstawowe cele: Minimalizacja pasma Redukcja problemów z NATami Dwa protokoły w jednym: sygnalizacja i dane 18

IAX2 Trzy rodzaje ramek Full frame Mini frame Meta frame Wsparcie dla szyfrowania (AES) IAX2 może przenosić oprócz dźwięku także wideo, tekst, obraz Popularna implementacja: iaxclient 19

IAX2 zalety i wady Zalety: Sygnalizacja i dane w jednym strumieniu UDP Trunking Wykorzystanie jednego portu Protokół binarny Wady: Dane przechodzą zawsze przez serwer Prosty protokół (mniejszy zakres zastosowań) Brak standaryzacji (draft, nie RFC) 20

IP Multimedia Subsystem Session Initiation Protocol (RFC 3261-4) Session Description Protocol (RFC 4556) Realtime Transport Protocol (RFC 3550) Wielkie firmy telekomunikacyjne Standardyzacja IETF w formie RFC Rozwiązania praktyczne Podstawa telefonii 3G 21

SIP: główne cechy Protokół tekstowy Transport UDP Podstawowa funkcjonalność: rejestracja i nawiązanie połączenia Rozszerzenie SIMPLE: instant messaging & presence Łączność zza NAT-a 22

SIP: protokół tekstowy Format wiadomości jak w HTTP, obsługa MIME Istotne różnice UTF-8 Kolejność nagłówków Szyfrowanie S/MIME tylko payload! Format tekstowy łatwy do debugowania Bezpieczeństwo! 23

SIP: Transport UDP Brak sesji większa wydajność i skalowalność Stateless proxy Straty wymagana rozbudowana warstwa transakcyjna Alternatywne transporty: TCP i TLS W przyszłości: DTLS 24

SIP: Architektura w wielkim uproszczeniu ;) SIP Client 1 SBC Registrar Media Gateway SIP Client 2 SIP Proxy Sygnalizacja Media 25

SIP: Podstawowa funkcjonalność Rejestracja związanie aktualnego adresu Internetowego klienta (kontaktu) z jego publicznym ID (SIP URL) Nawiązanie połączenia (sesji) metoda INVITE 26

SIP: rozszerzenie SIMPLE Komunikator internetowy Przesyłanie krótkich wiadomości tekstowych metoda MESSAGE Publikowanie informacji o dostępności/statusie użytkownika (presence) Bramka SIP/XMPP 27

SIP: Łączenie zza NAT-a Nagłówek Via Routing symetryczny: rport Mechanizmy keep-alive Wykorzystanie STUN/TURN Zbyt mądre NAT-y 28

Opis sesji w SDP Wymiana informacji o parametrach sesji Typ mediów (audio/video) Transport (RTP) Adresy (IP i port RTP) Obsługiwane kodeki (payload map) Kierunek transmisji 29

SDP: negocjacja kodeka 1. Inicjator przysyła listę obsługiwanych kodeków w SIP INVITE priorytet: kolejność na liście 2. Odbiorca ustala wspólny podzbiór i odsyła zmodyfikowany payload map w odpowiedzi 30

SDP: modyfikacja parametrów sesji Powtórna wiadomość SIP INVITE ze zmodyfikowanym opisem SDP Zastosowanie: funkcja HOLD Zmiana adresu IP RTP na 0.0.0.0 Zmiana kierunku sesji music on hold 31

Transport mediów: RTP Podstawowa funkcjonalność RTP Transmisja kodów DTMF Kodowanie szumu komfortowego RTP via NAT 32

RTP: podstawowa funkcjonalność Porządkowanie pakietów Wykrywanie straty pakietu Identyfikacja nadawców w miksie Identyfikacja ładunku 33

RTP: transmisja kodów DTMF Zastosowanie: automaty IVR i inne aplikacje telefoniczne In-band signalling Kodek telephone-event (RFC 2833) 34

RTP via NAT Mechanizm early media/address & port latching Bezpieczeństwo! Metodologia ICE (draft-ietf-mmusic-ice- 13) 35

Transmisja mediów w VoIP Komponenty Kodeki dźwięku Czynniki pogarszające jakość dźwięku Mechanizmy QoS 36

Komponenty systemu AEC Dekodowanie AGC Jitter Buffer CN VAD PLC DTX Kodowanie Depakietyzacja Pakietyzacja 37

Acoustic Echo Cancellation Przyczyny powstawania echa Czas echa 200-500ms Echo wielokrotne Algorytmy AEC Paradoks tu włączam tam efekt 38

Komponenty systemu AEC Dekodowanie AGC Jitter Buffer CN VAD PLC DTX Kodowanie Depakietyzacja Pakietyzacja 39

Automatic Gain Control Problem dalekiego mikrofonu Algorytm AGC Zakłócenia Szum i łomot Sprzężenia 40

Komponenty systemu AEC Dekodowanie AGC Jitter Buffer CN VAD PLC DTX Kodowanie Depakietyzacja Pakietyzacja 41

VAD/DTX/CN Voice Activity Detection: jak wykryć ciszę? Discontinous Transmission: ograniczenie obciążenia sieci Comfort Noise: halo? jesteś tam? Wsparcie ze strony kodeka 42

Komponenty systemu AEC Dekodowanie AGC Jitter Buffer CN VAD PLC DTX Kodowanie Depakietyzacja Pakietyzacja 43

Packet Loss Concealment Typowe implementacje Powtórzenie pakietu Zastąpienie szumem Powtórzenie z przemiksowaniem z szumem Predykcja liniowa Wsparcie ze strony kodeka Wybór algorytmu PLC 44

Komponenty systemu AEC Dekodowanie AGC Jitter Buffer CN VAD PLC DTX Kodowanie Depakietyzacja Pakietyzacja 45

Kodeki dźwięku Kodek (CODEC): Koder/Dekoder; algorytm kodowania (kompresji) dźwięku Kryteria wyboru kodeka Ocena jakości dźwięku kodowanego 46

Kodek: kryteria wyboru Złożoność obliczeniowa Stopień kompresji Prosty kodek niska kompresja (G.711 64kbps) Złożony kodek wysoka kompresja (G.729 8kbps) Jakość dźwięku Licencja! 47

Kodek: ocena jakości Skala MOS (Mean Opinion Score) wynik testów odsłuchowych (subiektywnych) Symulacja MOS via PESQ (Perceptual Evaluation of Speech Quality ITU-T P.862) Miara obiektywna Wady! 48

Kodek: jakość/pasmo 49

Czynniki pogarszające jakość Kompresja Straty pakietów Opóźnienie Jitter 50

Kompresja Pamiętamy wykres narzut protokołu? Zbyt wysoka kompresja utrata jakości bez zysku Optymalny bitrate w sieci IPv4 ~16-20kbps 51

Straty pakietów Typowy transport UDP Utrata pojedynczego pakietu - z reguły niezauważalna przy dobrym algorytmie PLC Straty sekwencyjne 52

Opóźnienie Czas niekomfortowy według standardów telekomunikacyjnych 35ms Typowo w VoIP 200-300ms Przyczyny Buforowanie w karcie dźwiękowej (40-100ms) Bezwładność (latency) systemu operacyjnego Buforowanie w sieci 53

Jitter Opóźnienie zmienne w czasie Przyczyny Duży kwant czasu procesora (rzędu długości ramki audio) Zmienne obciążenie routerów Dryft zegara 54

Jitter: przeciwdziałanie Buforowanie Adaptacja długości bufora Synteza ramek Sklejanie ramek Związek z PLC Optymalny moment adaptacji? 55

Mechanizmy QoS Znakowanie pakietów IP Protokół RSVP 56

QoS: znakowanie pakietów Pole Type of Service w nagłówku IP Mała ziarnistość kontroli Niejednoznaczna interpretacja Bardzo często ignorowane Windows XP i nowsze niemodyfkowalne bez uprawnień administratora, silently ignored 57

QoS: RSVP Resource Reservation Protocol rezerwacja zasobów sieciowych Precyzyjna kontrola min., max. pasmo, żądane gwarancje Traffic shaper wymusza interwał nadawania Stosowanie w Internecie mocno wątpliwe tylko sieci pod kontrolą 58

Dziękujemy! Pytania? 59