首頁>>廠商>>語音板卡開發(fā)商>>OpenVox

Asterisk命令MeetMe詳解

2010/02/02

>>開放源代碼的IP呼叫中心專欄

MeetMe

概要

  MeetMe 會議橋

描述

  語法:MeetMe([confno][,[options][,pin]])

  用途: 讓用戶進入一個指定的MeetMe會議。如果省略了會議編號,系統(tǒng)會提示用戶選擇一個。(注意:MeetMe會議需要一個Zaptel時鐘才能工作,你可以不裝任何板卡,但是你需要安裝Zaptel)

  參數(shù):options可以為空,也可以設置一個或者多個參數(shù),參數(shù)有如下一些:


參數(shù)詳解

  參數(shù) 's'

  's' 和 'p' 參數(shù)不能跟 'X' 參數(shù)共同使用。

  參數(shù) 'q'

  最好在 Asterisk v1.2以上版本用,早期版本的SIP通道會有延遲。

  參數(shù) 'r'

  在開始MeetMe()錄音之前,要指定Set ${MEETME_RECORDINGFILE}的值。

  否則,錄音文件將存放在/var/lib/asterisk/sounds目錄下,該目錄是存放系統(tǒng)提示音的,不適合存放錄音文件。

  例如:

  exten => s,1,SetVar(MEETME_RECORDINGFILE=/var/conf_recording-${EPOCH}-${USER})
  exten => s,2,MeetMe(,rD) ;開設一個新會議,對會議錄音,

  例子

  在meetme.conf 中設定一個會議室號為101,密碼為123456的會議。
  exten => 500,1,MeetMe(101||123456)

  授權(quán)的會議

  exten => 18,1,Answer
  exten => 18,2,Wait(1)
  exten => 18,3,Authenticate(5678)
  exten => 18,4,MeetMe(18|p)
  exten => 18,5,Playback(vm-goodbye)
  exten => 18,6,Hangup

  動態(tài)會議室,用戶需要按鍵輸入要創(chuàng)建的會議室號

  exten => 9999,1,Wait(1)
  exten => 9999,2,MeetMe(|Md)

  注意:如果你加入?yún)?shù)'e', 按*將選擇#會議室
  如果你需要為會議室設定一個密碼,,請將 'd' 參數(shù)改為 'D' 。

  動態(tài)會議室123設為安靜模式。如果用戶foo 撥打分機號10,他將成為一個標記用戶(’A’),foo離開會議后,會議室將被關(guān)閉,其他的撥打11的用戶也將被迫離開會議室。

  exten => 10,1,MeetMe(123|Aqd)
  exten => 11,1,MeetMe(123|xqd)

  OEJ發(fā)表的回顧 (May 23, 2004)

  你發(fā)現(xiàn)這個簡單得不能再簡單的(not-so-simple-anymore)簡單MeetMe會議橋了嗎?這可是Asterisk的一個殺手級應用哦。它帶來豐富的功能應用:


  更多豐富命令包括


  在CLI 下面也可以管理MeetMe:


  OEJ附加說明


性能方面的考慮

  在ISDN PRI環(huán)境下開超過10個人的MeetMe會議

  我曾經(jīng)發(fā)現(xiàn)在ISDN PRI環(huán)境下超過10個人的會議回發(fā)生嘯叫。人們認為電信運營商已經(jīng)對ISDN-PRI這樣的純數(shù)字化環(huán)境做過回聲消除了,所以不需要再設置回聲消除。然而事實并非如此。我在配置文件 /etc/asterisk/zapata.conf下面增加了下列的參數(shù)項,從而解決了這個問題:

  echocancel=yes
  echocancelwhenbridged=yes
  echotraining=yes

