Router - PRI MGCP Voice Gateway
This configuration snippet shows how to setup a voice gateway using MGCP with a PRI circuit from the telco. Remember that for
MGCP PRI circuits, the signaling channel is backhauled to callmanager.
# This configuration was taken from an ISR 2821 running 12.3(14)T2 Adv IP Svs It is always a good idea to check with TAC
# to see what they recommend as the latest stable version of code for this application.
# I always like debug and log informatio to show the actual date and time and it is also good security practice to make sure
# password-encryption is turned on
service timestamps debug datetime msec
service timestamps log datetime msec
service password-encryption
hostname Voice-GW-Rtr
# We need tp specify which wic or vwic cards will participate in the clocking domain as well as select a preference order
# for where we will pull the router's clock source from. In this case there is only one circuit so we set wic slot 0 to participate
# and then select it with a priority of 1 stating that this is our primary clock source.
network-clock-participate wic 0
network-clock-select 1 T1 0/0/0
no aaa new-model
ip subnet-zero
ip cef
no ip domain lookup
ip domain name ciscoconfigs.net
# The circuit provider will have to provide you with the correct ISDN switch-type that they are using and here we set
# it as primary-ni which is pretty common in my area.
isdn switch-type primary-ni
# The next statement is basically stating that we will not be using DSP resources for conferencing, transcoding or
# as an MTP.
voice-card 0
no dspfarm
# The following command allows the voice path to be established in both directions when the RTP channel is opened
voice rtp send-recv
# The following statements are needed to ensure that fax pass-through and modem pass-through are sent with the
# G.711 codec.
voice service voip
fax protocol pass-through g711ulaw
modem passthrough nse codec g711ulaw
# The following lines control how this router communicates with CallManager using MGCP . The simple arguement
# of MGCP enables the router to communicate via MGCP to CallManager. The fallback-mgcp statement allows the router
# to establish an mgcp session with a redundant CallManager in order to take over processing if the primary CallManager
# fails. Use the redundant-host command to define the backup CallManager. By default the fax protocol is set to cisco
# so we want to turn that off in order to allow fax pass-through to occur. We need to specify music-on-hold in order to
# allow multicast MOH on the MGCP gateway. The config server ip address statement defines the IP address of the
# CallManager TFTP server from which this MGCP gateway will tftp its MGCP configuration from. Finally we need to
# specify config, in order to actually enable the MGCP configuration downloads from CallManager.
ccm-manager fallback-mgcp
ccm-manager mgcp
ccm-manager redundant-host 172.16.1.10
no ccm-manager fax protocol cisco
ccm-manager music-on-hold
ccm-manager config server 172.16.1.11
ccm-manager config
# The router has a vwic-1mft card that will be used to terminat the PRI voice circuit from the provider.
# Default framing and linecoding has been defined per carrier specs.
# We then create a pri-group with all 24 channels and need to specify the that it is using the service of mgcp
# This command will then create the serial0/0/0:23 interface which we will see further down in the config.
controller T1 0/0/0
framing esf
linecode b8zs
pri-group timeslots 1-24 service mgcp
# This router has 2 Gigabit Ethernet interfaces. We used the first one for Data and the second one
# for voice. Note there is a dhcp server on the data segment therefore we need to provide the helper-address
# on the voice side so the dhcp broadcast can be forwarded to the dhcp server.
interface GigabitEthernet0/0
description Data Vlan
ip address 10.1.1.1 255.255.255.0
duplex full
speed 1000
interface GigabitEthernet0/1
description Voice Vlan
ip address 172.16.1.1 255.255.255.0
ip helper-address 10.1.1.10
# Here is the interface that was created when we defined the pri-group. This is where the voice calls go
# in and out. We specify the isdn switch-type per the carrier specifications. We need the
# isdn incoming-voice voice statement to ensure that the calls will be handled as voice as passed off to
# a DSP (Digital Signal Processor). In order to configure the PRI signalling channel to be backhauled to
# CallManager we need to add the bind-l3 ccm-manager statement. This is needed for MGCP
# PRI voice gateways.
interface Serial0/0/0:23
no ip address
isdn switch-type primary-ni
isdn incoming-voice voice
isdn bind-l3 ccm-manager
ip classless
ip route 0.0.0.0 0.0.0.0 10.1.1.254
ip http server
ip http authentication local
ip http secure-server
ip http timeout-policy idle 600 life 86400 requests 10000
control-plane
# Prior to 12.3(14)Tx, not sure which specific one, this was needed to make sure that calls were not rejected when the dial
# peer did not have valid voice application. In this case it lets us roll back to a pre-loaded application called DEFAULT which
# handles basic call processing on the port. Although I am not 100% sure of this I believe this is needed in order to be
# able to roll back to h.323 call processing if there is an MGCP outage, i.e. can't connect to callmanager and you need
# SRST to kick using h.323 dial peers.
call application alternate DEFAULT
# Set up a local username for administrative access
username admin privilege 15 secret ciscoconfigs
# This is voice port that was dynamically created when we created the PRI-GROUP on the controller interface.
voice-port 0/0/0:23
# Finally all of the MGCP statements.
# First we turn mgcp on then we define who the call agent is. i.e. in most cases callmanager. The version type is just
# reference to different RFC versions for compatibility. Port 2427 is the default port for version 0.1.
# dtmf-relay is turned on to ensure forwarding of the digits through the compressed codecs.
# Default modem passthrough command
# The packages define what capabilities the mgcp gateway will support. This is the default set we typically use and
# works in most cases. The mgcp fax t38 is disabled by default. This is no longer true in IOS 12.4T or later.
# The sdp mode is set to simple.
# The rtp payload type is used to ensure backward compatibility if talking with an older gateway.
# The bind commands force the media and control packets to be sourced with the ip address on the
# associated gateway. You want to make this the IP address of the interface on the voice network. This way
# you know what it is.
mgcp
mgcp call-agent 172.16.1.11 2427 service-type mgcp version 0.1
mgcp dtmf-relay voip codec all mode out-of-band
mgcp rtp unreachable timeout 1000 action notify
mgcp modem passthrough voip mode nse
mgcp package-capability rtp-package
no mgcp package-capability res-package
mgcp package-capability sst-package
no mgcp package-capability fxr-package
mgcp package-capability pre-package
no mgcp timer receive-rtcp
mgcp sdp simple
mgcp fax t38 inhibit
mgcp rtp payload-type g726r16 static
mgcp bind control source-interface GigabitEthernet0/1
mgcp bind media source-interface GigabitEthernet0/1
mgcp profile default
# In this scenario, only one dial peer is needed. The key statement here is application mgcpapp, which
# tells the dial peer that it is controlled by MGCP. The incomin called-number . command will ensure that
# all incoming calls will match this dial peer. We disabled the fax rate since we are using fax pass-through.
# Since we had DID service we need to specifiy the direct-inward-dial command so the router will use the
# called number to match the destination pattern for the call. Finally we assign the PRI data channel as
# the port for this dial-peer.
dial-peer voice 1 pots
application mgcpapp
incoming called-number .
fax rate disable
direct-inward-dial
port 0/0/0:23
# Configured the console and the virtual terminal ports to accept a loing by authenticating against
# the local user database.
line con 0
login local
line aux 0
line vty 0 4
privilege level 15
login local
transport input telnet ssh
# It is always good to have a time server configured so all of your network devices will have the correct
# time. This is important when trying to correlate events between devices and logs.
ntp server 10.1.1.100
end
Refer to http://ciscoconfigs.net/
# to see what they recommend as the latest stable version of code for this application.
# I always like debug and log informatio to show the actual date and time and it is also good security practice to make sure
# password-encryption is turned on
service timestamps debug datetime msec
service timestamps log datetime msec
service password-encryption
hostname Voice-GW-Rtr
# We need tp specify which wic or vwic cards will participate in the clocking domain as well as select a preference order
# for where we will pull the router's clock source from. In this case there is only one circuit so we set wic slot 0 to participate
# and then select it with a priority of 1 stating that this is our primary clock source.
network-clock-participate wic 0
network-clock-select 1 T1 0/0/0
no aaa new-model
ip subnet-zero
ip cef
no ip domain lookup
ip domain name ciscoconfigs.net
# The circuit provider will have to provide you with the correct ISDN switch-type that they are using and here we set
# it as primary-ni which is pretty common in my area.
isdn switch-type primary-ni
# The next statement is basically stating that we will not be using DSP resources for conferencing, transcoding or
# as an MTP.
voice-card 0
no dspfarm
# The following command allows the voice path to be established in both directions when the RTP channel is opened
voice rtp send-recv
# The following statements are needed to ensure that fax pass-through and modem pass-through are sent with the
# G.711 codec.
voice service voip
fax protocol pass-through g711ulaw
modem passthrough nse codec g711ulaw
# The following lines control how this router communicates with CallManager using MGCP . The simple arguement
# of MGCP enables the router to communicate via MGCP to CallManager. The fallback-mgcp statement allows the router
# to establish an mgcp session with a redundant CallManager in order to take over processing if the primary CallManager
# fails. Use the redundant-host command to define the backup CallManager. By default the fax protocol is set to cisco
# so we want to turn that off in order to allow fax pass-through to occur. We need to specify music-on-hold in order to
# allow multicast MOH on the MGCP gateway. The config server ip address statement defines the IP address of the
# CallManager TFTP server from which this MGCP gateway will tftp its MGCP configuration from. Finally we need to
# specify config, in order to actually enable the MGCP configuration downloads from CallManager.
ccm-manager fallback-mgcp
ccm-manager mgcp
ccm-manager redundant-host 172.16.1.10
no ccm-manager fax protocol cisco
ccm-manager music-on-hold
ccm-manager config server 172.16.1.11
ccm-manager config
# The router has a vwic-1mft card that will be used to terminat the PRI voice circuit from the provider.
# Default framing and linecoding has been defined per carrier specs.
# We then create a pri-group with all 24 channels and need to specify the that it is using the service of mgcp
# This command will then create the serial0/0/0:23 interface which we will see further down in the config.
controller T1 0/0/0
framing esf
linecode b8zs
pri-group timeslots 1-24 service mgcp
# This router has 2 Gigabit Ethernet interfaces. We used the first one for Data and the second one
# for voice. Note there is a dhcp server on the data segment therefore we need to provide the helper-address
# on the voice side so the dhcp broadcast can be forwarded to the dhcp server.
interface GigabitEthernet0/0
description Data Vlan
ip address 10.1.1.1 255.255.255.0
duplex full
speed 1000
interface GigabitEthernet0/1
description Voice Vlan
ip address 172.16.1.1 255.255.255.0
ip helper-address 10.1.1.10
# Here is the interface that was created when we defined the pri-group. This is where the voice calls go
# in and out. We specify the isdn switch-type per the carrier specifications. We need the
# isdn incoming-voice voice statement to ensure that the calls will be handled as voice as passed off to
# a DSP (Digital Signal Processor). In order to configure the PRI signalling channel to be backhauled to
# CallManager we need to add the bind-l3 ccm-manager statement. This is needed for MGCP
# PRI voice gateways.
interface Serial0/0/0:23
no ip address
isdn switch-type primary-ni
isdn incoming-voice voice
isdn bind-l3 ccm-manager
ip classless
ip route 0.0.0.0 0.0.0.0 10.1.1.254
ip http server
ip http authentication local
ip http secure-server
ip http timeout-policy idle 600 life 86400 requests 10000
control-plane
# Prior to 12.3(14)Tx, not sure which specific one, this was needed to make sure that calls were not rejected when the dial
# peer did not have valid voice application. In this case it lets us roll back to a pre-loaded application called DEFAULT which
# handles basic call processing on the port. Although I am not 100% sure of this I believe this is needed in order to be
# able to roll back to h.323 call processing if there is an MGCP outage, i.e. can't connect to callmanager and you need
# SRST to kick using h.323 dial peers.
call application alternate DEFAULT
# Set up a local username for administrative access
username admin privilege 15 secret ciscoconfigs
# This is voice port that was dynamically created when we created the PRI-GROUP on the controller interface.
voice-port 0/0/0:23
# Finally all of the MGCP statements.
# First we turn mgcp on then we define who the call agent is. i.e. in most cases callmanager. The version type is just
# reference to different RFC versions for compatibility. Port 2427 is the default port for version 0.1.
# dtmf-relay is turned on to ensure forwarding of the digits through the compressed codecs.
# Default modem passthrough command
# The packages define what capabilities the mgcp gateway will support. This is the default set we typically use and
# works in most cases. The mgcp fax t38 is disabled by default. This is no longer true in IOS 12.4T or later.
# The sdp mode is set to simple.
# The rtp payload type is used to ensure backward compatibility if talking with an older gateway.
# The bind commands force the media and control packets to be sourced with the ip address on the
# associated gateway. You want to make this the IP address of the interface on the voice network. This way
# you know what it is.
mgcp
mgcp call-agent 172.16.1.11 2427 service-type mgcp version 0.1
mgcp dtmf-relay voip codec all mode out-of-band
mgcp rtp unreachable timeout 1000 action notify
mgcp modem passthrough voip mode nse
mgcp package-capability rtp-package
no mgcp package-capability res-package
mgcp package-capability sst-package
no mgcp package-capability fxr-package
mgcp package-capability pre-package
no mgcp timer receive-rtcp
mgcp sdp simple
mgcp fax t38 inhibit
mgcp rtp payload-type g726r16 static
mgcp bind control source-interface GigabitEthernet0/1
mgcp bind media source-interface GigabitEthernet0/1
mgcp profile default
# In this scenario, only one dial peer is needed. The key statement here is application mgcpapp, which
# tells the dial peer that it is controlled by MGCP. The incomin called-number . command will ensure that
# all incoming calls will match this dial peer. We disabled the fax rate since we are using fax pass-through.
# Since we had DID service we need to specifiy the direct-inward-dial command so the router will use the
# called number to match the destination pattern for the call. Finally we assign the PRI data channel as
# the port for this dial-peer.
dial-peer voice 1 pots
application mgcpapp
incoming called-number .
fax rate disable
direct-inward-dial
port 0/0/0:23
# Configured the console and the virtual terminal ports to accept a loing by authenticating against
# the local user database.
line con 0
login local
line aux 0
line vty 0 4
privilege level 15
login local
transport input telnet ssh
# It is always good to have a time server configured so all of your network devices will have the correct
# time. This is important when trying to correlate events between devices and logs.
ntp server 10.1.1.100
end
Refer to http://ciscoconfigs.net/