sip , eng. Session Initiation Protocol , Session Initiation Protocol - tiedonsiirtoprotokolla, joka kuvaa menetelmän käyttäjän viestintäistunnon muodostamiseksi ja lopettamiseksi, mukaan lukien multimediasisällön vaihto ( IP-puhelut , video- ja äänikonferenssit , pikaviestit , online-pelit ) [1] .
Tämä protokolla kuvaa, kuinka asiakassovellus (esimerkiksi softphone ) voi pyytää yhteyden aloittamista toiselta, mahdollisesti fyysisesti etäasiakkaalta samassa verkossa, käyttämällä sen yksilöllistä nimeä. Protokolla määrittelee tavan luoda viestintäkanava ja neuvotella protokollia asiakkaiden välistä tiedonvaihtoa varten (esim. RTP -protokollaa käytetään puhedatan vaihtoon ). Tällaisia kanavia voidaan lisätä tai poistaa muodostetun istunnon aikana sekä liittää ja katkaista lisäasiakkaita (eli neuvottelupuhelu tarjotaan, kun useampi kuin kaksi osapuolta saa osallistua vaihtoon). SIP määrittää myös istunnon päättymisjärjestyksen [2] .
SIP :n on kehittänyt IETF MMUSIC Working Group [3] . Protokollaa alkoivat kehittää vuonna 1996 Henning Schulzrinne ( Columbia University ) ja Mark Handley ( University College London ). Marraskuussa 2000 SIP hyväksyttiin 3GPP - signalointiprotokollaksi ja IMS-arkkitehtuurin ydinprotokollaksi ( muunnos 3GPP TS.24.229 [4] ) [5] . SIP on H.323 :n ohella yksi protokollista, joita käytetään aktiivisesti äänen siirtoon Internetissä ( Voice over IP ) .
MMUSIC-työryhmä perusti protokollan seuraaviin periaatteisiin:
SIP-asiakkaat käyttävät perinteisesti TCP- tai UDP - porttia 5060 SIP-verkkoelementtien yhdistämiseen. Periaatteessa SIP:tä käytetään ääni- ja videopuheluiden muodostamiseen ja katkaisemiseen. Samalla sitä voidaan käyttää kaikissa muissa sovelluksissa, joissa tarvitaan yhteyttä, kuten yleisäänentoistojärjestelmissä, mobiilipäätelaitteissa ja niin edelleen. On olemassa suuri määrä SIP:hen liittyviä RFC :itä , jotka määrittelevät tällaisten sovellusten toiminnan. Itse ääni- ja videodatan siirtämiseen käytetään muita siirtoprotokollia, useimmiten RTP .
SIP:n kehittämisen päätavoitteena oli luoda IP -pohjainen signalointiprotokolla, joka voisi tukea olemassa olevan PSTN :n tarjoamia laajennettuja puhelunkäsittelyominaisuuksia ja palveluita . SIP-protokolla itsessään ei määrittele näitä toimintoja, vaan keskittyy vain käyttäjän rekisteröintiin, puhelun muodostamiseen ja lopettamiseen sekä niihin liittyvään signalointiin. Samalla se on suunniteltu tukemaan sellaisia verkon toiminnallisia elementtejä kuin välityspalvelimet (välityspalvelimet) ja käyttäjäagentit (käyttäjäagentit). Nämä elementit tarjoavat peruspalveluiden joukon: soittaminen, soittaminen puhelimeen, tilaajan ääni-ilmoitus puhelun tilasta.
SIP-pohjaiset puhelinverkot voivat myös tukea SS-7 :n tyypillisesti tarjoamia kehittyneempiä palveluita huolimatta näiden kahden protokollan välisistä merkittävistä eroista. SS-7:lle on ominaista monimutkainen, keskitetty älyverkko ja yksinkertaiset, ei-älykkäät päätelaitteet (perinteiset puhelimet). SIP päinvastoin vaatii hyvin yksinkertaisen (ja siksi erittäin skaalautuvan) verkon, jonka reunassa oleviin päätyelementteihin on sisäänrakennettu älykkyys (fyysisiksi laitteiksi tai ohjelmiksi rakennetut päätteet).
SIP:tä käytetään yhdessä useiden muiden protokollien kanssa ja se osallistuu vain viestintäistunnon signalointiosaan. SIP toimii SDP :n siirtotienä , joka kuvaa istunnon sisällä tapahtuvan median lähetyksen parametrit, kuten käytetyt IP - portit ja koodekit . Tyypillisessä sovelluksessa SIP-istunnot ovat yksinkertaisesti RTP -pakettien virtoja . RTP on ääni- ja videodatan suora välittäjä.
Standardin ensimmäinen ehdotettu versio (SIP 2.0) määriteltiin RFC 2543 :ssa . Protokollaa jalostettiin edelleen RFC 3261 :ssä , vaikka monet toteutukset perustuvat edelleen standardin väliversioihin. Huomaa, että versionumero on edelleen 2.0.
SIP käyttää sähköpostiosoitteen kaltaista osoitetta ollakseen vuorovaikutuksessa olemassa olevien IP-verkkosovellusten kanssa ja tarjotakseen käyttäjien liikkuvuuden . Soitto- ja kutsuosoitteet ovat Uniform Resource Pointers URI :ita , ns. SIP URI :ita , yleensä muodossa sip:идентификатор@домен, jossa "tunniste" on tilaajan nimi tai puhelinnumero ja "domain" määrittää palvelimen tai IP-PBX:n, jonka voi määrittää verkkotunnuksen nimi tai IP-osoite.
Esimerkkejä:
URI-standardi on määritelty RFC 3986 :ssa .
Osoitteessa on kaksi osaa. Ensimmäinen osa on verkkotunnukseen tai työasemaan rekisteröidyn käyttäjän nimi. Osoitteen toinen osa määrittää verkkoalueen nimen, isäntä- tai IP-osoitteen. Jos toinen osa identifioi puhelinyhdyskäytävän, niin ensimmäinen osa ilmoittaa tilaajan puhelinnumeron.
Käyttäjätunnukset ovat yksinkertaisesti aakkosnumeerisia tunnisteita. IP-puhelimessa käytetään pääsääntöisesti puhtaasti digitaalisia tunnisteita ("numeroita") klassisten puhelinverkkojen laajentamisen / korvaamisen helpottamiseksi. Paikalliset puhelinnumerot ovat yleensä 2-3-4-numeroisia.
Yhdyskäytävälle välitettävä puhelinnumero on mikä tahansa sen kautta saatavilla, se voi olla joko paikallisliittymän numero tai matkapuhelin- tai lankapuhelinnumero. Yhdyskäytävän osoite (IP-osoite tai verkkotunnus) asetetaan puhelimen tai asiakasohjelman asetuksissa, ja käyttäjän tarvitsee vain valita numero soittaakseen.
SIP-protokollalla on asiakas-palvelin-arkkitehtuuri.
Asiakas lähettää pyynnöt, jotka ilmoittavat, mitä se haluaa vastaanottaa palvelimelta. Palvelin vastaanottaa ja käsittelee pyyntöjä ja antaa vastauksia, jotka sisältävät ilmoituksen pyynnön onnistumisesta, virheilmoituksen tai asiakkaan pyytämiä tietoja.
Puhelupalvelu on hajautettu SIP-verkon eri osien kesken. Pääasiallinen yhteydenhallintatoimintoja toteuttava toiminnallinen elementti on käyttäjäpääte. Muut verkon osat voivat olla vastuussa puheluiden reitittämisestä ja joskus tarjota lisäpalveluita.
Kun asiakas ja palvelin on toteutettu päätelaitteessa ja ovat suoraan vuorovaikutuksessa käyttäjän kanssa, niitä kutsutaan User Agent Client ( englanniksi UAC , user agent client) - ja User Agent Server ( englanniksi UAS , user agent server). Jos laitteessa on sekä UAC että UAS, sitä kutsutaan käyttäjäagentiksi ( UA , user agent) ja se on pohjimmiltaan SIP -pääte .
Palvelin ( UAS ) ja asiakas ( UAC ) voivat olla vuorovaikutuksessa suoraan käyttäjän kanssa. Muut SIP- asiakkaat ja -palvelimet eivät voi tehdä tätä.
Välityspalvelin ( englanninkielisestä välityspalvelimesta - "edustaja") edustaa käyttäjän etuja verkossa. Se hyväksyy pyynnöt, käsittelee ne ja suorittaa tarvittavat toimenpiteet. Välityspalvelin koostuu asiakas- ja palvelinosasta, joten se voi vastaanottaa puheluita, aloittaa pyyntöjä ja palauttaa vastauksia.
Välityspalvelin ei saa muuttaa lähetettyjen viestien rakennetta ja sisältöä, vaan ainoastaan lisää osoitetietonsa erityiseen Via-kenttään.
Välityspalvelimia on kahdenlaisia
Välityspalvelin voi vastauksena ensimmäiseen pyyntöön ilmoittaa käyttäjälle lisätodennuksen tarpeen - vähintään sisäänkirjautumisen (vastaus 407 Proxy-todennus vaaditaan ), sis. digitaalinen todennus turvallisuuden takaamiseksi.
B2BUA - ( englanniksi back-to-back user agent , kirjaimellisesti: "back-to-back user agent") - palvelimen loogisen elementin muunnos SIP-protokollaa käyttävissä sovelluksissa. B2BUA on konseptiltaan samanlainen kuin SIP-välityspalvelin , mutta siinä on perustavanlaatuisia eroja. B2BUA-palvelin toimii samanaikaisesti usean (yleensä kahden) päätelaitteen - päätelaitteen kanssa jakaen puhelun tai istunnon eri osiin. B2BUA toimii jokaisen kohteen kanssa erikseen, UAS:na - suhteessa aloittajaan ja UAC:na - suhteessa puhelun vastaanottavaan päätteeseen. Tällöin signalointiviestit lähetetään istunnon sisällä molempiin suuntiin synkronisesti, vaikka päätöksen viestin lähetystarpeesta ja sen muodosta tekee B2BUA kullekin lohkolle erikseen. Jokainen signalointikerroksen yhteyden (viestintäistunnon) osallistuja on vuorovaikutuksessa B2BUA:n kanssa kuin päätelaitteen kanssa, vaikka todellisuudessa palvelin on välittäjä. Tämä näkyy B2BUA-palvelimen lähettämien viestien osoitekentissä (kuten From, To ja Contact). Siten keskeinen ero B2BUA:n välillä on kaikkien puheluosien täysin riippumaton signalointi. Tämä tarkoittaa erityisesti sitä, että yksilöllisiä tunnisteita käytetään vuorovaikutuksessa kunkin yksittäisen käyttäjän kanssa viestintäistunnon aikana, ja eri sivustojen samojen viestien sisältö on erilainen. Päätelaitteiden käyttäjäagentit voivat olla vuorovaikutuksessa B2BUA:n kanssa ja välityspalvelinten osallistuessa.
B2BUA-palvelin voi tarjota seuraavat ominaisuudet:
Melko usein B2BUA on osa mediayhdyskäytävää hallitakseen mediavirtoja istunnon aikana. Signaling Gateway, joka on osa Connection/Session Border Controlleria , on erinomainen esimerkki B2BUA-sovelluksesta.
Uudelleenohjauspalvelinta käytetään puhelun ohjaamiseen käyttäjän nykyiseen sijaintiin . Uudelleenohjauspalvelin ei katkaise puheluita eikä aloita omia pyyntöjään, vaan ilmoittaa vain tarvittavan päätteen tai välityspalvelimen osoitteen käyttämällä 3XX-luokan vastauksia ( 301 Siirretty pysyvästi tai 302 Siirretty väliaikaisesti ). Näitä tarkoituksia varten uudelleenohjauspalvelin voi olla vuorovaikutuksessa SIP-rekisteröijän tai sijaintipalvelimen kanssa.
Käyttäjä ei kuitenkaan saa käyttää uudelleenohjauspalvelinta yhteyden muodostamiseen, jos hän itse tietää vaaditun käyttäjän nykyisen osoitteen.
SIP - protokolla tarkoittaa käyttäjän liikkuvuutta, eli käyttäjä voi liikkua verkon sisällä hankkimalla uuden osoitteen. Siksi SIP:llä on rekisteröintimekanismi - ilmoitus uudesta osoitteesta käyttäjäagentilta. Rekisteröintipalvelin tai rekisterinpitäjä ( rekisterinpitäjä ) korjaa ja tallentaa käyttäjän nykyisen osoitteen ja on säännöllisesti päivitettävä osoitetietokanta. Yleensä käyttäjä antaa rekisteröintipalvelimelle pyynnön avulla osoitetietonsa, kuten IP-osoitteen tai verkkotunnuksen ja tilaajan puhelinnumeron REGISTER. Palvelin voi vahvistaa onnistuneen rekisteröinnin ( 200 OK) tai hylätä, jos tiedot tarkistetaan ja käyttäjätiliä ei löydy ( 404 Not found) tai rekisteröityminen käyttäjälle on tällä hetkellä kielletty ( 403 Forbidden). Rekisterinpitäjä voi ilmoittaa käyttäjän sisäänkirjautumisen tarpeen vahvistusta varten ( 401 Unauthorized), kun taas se voi tarjota asiakkaalle todennuksen salatun salasanan perusteella. Laite tai ohjelmisto, joka ei käytä SIP-protokollaa (esimerkiksi DBMS , MS Exchange , RADIUS-palvelin jne.), voi toimia tietolähteenä käyttäjän todennusta varten. Käyttäjän päätteen rekisteröinnillä palvelimelle on tietty "elinikä" ja se on vahvistettava REGISTERasiakkaan uudella pyynnöstä, muuten osoitetiedot voivat hävitä. Asiakas voi myös lähettää pyynnön ilman rekisteröintiaikaa - pyynnön pakottaa osoitetietojen poistaminen palvelimelta (rekisteröinnin loppuun saattaminen).
SIP-verkkojen erilaisissa toteutuksissa voi olla rekisteröintipalvelimen ja muiden palvelimien yhdistelmä yhdessä sovelluksessa tai laitteessa, joka toimii yhden pistorasian kautta yhdessä portissa (yleensä UDP / 5060) - eli yksi vastaanottopiste. ja pyyntöjen käsittelyä. Niin usein rekisterinpitäjät yhdistetään uudelleenohjauspalvelimeen, B2BUA- tai SIP-välityspalvelimeen. Esimerkiksi monet ohjelmistovaihteet (esimerkiksi Asterisk , Yate , RTU ) sisältävät SIP-rekisteröinnin toiminnot, joissa varmistetaan kunkin käyttäjän rekisteröintitiedot. Tieto käyttäjän kyvystä rekisteröityä ja muodostaa yhteyksiä määräytyy tässä tapauksessa hänen yksittäisen tilinsä perusteella. IP-puhelimen tilaajalaitteet ( puhelimet , tilaajayhdyskäytävät ) puolestaan vaativat useimmissa tapauksissa pakollisen ennakkorekisteröinnin palvelimelle jatkotyöskentelyä varten puhelinverkossa.
Tämän seurauksena IP-puhelinjärjestelmä voi näyttää samanlaiselta kuin solukkojärjestelmä - päälle kytkettynä kaikki tilaajalaitteet rekisteröityvät kytkimeen (PBX) ja sen jälkeen voivat soittaa ja vastaanottaa puheluita sen kautta, mikä joko ohjaa pyynnön toiseen päähän. käyttäjälle tai välittää pyynnön toiselle kytkimelle.
Käyttäjä voi liikkua eri verkkojen sisällä, lisäksi käyttäjän oikea osoite voi olla tuntematon, vaikka hänen numeronsa olisi tiedossa. Tämä koskee erityisesti numeron siirrettävyyspalvelua (LNP/MNP) . Tällaisten ongelmien ratkaisemiseksi on olemassa mekanismi , jolla määritetään käyttäjän sijainti käyttämällä kolmannen osapuolen työkaluja, jotka eivät liity suoraan SIP- sijaintipalvelimeen , joka tallentaa käyttäjän nykyisen osoitteen ja on säännöllisesti päivitettävä osoitetietokanta.
Käyttäjä, joka tarvitsee toisen käyttäjän osoitetietoja yhteyden muodostamiseen, ei ota yhteyttä sijaintipalvelimeen suoraan. Tämän toiminnon suorittavat muut SIP-palvelimet, jotka käyttävät LDAP- , R WHOIS- , ENUM- , RADIUS- tai muita protokollia.
SIP- protokollaviestit (pyynnöt ja vastaukset) ovat RFC 2279 :n mukaisesti koodattuja tekstijonoja . SIP - viestien rakenne ja syntaksi ovat samat kuin HTTP - protokollassa .
SIP-viestin rakenne |
Aloituslinja |
---|
Otsikot |
Tyhjä rivi |
Viestin runko |
KUTSU- pyyntö esimerkki :
KUTSU sip:[email protected] SIP/2.0 Record-Route: <sip:[email protected];lr> Lähde: SIP/2.0/UDP 10.0.0.10; haara=z9hG4bK3af7.0a6e92f4.0 Lähde: SIP/2.0/UDP 192.168.0.2:5060;branch=z9hG4bK12ee92cb;rport=5060 Lähettäjä: "78128210000" <sip:[email protected]>;tag=as149b2d97 Vastaanottaja: <sip:[email protected]> Ota yhteyttä: <sip:[email protected]> Puhelutunnus: [email protected] CSeq: 103 KUTSU Max hyökkääjät: 16 Päivämäärä: ke, 10. tammikuuta 2001 13:16:23 GMT Salli: KUTSU, HYVÄKSY, PERUUTA, ASETUKSET, HEIKAI, VIITE, TILAA, ILMOITA Tuettu: korvaa Sisältötyyppi: sovellus/sdp Sisällön pituus: 394 v=0 o = juuri 3303 3304 IN IP4 10.0.0.10 s = istunto c=IN IP4 10.0.0.10 t = 0 0 m = ääni 40358 RTP/AVP 0 8 101 a=rtpmap:0 PCMU/8000 a=rtpmap:8 PCMA/8000 a=rtpmap:101 phone-event/8000 a=fmtp:101 0-16 a=silenceSupp:off - - - - a=sendrecvSIP-protokollan alkuperäinen versio ( RFC 3261 ) määritteli kuusi pyyntötyyppiä. Pyyntöjen avulla asiakas ilmoittaa nykyisen sijainnin, kutsuu käyttäjiä osallistumaan viestintäistuntoihin, muokkaa jo muodostettuja istuntoja, lopettaa ne jne. Pyynnön tyyppi ilmoitetaan aloitusrivillä.
Jatkossa protokollaa laajennettiin, siihen lisättiin useita muita pyyntötyyppejä:
Vastauksissa pyyntöihin raportoidaan pyynnön käsittelyn tulos tai välitetään pyydetyt tiedot. SIP - protokolla peri vastausten rakenteen ja niiden tyypit HTTP - protokollalta . On määritelty kuusi tyyppistä vastetta, jotka kantavat erilaisia toiminnallisia kuormia. Vastaustyyppi on koodattu kolminumeroiseksi numeroksi, joista tärkein on ensimmäinen numero, joka määrittää vastausluokan:
SIP-protokolla on ohjausprotokolla suoratoistodatayhteyden muodostamiseen, muokkaamiseen ja katkaisemiseen. Mediavirtojen siirtoparametrit on kuvattu SIP-protokollassa SDP :n (Session Description Protocol) avulla. Suoratoistomediaa voidaan lähettää useilla eri tavoilla, joista suosituimpia ovat RTP- ja RTCP -kuljetusprotokollat .
SIP-protokolla määrittelee 3 pääskenaariota yhteyden muodostamiselle: välityspalvelimen, välityspalvelimen ja suoraan käyttäjien välillä. Skenaariot vaihtelevat sen mukaan, kuinka kutsuttu käyttäjä löydetään ja kutsutaan. Yhteyden muodostamisen perusalgoritmit on kuvattu RFC 3665 :ssä .
Alla olevassa esimerkissä medialiikenne välitetään palvelimen kautta. Signalointiviestit segmenteille Alice - B2BUA ja B2BUA - Boris ovat täysin riippumattomia ja ne suoritetaan eri istunnoissa (ainakin istuntojen kohde- ja lähetysosoitteet sekä puhelutunnus muuttuvat). Liisa terminaali ei tiedä Borisin terminaalin todellista sijaintia ja päinvastoin. Tämä voi näyttää vuorovaikutukselta joidenkin softswitchien tai istuntorajojen ohjaimien (SBC) kautta .
Vuorovaikutuksessa perinteisten SS-7- signalointia käyttävien puhelinverkkojen kanssa kehitettiin SIP-protokollan muunnelmia puhelimille: Session Initiation Protocol for Phones (SIP-T) ja Session Initiation Protocol Internetworking (SIP-I). SIP-I-protokollan on kehittänyt ITU-T , suositus Q.1912.5 [6] , ja SIP-T:n kehitti IETF ja se on kuvattu RFC 3372:ssa. Näiden SIP-protokollan muutosten päätehtävänä on siirtää läpinäkyvästi ISUP -viestit IP-verkon kautta. Tämä tehtävä suoritetaan kapseloimalla SS -signalointiyksiköt SIP-sanomiin. Kaikki protokollien väliseen vuorovaikutukseen tarvittavat tehtävät ratkaistiin SIP-protokollan perusteella:
Yhteentoimivuusvaatimus | SIP-T-toiminto |
---|---|
ISUP-signaloinnin läpinäkyvyys | ISUP-kapselointi SIP-viestirungossa |
Mahdollisuus reitittää SIP-viestejä ISUP-parametreista riippuen | ISUP-parametrien käännös SIP-sanoman otsikossa |
Osoitetietojen kääntäminen muodostetun yhteyden aikana | INFO-menetelmällä |
SIP on ihmisten luettavissa ja jäsennelty pyyntöjen ja vastausten suhteen. SIP:n kannattajat väittävät myös, että se on yksinkertaisempi kuin H.323 [7] . Kuitenkin jotkut[ kuka? ] ovat taipuvaisia ajattelemaan, että vaikka SIP:n alkuperäinen tavoite oli yksinkertaisuus, siitä on nykymuodossaan tullut yhtä monimutkainen kuin H.323. muu[ kuka? ] uskovat, että SIP on tilaton protokolla, mikä helpottaa vikasieto- ja muiden ominaisuuksien toteuttamista, jotka ovat vaikeita tilapitoisissa protokollissa, kuten H.323. SIP ja H.323 eivät rajoitu puheviestintään, ne voivat palvella mitä tahansa viestintäistuntoa puheesta videoon tai tuleviin sovelluksiin.
Vertaa parametreja | SIEMAILLA | H.323 |
---|---|---|
Lisäpalvelut | Molempien protokollien tukemat palvelut ovat suunnilleen samat. | |
Käyttäjien henkilökohtainen liikkuvuus | Siinä on hyvä joukko liikkuvuutta tukevia työkaluja | Henkilökohtainen liikkuvuus tuettu, mutta vähemmän joustava |
Protokollan laajennettavuus | Kätevä laajennettavuus, helppo yhteensopivuus aikaisempien versioiden kanssa | Laajennettavuutta tuetaan, mutta siinä on useita monimutkaisia tekijöitä |
Verkon skaalautuvuus | Molemmat protokollat tarjoavat hyvän verkon skaalautuvuuden | |
Yhteyden muodostusaika | Yksi kauppa riittää | Tarvitaan useita tapahtumia |
Protokollan monimutkaisuus | Yksinkertainen, vähän pyyntöjä, tekstiviestimuoto | Monimutkainen, monia pyyntöjä ja protokollia, viestien binääriesitys |
Laitteiston yhteensopivuus | Käytännössä ei yhtään. Jokainen SIP-laitteiden valmistaja noudattaa vain suosituksia (RFC), joista hän pitää, koska näiden suositusten joukko on erittäin suuri. Itse asiassa vain peruspuhelu on yhteensopiva | Melkein valmis. Standardit ovat vakiintuneita ja niillä on selkeät eritelmät |
RFC 3261 :n erillinen osa on omistettu SIP-protokollaa käyttäville tietoturvakysymyksille . Signalointiliikenteen salaus on mahdollista siirtotasolla käyttämällä TLS :ää TCP/UDP:n kautta. Lisäksi on kehitetty SIPS -standardi ( englanniksi SIPS ), joka asettaa lisäsopimuksia suojattuun tiedonsiirtoon SIP:n kautta. SRTP - protokollaa käytetään multimediasisällön salaamiseen .
Sanakirjat ja tietosanakirjat | |
---|---|
Bibliografisissa luetteloissa |
IP - puhelinohjelmisto | |
---|---|
Protokollat | |
Asiakasohjelmisto | |
Palvelinohjelmisto | |
Web palvelut | |
vertailu |