架構(gòu)和局限

  在Asterisk 1.2版本中,同時開很多個會議的時候可能會有些局限。目前大部分版本已經(jīng)升到1.4及以上,也就不存在這些問題了,不再鏊述。

  關(guān)于參數(shù)'b' (AGI_BACKGROUND)

  網(wǎng)友疑問

  我看了論壇上一些老的帖子,但是還是有個疑問,是關(guān)于AGI_BACKGROUND的。如果我的機器上安裝了Asterisk兼容板卡但是會議里沒有加入Zap通道,只有SIP通道,那么SIP通道上的MEETME_AGI_BACKGROUND腳本能正常工作嗎?

  回答

  不能正常工作。下面我們分析一下工作原理:

  合并輸入的語音包,輸出合并后的語音包,這些工作是在Zaptel驅(qū)動里面做的。對于真實的Zap通道,這個工作是在驅(qū)動層就請全部完成的。而對于非Zap通道,系統(tǒng)會創(chuàng)建一個Zap虛擬通道,然后在非Zap通道和Zap虛擬通道之間雙向拷貝語音數(shù)據(jù)。

  看一下這部分源代碼(在conf_run()中),我們會發(fā)現(xiàn),conf_run() 函數(shù)要么執(zhí)行AGI腳本,要么執(zhí)行虛擬通道拷貝循環(huán),不能同時執(zhí)行兩個。所以當你使用AGI腳本的時候,在非Zap 通道和Zap虛擬通道之間就沒有任何連接了。

  擁有一塊Asterisk卡或者dummy時鐘驅(qū)動 (比如: ztdummy 或者 zaprtc) 都能使用MeetMe功能,但是這并不意味著你可以在參加會議的SIP通道上使用AGI:他們沒有執(zhí)行任何AGI的能力。你可以試下看,但是最終的結(jié)果一定是什么聲音也得不到。

  還要注意的是,使用AGI將會使其他的一些內(nèi)置功能,比如說靜音、踢人和音樂等待等功能不能使用。

  AGI_BACKGROUND Pros/Cons

  使用AGI將會使其他的一些內(nèi)置功能,比如說不用通過命令行實現(xiàn)靜音、踢人和音樂等待等功能。

  參數(shù) 'p' (按#退出) 也不能用。錄音功能也不能用。

  如果你需要把會議中的某個成員踢出去,首先需要停止該成員的AGI_BACKGROUND 任務。

  一旦AGI_BACKGROUND腳本停止,該成員就自動退出會議室了。

  所有的DTMF按鍵事件都被送到AGI_BACKGROUND 進程/腳本。所以你可以讓你的.agi腳本不停地循環(huán),捕獲按鍵音,來決定怎樣處理一個特定的按鍵。

  AGI_BACKGROUND 也開放了很多開發(fā)的編程機會。你可以使用進程間通訊(sockets, signals等等)來遠程控制會議室(即: 基于外部時間或用戶輸入來給會議室放音)。

  從普通通話發(fā)起多方通話(邀請用戶參加會議)

  下面我講一下怎樣從一個普通通話(兩方通話)發(fā)起多方通話。主要是通過MeetMe和ChannelRedirect來實現(xiàn)。

  疑問: 在 Asterisk 1.4 版本中,我們是否需要用'ManagerRedirect'來替換 'ChannelRedirect'?

  下面是dialplan 例子:

  [default]
  exten => _XXX,1,Set(DYNAMIC_FEATURES=nway-start)
  exten => _XXX,n,Dial(SIP/${EXTEN})

  [dynamic-nway]
  exten => _XXX,1,Answer
  exten => _XXX,n,Set(CONFNO=${EXTEN})
  exten => _XXX,n,Set(MEETME_EXIT_CONTEXT=dynamic-nway-invite)
  exten => _XXX,n,Set(DYNAMIC_FEATURES=)
  exten => _XXX,n,MeetMe(${CONFNO},pdMX)
  exten => _XXX,n,Hangup

  [dynamic-nway-invite]
  exten => 0,1,Read(DEST,dial,,i)
  exten => 0,n,Set(DYNAMIC_FEATURES=nway-inv#nway-noinv)
  exten => 0,n,Dial(Local/${DEST}@dynamic-nway-dest,,g)
  exten => 0,n,Set(DYNAMIC_FEATURES=)
  exten => 0,n,Goto(dynamic-nway,${CONFNO},1)
  exten => i,1,Goto(dynamic-nway,${CONFNO},1)

  [dynamic-nway-dest]
  exten => _XXX,1,Dial(SIP/${EXTEN})

  [macro-nway-start]
  exten => s,1,Set(CONFNO=${FindFreeConf()})
  exten => s,n,ChannelRedirect(${BRIDGEPEER},dynamic-nway,${CONFNO},1)
  exten => s,n,Read(DEST,dial,,i)
  exten => s,n,Set(DYNAMIC_FEATURES=nway-inv#nway-noinv)
  exten => s,n,Dial(Local/${DEST}@dynamic-nway-dest,,g)
  exten => s,n,Set(DYNAMIC_FEATURES=)
  exten => s,n,Goto(dynamic-nway,${CONFNO},1)

  [macro-nway-ok]
  exten => s,1,ChannelRedirect(${BRIDGEPEER},dynamic-nway,${CONFNO},1)

  [macro-nway-notok]
  exten => s,1,SoftHangup(${BRIDGEPEER})

  注意:你需要用 FindFreeConf() 函數(shù) (或者其他方式) 來獲得空閑的會議室號碼。

  此外,還需要修改 features.conf,增加下面的內(nèi)容:

  [applicationmap]
  nway-start => *0,caller,Macro,nway-start
  nway-inv => **,caller,Macro,nway-ok
  nway-noinv => *#,caller,Macro,nway-notok

(譯注:事實上,F(xiàn)indFreeConf()這個函數(shù)好像需要Trunk版本支持,需要修改一下這個例子的部分內(nèi)容才能運行。另外,實際測試中我們也發(fā)現(xiàn),兩個按鍵*0之間的間隔時間不能太長,最好是連續(xù)按鍵。)

  工作原理:

  普通通話情況下:

  當你和別人通話的時候,按*0 (執(zhí)行宏 nway-start)。 被叫馬上被傳遞到一個空閑的會議室,而你將聽到撥號音,等待你輸入你要邀請的電話號碼。當被邀請方接通后,你在和這個第三方通話的過程中,可以按 ** (在features.conf可以定義)加入會議,按 *# 掛掉他然后返回會議。

  會議室情況下:

  在會議室里面,任何用戶可以按0邀請其他用戶加入會議,其他的步驟同上。

  合并會議

  這些可以使用使用 Asterisk local channels 和 Asterisk manager API來實現(xiàn)(一般使用AGI 或者Call Files) 。

  下面是一個合并會議123和會議124的OriginateAction例子:

  在dialplan (context = default):
  exten => 7799,1,Meetme(123|qd)
  exten => 7798,1,Meetme(124|qd)

  在Manager API:
  Action: Originate
  ActionID: 12345678
  Channel: local/7798
  Context: default
  Exten: 7799
  Priority: 1

  與某個成員悄悄話

  在Meetme中,還有一個類似ChanSpy的悄悄話功能(密談)。會議成員可以與其他成員通過'whisper'功能來密談。

  我還增加了一個 'z' 標志:

  'z' — 所有的DTMF按鍵事件將被送到manager

  用戶可以通過對MeetMe系統(tǒng)中的按鍵進行偵測,然后在決定在manager命令中如何處理。
除了標準MeetMe之外的其他選擇

  MeetMe2

  MeetMe2是在MeetMe基礎上增加了Web控制界面的一個變體。

  "目的是控制會議室里面的聲音和成員。這個功能可以為你提供一個通過網(wǎng)絡來控制會議和直觀查看會議的方法。app_meetme已經(jīng)做了大量改動,將一些會議信息寫入DB,并檢查會議屬性是否已經(jīng)改變。"

  Q: 我看到會議中的成員,但是我不能把他們踢出去,也不能將他們的模式從說變成可聽可說。沒有顯示任何錯誤。
  A: 在php中打開register_globals。
  你也可以在php文件的頂部加入"extract($_GET);"
(也有網(wǎng)友建議使用MeetMe-Web-Control來替代MeetMe2)

  app_conference

  另外一個變種 app_conference,針對大容量的會議。
  http://sourceforge.net/projects/appconference/
  有些人認為它比MeetMe更為強大,但是目前還沒有人提供詳細的比較測試數(shù)據(jù)。

  遠程會議主機

  通過第三方會議提供商: http://www.junctionnetworks.com,IAX和SIP通道可以加入遠程會議。在dialplan里面可以這樣寫:
  exten => 7000,1,Dial(IAX2/conference@iax.jnctn.net)
  exten => 7000,1,Dial(SIP/conference@sip.jnctn.net)

  通過撥打7000,您就可以參加他們的會議。
  他們提供很多種參加會議的方法,可以通過Web網(wǎng)頁來訂制,方便了會議管理和統(tǒng)計。

CTI論壇編輯



相關(guān)閱讀:
OpenVox攜手UcSky™為美國普達構(gòu)建融合通訊系統(tǒng) 2010-03-16
可管理的電話會議系統(tǒng)開發(fā)從入門到精通(四) 2010-03-02
可管理的電話會議系統(tǒng)開發(fā)從入門到精通(三) 2010-02-21
可管理的電話會議系統(tǒng)開發(fā)從入門到精通(二) 2010-02-09
可管理的電話會議系統(tǒng)開發(fā)從入門到精通(一) 2010-02-08

熱點專題:  開源軟件