• <strike id="fdgpu"><input id="fdgpu"></input></strike>
    <label id="fdgpu"></label>
    <s id="fdgpu"><code id="fdgpu"></code></s>

  • <label id="fdgpu"></label>
  • <span id="fdgpu"><u id="fdgpu"></u></span>

    <s id="fdgpu"><sub id="fdgpu"></sub></s>
    您當前的位置是:  首頁(yè) > 資訊 > 文章精選 >
     首頁(yè) > 資訊 > 文章精選 >

    基于SIP協(xié)議的媒體錄音規范(SIPREC)完整技術(shù)概述

    2019-09-03 13:58:31   作者:james.zhu    來(lái)源:Asterisk開(kāi)源派   評論:0  點(diǎn)擊:


      在當前的語(yǔ)音通信環(huán)境中,除了用戶(hù)非常重視呼叫的用戶(hù)體驗,同時(shí)對其他第三方的業(yè)務(wù)要求也有了新的要求。特別是在某些金融領(lǐng)域,法律咨詢(xún)領(lǐng)域和人力資源領(lǐng)域,雙方電話(huà)溝通需要有完整的通話(huà)錄音,這些錄音可能會(huì )幫助雙方對某些歧義進(jìn)行進(jìn)一步的佐證。但是,隨著(zhù)呼叫中心,IPPBX部署方式的技術(shù)革命,很多呼叫中心,IPPBX已經(jīng)實(shí)現了云部署的方式,以前傳統的錄音方式基本上很難滿(mǎn)足用戶(hù)的需求,市場(chǎng)份額也正在萎縮。在當前主流的部署方式中,使用SBC對接其他業(yè)務(wù)應用是大家正在逐步使用的主要的部署方式。關(guān)于SBC的背景介紹,我們在以前的文章中做過(guò)非常多的關(guān)于SBC以及其功能的介紹,筆者也發(fā)表過(guò)關(guān)于開(kāi)源OpenSIPS電話(huà)錄音的分享。
    • 如何通過(guò)SBC實(shí)現公網(wǎng)注冊SIP話(huà)機演示,實(shí)現聯(lián)通COP對接通話(huà)
    • 圖解邊界會(huì )話(huà)控制器(SBC)的20個(gè)最常用功能
    • SIP系列講座-邊界會(huì )話(huà)控制器-SBC全面剖析
    • 基于OpenSIPS實(shí)現電話(huà)錄音解決方案探討
      為了進(jìn)一步完善SIP呼叫錄音的討論,今天,筆者在以前的錄音分享技術(shù)討論的基礎上,進(jìn)一步討論一些和SIP電話(huà)呼叫中的一些非常細節的說(shuō)明和其相關(guān)的行業(yè)規范,通過(guò)規范和解決方案的示例討論,讀者獲得更多關(guān)于SIP呼叫錄音的技術(shù)策略和部署方式。
      更多技術(shù)分享,關(guān)注SIP技術(shù)學(xué)習
      筆者這里主要討論的內容包括:錄音解決方案背景介紹,關(guān)于SIPREC的技術(shù)細節說(shuō)明(Session Recording Protocol),相關(guān)技術(shù)架構討論,基于SIP的媒體錄音場(chǎng)景規范(SIPREC)以及數據規范的討論,SBC對SIPREC的支持和以及其他問(wèn)題討論。
      1、錄音解決方案背景介紹
      呼叫中心或IPPBX是幫助企業(yè)用戶(hù)和客戶(hù)主要溝通的工具。根據一家美國公司對市場(chǎng)的調查中,在最近幾年,語(yǔ)音仍然是企業(yè)用戶(hù)和客戶(hù)互動(dòng)的首先方式。
      以下部分圖片來(lái)自于互聯(lián)網(wǎng)
      在呼叫中心或者語(yǔ)音使用比較高的行業(yè)中,服務(wù)行業(yè)是一個(gè)需求非常旺盛的行業(yè),客服中心是非常關(guān)鍵的部門(mén)。為了保證其服務(wù)和其他業(yè)務(wù)那個(gè)在一種可控的環(huán)境下進(jìn)行,雙方的錄音是最好的憑證。另外,語(yǔ)音呼叫結合電話(huà)錄音也是服務(wù)行業(yè)的一個(gè)必然的趨勢,以下是美國行業(yè)調查數據:
      資料來(lái)源:https://www.telemessage.com/voice-call-recording-latest-market-and-compliancetrends-infographic/
      當然,錄音也不僅僅局限于客服的一種需求,其他行業(yè)也存在巨大的市場(chǎng)。以下示例說(shuō)明了各種環(huán)境下對錄音的需求:
      但是,隨著(zhù)呼叫中心或客服中心技術(shù)的不斷發(fā)展,很多呼叫中心和客服中心的技術(shù)也發(fā)生了巨大的變化,從很早的本地部署方式逐漸升級為基于云的部署方式,客服或坐席人員也出現了分布式的部署方式。因此,隨著(zhù)呼叫中心或客服中心技術(shù)和管理方式的變化導致了錄音解決方案的變化。我們知道,傳統的PSTN的錄音或者IP錄音是通過(guò)高阻三通方式或鏡像錄音實(shí)現呼叫錄音,但是,這些部署很難滿(mǎn)足對現代云部署技術(shù)的支撐,它們也滿(mǎn)足不了非常細節的業(yè)務(wù)功能。因此,傳統的錄音設備或者本地錄音方式面臨著(zhù)很大的挑戰。
      隨著(zhù)呼叫中心或客服系統朝云平臺的遷移,基于云平臺的錄音解決方案也逐漸形成了自己的市場(chǎng)。同時(shí),錄音解決方案可以非常方便地和人工智能的接口實(shí)現無(wú)縫對接支持。因此,基于云的呼叫中心配合云錄音方案將更加普及。
      在基于云部署的呼叫中心的使用場(chǎng)景中,絕大部分的呼叫中心使用了基于SIP協(xié)議的解決方案。目前,基于SIP協(xié)議的技術(shù)架構中,基于SIP協(xié)議對媒體錄音的規范是SBC,軟交換,媒體服務(wù)器部署時(shí)需要支持的協(xié)議規范(SIPREC)。一些比較主流的SBC廠(chǎng)家,媒體服務(wù)器都已經(jīng)支持了SIPREC-基于SIP的媒體錄音協(xié)議。這看來(lái)也是一個(gè)市場(chǎng)發(fā)展的必然趨勢。為了更快了解這些相關(guān)的技術(shù)和規范,在本文章中,筆者在接下來(lái)的章節中會(huì )逐步介紹SIPREC相關(guān)的技術(shù)規范,它們包括:
      RFC5341-基于SIP的媒體錄音使用場(chǎng)景規范:
      Use Cases and Requirements for SIP-Based Media Recording (SIPREC)
      RFC7245-SIP媒體錄音技術(shù)架構:
      An Architecture for Media Recording Using the Session Initiation Protocol
      RFC 7865-SIP錄音時(shí)的metadata:
      Session Initiation Protocol (SIP) Recording Metadata
      RFC7866-SIP錄音的呼叫流程:
      Session Initiation Protocol (SIP) Recording Call Flows
      因為篇幅的關(guān)系,我們不可能在一篇文章中涵蓋所有的技術(shù)細節,除了簡(jiǎn)略介紹以上規范以外,筆者還要結合目前主流的SBC應用場(chǎng)景和其他的問(wèn)題進(jìn)行多方面的討論來(lái)完善目前關(guān)于基于SIP媒體錄音解決方案的討論。
      2、SIPREC背景知識
      根據前面章節的介紹,因為某些商業(yè)環(huán)境的要求,系統可能需要對呼叫會(huì )話(huà)進(jìn)行錄音。SIPREC是基于SIP協(xié)議對媒體錄音的場(chǎng)景規范(RFC6341)。其全名為:
      Use Cases and Requirements for SIP-Based Media Recording (SIPREC)
      在整個(gè)SIPREC的規范中,包括了SRC和SRS兩個(gè)核心部分。它們之間的通信會(huì )話(huà)包括了錄音內容本身和一些相關(guān)的metadata,通過(guò)錄音內容和metadata的關(guān)聯(lián),系統就可以實(shí)現對SIP呼叫的媒體錄音的完成流程處理。因為對SIP呼叫的錄音,涉及了很多的業(yè)務(wù)模式和其他相關(guān)的技術(shù),因此,其規范也相對比較寬泛,不可能?chē)栏裣薅ǖ椒浅<毠澋募夹g(shù)范疇。讀者一定要清楚,一些其他業(yè)務(wù)要求和技術(shù)要素不在此官方的說(shuō)明范圍之內。這些要素包括:
    • 關(guān)于法律強制錄音的規定流程不在此規范討論范圍之內
    • 關(guān)于媒體注入,編碼轉換,安全問(wèn)題不在本規范討論范圍之內
    • 通過(guò)網(wǎng)絡(luò )鏡像方式錄音Passive 錄音方式不在本規范討論范圍之內
      此規范僅討論active 錄音方式,和如何通過(guò)SRC對SRS發(fā)送媒體流的處理場(chǎng)景。以下是一個(gè)關(guān)于SIPREC和SIP呼叫流程的圖例說(shuō)明:
      在以上的圖例中,用戶(hù)端可以是SIP終端, 呼叫中心,或者IPPBX,通過(guò)一個(gè)B2BUA實(shí)現對外網(wǎng)呼叫。這里的SRC是SBC,SRC客戶(hù)端再發(fā)送通信會(huì )話(huà)包括SIPREC metadata和RTP到第三方的SIPREC服務(wù)器端。在呼叫環(huán)境中,涉及了各種環(huán)境場(chǎng)景和控制流程,具體細節和各種錄音場(chǎng)景我們在第四章節中做具體說(shuō)明。
      劇透時(shí)間:可能是東半球網(wǎng)關(guān)銷(xiāo)售量最大的廠(chǎng)家即將震撼發(fā)布一系列融合通信產(chǎn)品,完成融合通信產(chǎn)品生態(tài)鏈部局。
      www.dinstar.cn
      3、技術(shù)架構討論-RFC7245
      在上面的章節中,我們介紹了關(guān)于SIPREC的一些背景知識和規范的局限性。SIPREC的工作方式是基于SIP媒體會(huì )話(huà)錄音的技術(shù)架構來(lái)實(shí)現的。因此,我們有必要針對媒體錄音技術(shù)架構進(jìn)行討論包括。關(guān)于SIP媒體會(huì )話(huà)錄音的技術(shù)架構,RFC7245對此有明確的規范說(shuō)明。在RFC7245中,官方協(xié)議中首先定義了多個(gè)關(guān)鍵詞,然后說(shuō)明了技術(shù)架構中具體的結構,創(chuàng )建錄音會(huì )話(huà)和記錄metadata數據。
      在RFC7245中所規定的幾個(gè)關(guān)鍵詞包括:
    1. 支持錄音意識用戶(hù)代理- Recording-aware User Agent (UA):此UA可以意識到其拓展已經(jīng)關(guān)聯(lián)到了通信會(huì )話(huà)(CS)。其拓展參數可以通知其UA錄音會(huì )話(huà)已啟動(dòng)或表示其狀態(tài),可以啟動(dòng),暫停和完全停止等消息。
    2. 無(wú)錄音意識用戶(hù)代理-Recording-unaware User Agent (UA):此UA意識不到其拓展已經(jīng)關(guān)聯(lián)到了通信會(huì )話(huà)(CS)。無(wú)錄音意識代理將通過(guò)其他手段通知其UA錄音會(huì )話(huà)已啟動(dòng)或表示其狀態(tài),可以啟動(dòng),暫停和完全停止等消息。
    3. Recording Metadata:描述SRS服務(wù)器端需要的相關(guān)錄音身份確認數據,包括通信會(huì )話(huà)和dialog狀態(tài)信息等。一般情況下,這些metadata會(huì )和復制媒體錄音一起發(fā)送到SRS服務(wù)器端。
    4. Replicated Media:由SRC客戶(hù)端創(chuàng )建的媒體流復制數據流,發(fā)送到SRS服務(wù)器端。它可能包括語(yǔ)音和視頻數據。
      其他幾個(gè)概念在下面的章節中會(huì )加以說(shuō)明,包括:Session Recording Server,Session Recording Client,Communication Session (CS)和Recording Session (RS)。
      對于介于SRS和SRC之間的錄音會(huì )話(huà)來(lái)說(shuō),它仍然借助了SIP dialogs和SDP的正常處理流程來(lái)進(jìn)行處理。但是,它又對SIP拓展了其他的頭域值(例如,headers,tags等)來(lái)滿(mǎn)足媒體錄音的需求。在此規范中規定,復制的媒體數據需要通過(guò)實(shí)時(shí)方式發(fā)送到SRS服務(wù)器端,不能使用SRC緩存方式發(fā)送。
      從媒體錄音的技術(shù)架構來(lái)說(shuō),SRC是一個(gè)邏輯構件,它可以介于多個(gè)應用部署的環(huán)境中。它本身必須是一個(gè)B2BUA的結構,這樣SRC才能對RTP媒體,對SIP信令進(jìn)行控制,最重要的是可以對會(huì )話(huà)進(jìn)行管理。關(guān)于B2BUA的概念,讀者可以查閱筆者的歷史文檔來(lái)進(jìn)一步學(xué)習,這里不再做過(guò)多解釋。另外,特別提醒讀者,SIP proxy不能作為SRC來(lái)工作,因為proxy不能touch到媒體語(yǔ)音流。這就是為什么opensips如果需要支持SIPREC時(shí),opensips必須加載B2BUA模塊,作為一個(gè)B2BUA來(lái)使用。
      當然,SIP endpoints也可以作為一個(gè)SRC,這種情況下,終端會(huì )對SRS發(fā)送復制的媒體。如果終端需要對SRS服務(wù)器端發(fā)送錄音時(shí),它可以發(fā)送一個(gè)INVITE請求,創(chuàng )建會(huì )話(huà)后發(fā)送,SRC對SRS發(fā)送媒體錄音。同樣,如果SRS需要啟動(dòng)錄音時(shí),它可以對SRC終端發(fā)送INVITE會(huì )話(huà),然后開(kāi)始錄音。
      錄音會(huì )話(huà)可以由SRS或者SRC創(chuàng )建。SRC創(chuàng )建的錄音會(huì )話(huà)的目的是對SRS發(fā)送媒體錄音流數據。如果有SRC創(chuàng )建錄音會(huì )話(huà)時(shí),它主要執行以下幾個(gè)步驟:
    1. SRC查詢(xún)定位SRS的URL地址,按照解析方式來(lái)解析SRS地址。
    2. 發(fā)送INVITE請求,創(chuàng )建一個(gè)dialog,然后發(fā)送到SRS。
    3. 在INVITE請求中包括一個(gè)錄音指示,表示會(huì )話(huà)已經(jīng)創(chuàng )建,希望發(fā)送媒體錄音。
    4. 如果馬上要發(fā)送復制媒體時(shí),在SDP中包含一個(gè)“a=sendonly”,表示馬上發(fā)送媒體錄音。如果還沒(méi)有準備好發(fā)送媒體的話(huà),包含一個(gè)“a=inactive”。
    5. 復制的媒體流被錄音然后發(fā)送到SRS服務(wù)器端。
      同樣,SRS也可以對SRC發(fā)送請求來(lái)啟動(dòng)一個(gè)錄音會(huì )話(huà),它需要執行以下幾個(gè)流程:
    1. SRS查詢(xún)SRC URL地址,通過(guò)地址解析后獲取SRC地址。
    2. SRS對SRC發(fā)送INVITE請求。
    3. 在SRS發(fā)送的INVITE中包括一個(gè)媒體錄音指示,表示要創(chuàng )建一個(gè)錄音會(huì )話(huà)來(lái)進(jìn)行媒體錄音。
    4. 確認會(huì )話(huà)數據內容。在實(shí)際環(huán)境中,確認消息取決于SRC的策略設置。
    5. 如果馬上要發(fā)送復制媒體時(shí),在SDP中包含一個(gè)“a=sendonly”,表示馬上發(fā)送媒體錄音。如果還沒(méi)有準備好發(fā)送媒體的話(huà),包含一個(gè)“a=inactive”。
      如果SRS服務(wù)器端不知道哪個(gè)媒體會(huì )話(huà)需要錄音的話(huà),SRS服務(wù)器端可以執行一個(gè)協(xié)商機制,它可以先對SRC發(fā)送一個(gè)無(wú)實(shí)際意義的INVITE,然后SRC客戶(hù)端對其發(fā)送一個(gè)初始的offer。
      在媒體錄音進(jìn)行過(guò)程中,SRS或者SRC任意一方可以暫停或者重新啟動(dòng)錄音。通過(guò)SDP中包含一個(gè)inactive來(lái)暫停錄音,或者通過(guò)SDP中包含“recvonly”或“sendonly”重新啟動(dòng)錄音。
      通常情況下,在一個(gè)簡(jiǎn)單的會(huì )話(huà)中,在SRC客戶(hù)端,RTP媒體流可能包含兩個(gè)媒體數據流。這些媒體流必須在發(fā)送到SRS服務(wù)器端之前進(jìn)行混音。如果沒(méi)有混音的媒體發(fā)送到SRS時(shí),需要同時(shí)分開(kāi)發(fā)送兩個(gè)媒體流的metadata。
      在實(shí)際部署環(huán)境中,雙方媒體可能需要進(jìn)行媒體轉換處理,B2BUA可以執行此功能。如果SRC端不能執行媒體轉換處理的話(huà),它需要對SRS發(fā)送不同的媒體格式,SRS服務(wù)器端需要支持多種媒體格式。
      4、SIPREC使用場(chǎng)景討論
    • 在SIPREC的規范中,它說(shuō)明了幾個(gè)基于SIP的錄音使用場(chǎng)景。這些場(chǎng)景都可以支持SIPREC規范RFC6341。在此規范中,一些必要的定義需要再次說(shuō)明一下:
    • SRS-全稱(chēng)是Session Recording Server,它是一個(gè)具體的媒體服務(wù)器或媒體采集服務(wù)器,是一個(gè)用戶(hù)代理,同時(shí)匯總各種媒體流的metadata。SRS典型的部署方式是一個(gè)多口可拓展的服務(wù)器類(lèi)型。
    • SRC-全稱(chēng)是Session Recording Client,它是一個(gè)SIP用戶(hù)代理,負責對服務(wù)器端發(fā)送媒體流數據,它本身是一個(gè)邏輯功能單元,可以支持多個(gè)物理設備,在實(shí)際應用環(huán)境中,SRC可以是SIP終端話(huà)機,媒體網(wǎng)關(guān)或者SBC。SRC同時(shí)對SRS服務(wù)器發(fā)送metadata。
    • Communication Session (CS),通信會(huì )話(huà)創(chuàng )建于一個(gè)SIP或者多個(gè)用戶(hù)代理之間的會(huì )話(huà),是一個(gè)正在被錄音的會(huì )話(huà)對象。
    • Recording Session (RS):為通信會(huì )話(huà)(CS)錄音目的創(chuàng )建的介于SRS和SRC之間的SIP會(huì )話(huà)。
      關(guān)于SRS,SRC和CS直接的關(guān)系,讀者可查閱此示例:
      在RFC6341中說(shuō)明了12個(gè)應用場(chǎng)景,每一種場(chǎng)景都包含了具體的描述。
    1. 全時(shí)錄音:對RS對一個(gè)CS(參考以下示例),系統對所有呼叫進(jìn)行錄音,典型的應用場(chǎng)景包括呼叫中心,企業(yè)客服和金融呼叫流程等。
    2. 選擇性錄音:當CS錄音創(chuàng )建后,啟動(dòng)RS錄音。如果CS沒(méi)有啟動(dòng),系統不會(huì )錄音。
    3. 停止啟動(dòng)錄音:當呼叫在CS期間時(shí),可以啟動(dòng)停止RS錄音。系統可以通過(guò)用戶(hù)界面按鈕或者其他熱鍵啟動(dòng)錄音。這里注意,在CS期間,可能會(huì )生成一個(gè)或者多個(gè)RS錄音。
    4. 持續錄音:一個(gè)RS可以捕捉一個(gè)或多個(gè)CS錄音。此錄音方式通常應用于某些場(chǎng)景中,例如前臺總機,轉每個(gè)特定的分機號碼或者呼叫。整個(gè)RS需要對多個(gè)環(huán)節中的終端錄音,包括了轉接時(shí)的靜音等。最后,這些錄音的metadata可以關(guān)聯(lián)在一起,錄音文件可以合并。這里可能涉及了編碼協(xié)商的流程。
      
      5.實(shí)時(shí)錄音控制:在RS錄音期間,如果有特別業(yè)務(wù)要求,某些個(gè)人隱私或者安全信息不能錄音時(shí),實(shí)時(shí)錄音控制方式可以停止對某一段時(shí)間內的錄音暫停/關(guān)閉,需要時(shí)重新開(kāi)啟。信用卡信息輸入就是一個(gè)比較常見(jiàn)的例子,如果用戶(hù)需要對系統服務(wù)人員報信用卡或者其他身份信息時(shí)就要暫停錄音。
      6.IVR入口錄音:對系統IVR進(jìn)行錄音,包括其metadata等。
      7.企業(yè)移動(dòng)端錄音:系統對企業(yè)辦公人員進(jìn)行錄音。這些員工可能經(jīng)常不在辦公室環(huán)境中上班,他們經(jīng)常使用移動(dòng)端和企業(yè)呼叫中心或者通信系統進(jìn)行溝通,這些員工的呼叫需要被錄音。比較常見(jiàn)的場(chǎng)景包括銷(xiāo)售人員,保險銷(xiāo)售等。
      8.分布式錄音或集中式錄音:一些企業(yè),銀行,連鎖機構等辦公系統的電話(huà)呼叫需要通過(guò)部署在不同地區或者集中管理的電話(huà)系統進(jìn)行呼叫。系統需要對呼叫進(jìn)行錄音,并且對其每個(gè)RS的metadata進(jìn)行存儲。這樣方便管理每一個(gè)呼叫和其相關(guān)人分機。
      9.復雜呼叫流程:復雜呼叫流程是一個(gè)比較抽象的說(shuō)法,沒(méi)有特別具體的定義,此場(chǎng)景比較靈活,寬泛。簡(jiǎn)單來(lái)說(shuō),一個(gè)呼叫進(jìn)入到系統用戶(hù),客戶(hù)電話(huà)可能首先被前臺人員接聽(tīng),然后轉到具體的坐席人員。如果坐席人員不能回答客戶(hù)問(wèn)題的話(huà),坐席人員可能需要再呼叫坐席主管,主管來(lái)接聽(tīng)客戶(hù)的電話(huà)。坐席人員在此呼叫流程中需要首先執行呼叫停靠,然后再呼叫他/她的主管,主管接聽(tīng)客戶(hù)電話(huà)以后,坐席掛機。整個(gè)流程稱(chēng)之為復雜呼叫流程,所有的呼叫都需要錄音,并且SRC需要對SRS發(fā)送所有的metadata數據。
      10.高可靠性和持續錄音:根據用戶(hù)的需求,此應用場(chǎng)景需要SRS服務(wù)器端一直保持工作狀態(tài),失效還原功能。所有創(chuàng )建的呼叫都能錄音。此場(chǎng)景要求SRS服務(wù)器端必須持續工作,無(wú)呼叫錄音服務(wù)丟失。
      11.對通道和多會(huì )話(huà)錄音:一些應用場(chǎng)景要求媒體錄音是一個(gè)或者多個(gè)文件,可以實(shí)現同步存儲或者回放等功能。語(yǔ)音識別引擎可以對其明顯特定的媒體執行ASR/TTS處理。一些多渠道融合的呼叫中心或者IPPBX環(huán)境中可能需要對視頻,IM,其他數據文件進(jìn)行存儲。為了節省存儲空間,一些應用場(chǎng)景中可能需要僅多某些終端在某個(gè)特定時(shí)間段進(jìn)行錄音。
      12.實(shí)時(shí)媒體處理:此場(chǎng)景在當前的呼叫中心或客服系統中實(shí)時(shí)質(zhì)檢環(huán)境中使用比較廣泛。SRS服務(wù)器端必須有能力支持語(yǔ)音識別引擎工具,這些偵查工具可以對某一段媒體進(jìn)行ASR和以及相關(guān)語(yǔ)義識別,情緒分析等工具處理,如果發(fā)現其錄音中帶有比較敏感的詞,或者客服人員態(tài)度語(yǔ)氣有問(wèn)題,應用系統的主管人員可以及時(shí)處理。通過(guò)SIPREC的metadata可以非常方便快捷地查詢(xún)到客服人員的電話(huà)座席。以下示例是寧衛開(kāi)發(fā)的基于A(yíng)SR的實(shí)時(shí)質(zhì)系統。系統用戶(hù)可以根據自己的業(yè)務(wù)需求添加一些敏感詞。如果客服人員和客戶(hù)之間的溝通有危險詞匯或者不禮貌用語(yǔ),系統直接提示其狀態(tài)(紅色標識)。此對話(huà)過(guò)程可通過(guò)短信,郵箱或者其他第三方接口實(shí)時(shí)推送給坐席主管現在的狀態(tài)告警。

      當然,實(shí)現以上基于SIPREC錄音解決方案的話(huà),此規范有31個(gè)要求。筆者這里不立場(chǎng)31個(gè)具體的要求,讀者可以查閱RFC6341。
      另外,除了31個(gè)要求以外,此規范討論了關(guān)于錄音存儲和metadata的安全問(wèn)題,讀者也可以查閱RFC6341來(lái)進(jìn)一步學(xué)習。
      5、SIP錄音時(shí)的metadata
      SIP錄音時(shí)的metadata涉及到了錄音會(huì )話(huà)的相關(guān)參數的綁定。這些數據通過(guò)SRC發(fā)送到SRS服務(wù)器端。RFC7865主要針對通信會(huì )話(huà)的錄音文件進(jìn)行了規范,其核心包括SRS服務(wù)器端的metadata數據模式和數據錄音格式規范描述。在RFC7865中涵蓋了幾個(gè)主要的定義,它們分別是:
    • Metedata model:以UML為基礎的抽象metadata表達方式
    • Metedada class:模式中的每一塊為一個(gè)class
    • Attributes:class的屬性
    • Linkages:模式中每個(gè)class之間的相關(guān)性,每個(gè)linkage表示class之間的一個(gè)邏輯相關(guān)性
      以下示例表示了各種class自己的相互關(guān)系和其相關(guān)性,讀者可以查閱RFC7865進(jìn)一步了解這個(gè)數據模式。另外,讀者也可以學(xué)習UML或者軟件工程相關(guān)的文章了解UML背景知識。
      在metadata的數據格式方面,涉及了從SRC到SRS的發(fā)送格式。通過(guò)XML的格式來(lái)表示metadata的內容。
      錄音文件的metadata有分為不同的class。每個(gè)class有著(zhù)自己不同的屬性參數設置和相關(guān)性設置。這些class包括:
    1. Recording session:錄音會(huì )話(huà)類(lèi)別,在XML中使用“recording”,它依賴(lài)于SIP和SDP所關(guān)聯(lián)的屬性。
    2. Commnucation session group: 關(guān)聯(lián)一組通信會(huì )話(huà),例如坐席通過(guò)幾次電話(huà)轉接停靠以后的一系列相關(guān)呼叫。它在XML中使用“group”表示。
    3. Commnucation session:通信會(huì )話(huà)表示其通信屬性和metadata,其屬性包括:session_id,sipSession_ID, group-ref,start-time,stop-time。
    4. CS-RS Association :表示通信會(huì )話(huà)和錄音會(huì )話(huà)的關(guān)聯(lián)性,屬性包括關(guān)聯(lián)時(shí)間,斷開(kāi)時(shí)間和session_id。
    5. Participant:錄音參與者進(jìn)入到錄音會(huì )話(huà)的雙方,包括終端描述,Participant_id等。
    6. Participant-CS Association:參與者和通信會(huì )話(huà)的關(guān)聯(lián)性綁定關(guān)系。關(guān)聯(lián)性描述參與者和通信會(huì )話(huà)關(guān)聯(lián)時(shí)間,session_id,斷開(kāi)時(shí)間等屬性。
    7. Media Stream:描述SRC發(fā)送到SRS服務(wù)器端的媒體屬性,包括label,stream_id和session_id等屬性設置。
    8. Participant-Stream Association:描述參與者和媒體之間的綁定關(guān)系和時(shí)間段,參與者可能是發(fā)送方,接收方或者兩者角色都支持。
    9. Syntax of XML Elements for Date and Time:定義XML文件中日期和時(shí)間段規范,包括關(guān)聯(lián)時(shí)間,斷開(kāi)時(shí)間,啟動(dòng)錄音時(shí)間,停止錄音時(shí)間等相關(guān)的時(shí)間規范。此時(shí)間標準需要遵從RFC3339的格式規范。時(shí)間戳必須使用一個(gè)大寫(xiě)的T或者Z。
    10. Format of Unique ID:描述了生成UUID的步驟和解析規范。UUID解析必須遵從RFC4648。
    11. Metadata Version Indicator:version指示幫助SRC和SRS確認使用的XML文件版本是否一致。目前規定的是雙方都使用版本1。如果版本不一致的話(huà),可能導致傳輸失敗,目前的規范中沒(méi)有支持任何的協(xié)商機制。
      因為本身metadata的數據結構比較復雜,另外,如果SRS處理大量數據的時(shí)候需要消耗很多的計算資源和帶寬。因此,SRS可以明確通知SRC發(fā)送一個(gè)關(guān)于錄音的metadata的概要或者部分相關(guān)內容,而不需要發(fā)送一個(gè)完整的XML文件。具體的語(yǔ)法格式如下:
    1. SRS internal error
    2.  
      完整的metadata格式包含了大量的XML數據,文件相對比較大,這里不再介紹,讀者可以查閱RFC7865-8的完整SIP 錄音metadata 示例。
      6、SIP會(huì )話(huà)錄音協(xié)議
      前面的討論中,筆者已經(jīng)介紹了錄音技術(shù)架構,使用場(chǎng)景和metadata。在這一章節,我們重點(diǎn)介紹一下會(huì )話(huà)錄音協(xié)議-Session Recording Protocol。此協(xié)議主要規定了SR之間的實(shí)時(shí)媒體發(fā)送和metadata發(fā)生的邏輯流程,包括SIP使用, SDP使用和RTP的處理規范。再次說(shuō)明,此協(xié)議僅支持active 錄音模式,不支持passive 錄音模式(鏡像錄音)。在此協(xié)議中,主要規范了幾個(gè)方面的處理流程:
      基本操作流程規定,SIP處理流程定義,SDP處理流程定義。RTP處理流程定義,metadata處理,持續錄音處理和安全處理機制處理。
      基本操作流程規定中介紹了關(guān)于傳輸媒體流,傳輸metadata,接收錄音指示和提供錄音優(yōu)先設置。在傳輸媒體流的模式討論中,規范了兩種傳輸方式。一種傳輸方式是SRC以B2BUA的方式傳輸,一種是以SRC以endpoint的方式來(lái)傳輸。SRC以endpoint的模式傳輸媒體:
      以下是SRC以B2BUA的模式傳輸,電話(huà)會(huì )議就是此工作方式的表現形式。
      除了傳輸媒體流錄音以外,metadata也需要實(shí)時(shí)隨著(zhù)媒體的發(fā)送傳輸到SRS服務(wù)器端。SRC負責傳輸metadata,SRC也可以通過(guò)起始的CS的INVITE請求提供初始媒體流錄音的metadata數據消息,后續的metadata可以通過(guò)媒體事件的UPDATE(查閱rfc3311)來(lái)傳遞,也可以通過(guò)SRC發(fā)送到re-INVITE發(fā)送。傳輸metadata通常是逐步遞增的,消息內容可能會(huì )不斷增加,文件也可能非常大。因此,SRC發(fā)可以根據自己的策略重新發(fā)送metadata。meatadata通過(guò)INVITE或者UPDATE的消息體來(lái)傳輸。一些媒體流的屬性需要通過(guò)RS的SDP傳輸。在SRC和SRS傳輸過(guò)程中,可能出現其他的故障,丟失了metedata。SRS可以通過(guò)一個(gè)失敗消息對SRC要求重新傳輸metadata,SRS和SRC可以保持數據的同步。以下是一個(gè)通過(guò)SIP UPDATE重新傳輸的流程實(shí)例:
      在CS傳輸過(guò)程中,SRC負責對所有的參與者提供錄音指示消息內容。一些支持錄音狀態(tài)意識到UA會(huì )收到一個(gè)SDP帶“a=record”消息,表示SRC開(kāi)始發(fā)送錄音,同樣UA會(huì )在SDP中設定一個(gè)“a=recordpref”表示錄音的優(yōu)先偏好設置。如果UA暫時(shí)因為各種原因不能錄音,則可忽略這個(gè)優(yōu)先偏好設置。以下示例介紹了一個(gè)UA A作為SRC呼叫 終端B的流程,終端A呼叫并且開(kāi)始錄音,UA B則看到對方錄音,UA B回復了一個(gè)off狀態(tài),不想對呼叫進(jìn)行錄音。最后,UA A重新發(fā)送消息,停止呼叫錄音。
      錄音會(huì )話(huà)中同樣涉及了SIP處理,它是一個(gè)SIP 會(huì )話(huà)的拓展,很多的消息會(huì )包含在SRS和SRC中。當SRC或者SRS收到一個(gè)SIP會(huì )話(huà)時(shí),它不是錄音會(huì )話(huà)的話(huà),處理流程完全取決于SRC或者SRS自己。SRC通過(guò)SIP INVITE請求對SRS發(fā)起一個(gè)錄音會(huì )話(huà),無(wú)論是SRS還是SRC都是通過(guò)SIP的To或From頭來(lái)定義。SRC必須在Contact URL的功能標簽添加一個(gè)“+sip.src”來(lái)表示其拓展。在通過(guò)路由代理時(shí),呼叫方可以添加一個(gè)標簽“siprec”表示錄音會(huì )話(huà)需要路由到SRC或者SRS服務(wù)器端。SRC收到一個(gè)新的INVITE呼叫時(shí),它必須通過(guò)INVITE中的兩個(gè)功能標簽才能確認是一個(gè)錄音會(huì )話(huà)呼叫,一個(gè)是“+sip.srs”和“siprec”。同樣的原則,當SRS服務(wù)器端收到一個(gè)新的INVITE以后,它必須確認是否包含兩個(gè)標簽“+sip.src”和“siprec”才能確認是一個(gè)SRC發(fā)送到錄音請求。有意識錄音UA(recording-aware UA)可以通過(guò)標簽字段的形式支持是否錄音,重新啟動(dòng)錄音或者暫停錄音。一些網(wǎng)關(guān)或者終端通過(guò)界面來(lái)實(shí)現對DTMF控制也是一種錄音方式。
      除了對會(huì )話(huà)的控制以外,媒體錄音也需要metadata傳輸等機制,因此需要涉及到SDP的控制處理策略。在SDP處理模式上,SRC/SRS都遵守SDP offer/answer模式,具體規范查閱(RFC3264),筆者也曾經(jīng)做過(guò)介紹,讀者可對照學(xué)習。在SRC和SRS媒體發(fā)送過(guò)程中,SRC客戶(hù)端本身不希望從SRS服務(wù)器端收到媒體流數據,它僅是一個(gè)發(fā)送端,因此對SRC在SDP的設置中a字段設置為“a=sendonly”。SRC對每個(gè)發(fā)送到SRS服務(wù)器端的媒體錄音參與者必須都提供一個(gè)標識“a=label”,以此來(lái)確認每個(gè)媒體流的metadata。具體標識的規范讀者查閱RFC4574。以下示例是一個(gè)標識的示例,包括了具體的內容介紹,這里的 是可選的。
      媒體錄音也需要處理,因為各種原因,SRC可能增加或者刪除一些錄音會(huì )話(huà)。刪除增加會(huì )話(huà)需要根據RFC3264的規范來(lái)處理。RS暫停會(huì )話(huà)需要在SDP offer中增加一個(gè)a字段“a=inactive”。
      在通信會(huì )話(huà)中,目前的機制對通信會(huì )話(huà)錄音是播放一個(gè)語(yǔ)音提示音或者播放一個(gè)廣播,提醒需要UA需要錄音。在SDP中增加了一個(gè)“record”屬性參數。通過(guò)SDP的a字段“a=record”來(lái)處理各種環(huán)境的變化設置,其具體的語(yǔ)法如下:
      當SRC收到一個(gè)錄音優(yōu)先級/偏好時(shí),SRC通過(guò)設定a字段的屬性來(lái)控制是否錄音“a=record”,off或者on。
      前面我們討論的是SRC的SDP控制,在SRS端的處理流程其實(shí)也具有相同的處理流程和邏輯,可能有一些正好是一個(gè)相反的設置機制。SRS通常情況下只是從SRC端接收RTP流,因此其SDP的a字段設置為“a=recvonly”。示例如下:
      在SRS的SDP處理中,對有錄音意識UA,錄音指示和優(yōu)先級/偏好設置和SRC基本類(lèi)似,讀者可參考SRC配置說(shuō)明,這里不再做過(guò)多介紹。
      RTP處理也是錄音會(huì )話(huà)協(xié)議中非常重要的一個(gè)部分。其規范推薦了RTP/RTCP在SIPREC中的使用機制,保證SRS,SRC和有錄音意識終端那個(gè)通過(guò)這些推薦的處理機制來(lái)正常工作。在RTP的處理機制中,推薦了RTCP在SIPREC的兩種功能(數據分發(fā)反饋處理機制,包括持續的傳輸層身份確認(SSRC)),RTP屬性支持能力,SSRC,CSRC,SDES,Keepalive等機制處理方式。這些處理方式保證了語(yǔ)音傳輸,加密,穩定性處理,活動(dòng)偵測,帶寬優(yōu)化,異步傳輸等處理機制,用戶(hù)在實(shí)際本身時(shí)可靈活調整其參數來(lái)達到最佳的RTP處理解決方案。
      SRC可以扮演多種角色,它可能是一個(gè)UA也可能是一個(gè)B2BUA代理。因此,在RTP的處理上就會(huì )導致不同的處理方式,也可以靈活運用在不同的錄音場(chǎng)景中。SRC可以作為一個(gè)RTP流的轉移功能模塊,實(shí)現直接轉發(fā)RTP,或者可以作為一個(gè)RTP媒體的編碼轉換模塊,它可以針對不同的媒體格式進(jìn)行轉碼處理。SRC也可以作為一個(gè)媒體混音單元,讀者可查閱RFC3550對混音單元的規范做進(jìn)一步學(xué)習。
      SRC也可以作為一個(gè)RTP的endpoint,這些我們在前面做過(guò)介紹,這里不再討論。
      在錄音會(huì )話(huà)中,metadata屬性參數包含在了SDP描述中,其他數據包含在了application/rs-metadata。"recording-session"值包含了SRS需要處理的metadata。在SRC的示例如下:
      SRS發(fā)送到UPDATE消息如下:
      在錄音會(huì )話(huà)時(shí),規范做對持續錄音的場(chǎng)景做了一些規范推薦。在持續錄音時(shí),關(guān)于SRC和SRS的處理機制可以按照前面的流程處理。一些特殊情況,可能需要用戶(hù)針對特殊環(huán)境做進(jìn)一步處理,例如NAT環(huán)境中端口活動(dòng)檢測,如果是支持ICE的終端可能可以解決這個(gè)問(wèn)題,如果是不支持ICE的終端,用戶(hù)需要按照RFC6263來(lái)處理SRC和SRS的端口綁定。
      在錄音會(huì )話(huà)環(huán)境中,規范推薦了一些相關(guān)的安全問(wèn)題的討論,比如,SRC/SRS必須都支持加密,必須考慮RTP加密,metadata的安全處理,用戶(hù)簽權認證處理和存儲空間回放文件的處理。這些機制都和其他的安全機制是一致的。用戶(hù)可以查閱其他協(xié)議的安全處理機制來(lái)執行。
      7、SBC對SIPREC的支持
      在前面的章節中,筆者介紹了SIPREC的使用背景,錄音協(xié)議,錄音流程,技術(shù)架構和metadata等比較底層的技術(shù)概念。在實(shí)際應用場(chǎng)景中,SBC對SIPREC支持是非常典型的應用案例。目前,國外一些主流的SBC廠(chǎng)家產(chǎn)品都已經(jīng)支持了SIPREC(包括FreeSBC即將發(fā)布SIPREC高級功能),這樣就為SIP呼叫媒體錄音部署提供了可靠的技術(shù)環(huán)境。SBC支持SIPREC主要的應用場(chǎng)景包括:
      SBC企業(yè)本地部署支持SIPREC: 企業(yè)IPPBX或者呼叫中心和SBC/SRC連接,SRC通過(guò)SIPREC和SRS連接。錄音服務(wù)器可以通過(guò)終端以各種訪(fǎng)問(wèn)形式進(jìn)行訪(fǎng)問(wèn),運營(yíng)商和SBC進(jìn)行對接,然后呼叫到用戶(hù)終端。
      多租戶(hù)企業(yè)IPPBX錄音解決方案: 托管型的IPPBX或呼叫中心可以通過(guò)遠端終端呼叫SBC/SRC,然后通過(guò)SBC呼叫托管中心的PBX,IPPBX呼叫語(yǔ)音商線(xiàn)路出局。SRC同時(shí)對SRS發(fā)送RTP媒體流和metadata數據。
      高可靠性SIPREC錄音解決方案:SIPREC同樣規范了高可靠性的處理方式,SRS必須實(shí)現媒體流存儲無(wú)丟失機制。所以,SRS可以通過(guò)主從處理的方式同步媒體流和metadata數據。
      同樣,SRS的負載也是非常重要的技術(shù)要素。一些SBC做了均衡負載的處理,例如奧科SBC支持了類(lèi)似的功能:
      以上應用場(chǎng)景是比較典型的部署方式,SIPREC規范相對比較新,廠(chǎng)家仍然需要不斷更新支持一些SIPREC規范的高級功能。
      8、其他問(wèn)題討論
      前面我們討論了關(guān)于SIPREC錄音的官方協(xié)議和應用場(chǎng)景。SIPREC相當于鏡像錄音來(lái)說(shuō),其部署方式更符合目前SIP大型應用環(huán)境,云平臺的處理方式。但是,因為SIPREC是基于其他規范基礎發(fā)展而來(lái)的,因此其他規范的使用限制了一些SRC/SRS工作環(huán)境。另外,一些終端產(chǎn)品還沒(méi)有支持SIPREC,只有大部分SBC產(chǎn)品支持了SIPREC,SRS服務(wù)器端的功能仍然處于發(fā)展階段,一些商業(yè)產(chǎn)品支持了基本的SIPREC功能,一些高級功能仍然受到了限制。大家比較關(guān)心的問(wèn)題包括:
    • SRC客戶(hù)端發(fā)送到metadata文件大小影響傳輸結果和SRS的負載,SRC可能需要支持更多的傳輸策略來(lái)解決類(lèi)似的問(wèn)題。
    • SRC是否支持混音,如果SBC測來(lái)處理這些需求的話(huà),會(huì )導致SBC負載非常高,直接影響SBC的性能。
    • SRS服務(wù)器端的高可靠性設置問(wèn)題也是需要用戶(hù)面對的問(wèn)題。可能一些廠(chǎng)家的SBC很好解決了此問(wèn)題,但是需要真正實(shí)際驗證。
    • SRC是否很好支持了metadata的拓展支持決定了和SIP會(huì )話(huà)處理。如果很好支持很多拓展字段,可能會(huì )幫助SRS服務(wù)器端更加準確管理metedata和通信會(huì )話(huà)處理。另外,SIP會(huì )話(huà)的處理也需要終端和其他設備能夠很好配合,保證其具有良好的兼容性,從而保證metadata的準確性。
    •  
    •   
    • 隨著(zhù)融合通信的發(fā)展,用戶(hù)溝通增加了更多媒體支持,包括IM消息,共享文件和視頻格式。如何更好處理這些文件和其metadata也是一個(gè)非常大的挑戰。
      9、總結
      在本文章中,筆者首先介紹了SIPREC的規范和其相關(guān)的細節。基于SIP協(xié)議的媒體錄音應用已經(jīng)非常廣泛,從銀行到企業(yè)客服,保險業(yè)務(wù)推廣,法律機構和政府要求都需要電話(huà)錄音。這些錄音文件需要和其具體的通信會(huì )話(huà)相關(guān)人員進(jìn)行正確綁定才能符合真正的客戶(hù)要求。然后,筆者針對SIPREC和其他相關(guān)協(xié)議做了完整介紹,例如12個(gè)使用場(chǎng)景,錄音協(xié)議,metadata規范,呼叫流程規范。然后,筆者針對目前SRC使用最廣泛的SBC做了介紹,通過(guò)SBC的集成,企業(yè)客戶(hù)可以實(shí)現SIPREC錄音解決方案。最后,筆者討論了目前使用SIPREC可能面對的挑戰和一些相關(guān)問(wèn)題,為讀者提供了相對比較完整的專(zhuān)業(yè)建議。當然,隨著(zhù)技術(shù)的不斷發(fā)展,SIPREC的功能會(huì )更加完善,云平臺的使用越來(lái)越多,SBC部署的廣大,支持的終端也可能越來(lái)越多,SIPREC的需求也會(huì )逐漸增加。
      以上就是筆者針對基于SIP協(xié)議的媒體錄音規范和應用方面的概述。這里沒(méi)有過(guò)度討論各種錄音方式的特點(diǎn)。這些討論通常根據用戶(hù)的需求來(lái)決定,所以筆者認為沒(méi)有必要做過(guò)多討論。另外,關(guān)于SIPREC的場(chǎng)景討論也可能遺漏了其他方面的要素,望讀者諒解。總之,此文章已經(jīng)基本涵蓋了基于SIP協(xié)議做媒體錄音的大部分內容和規范,也完整敘述了其相關(guān)規范所有的技術(shù)要點(diǎn),對于讀者快速了解這些技術(shù)有著(zhù)非常大的幫助。
      參考資料:
      https://tools.ietf.org/html/rfc6341
      https://tools.ietf.org/html/rfc7245
      https://www.miarec.com/
      www.freepbx.org.cn
      https://www.cisco.com/c/en/us/td/docs/ios-xml/ios/voice/cube/configuration/cube-book/voi-sip-recording.pdf
       
       
      SIPlab@知識星球學(xué)習SIP語(yǔ)音相關(guān)技術(shù)
      asterisk@知識星球免費獲取關(guān)于A(yíng)sterisk的完整知識資料
      關(guān)注微信公眾號:asterisk-cn,獲得有價(jià)值的Asterisk行業(yè)分享
      Asterisk freepbx,FreeSBC技術(shù)文檔: www.freepbx.org.cn
      融合通信商業(yè)解決方案,協(xié)同解決方案首選產(chǎn)品:www.hiastar.com
      Asterisk/FreePBX中國合作伙伴,官方qq技術(shù)分享群(3000人):589995817
    【免責聲明】本文僅代表作者本人觀(guān)點(diǎn),與CTI論壇無(wú)關(guān)。CTI論壇對文中陳述、觀(guān)點(diǎn)判斷保持中立,不對所包含內容的準確性、可靠性或完整性提供任何明示或暗示的保證。請讀者僅作參考,并請自行承擔全部責任。

    專(zhuān)題

    CTI論壇會(huì )員企業(yè)

    亚洲精品网站在线观看不卡无广告,国产a不卡片精品免费观看,欧美亚洲一区二区三区在线,国产一区二区三区日韩 渝北区| 隆德县| 兴海县| 石渠县| 公安县| 金平| 奉新县| 商南县| 河北区| 锡林浩特市| 佛山市| 徐水县| 内乡县| 湖南省| 资阳市| 梁河县| 潼南县| 新野县| 卢湾区| 桃园县| 吴堡县| 青岛市| 读书| 黄石市| 清河县| 修文县| 武汉市| 行唐县| 东乡县| 文山县| 莱西市| 安顺市| 西藏| 凤台县| 饶平县| 曲水县| 万山特区| 化德县| 阿荣旗| 紫云| 印江| http://444 http://444 http://444 http://444 http://444 http://444