- Zone-Based Policy Firewalls
- Zone-Based Policy Firewall IPv6 Support
- VRF-Aware Cisco IOS XE Firewall
- Layer 2 Transparent Firewalls
- Nested Class Map Support for Zone-Based Policy Firewall
- Zone Mismatch Handling
- Configuring Firewall Stateful Interchassis Redundancy
- Box-to-Box High Availability Support for IPv6 Zone-Based Firewalls
- Interchassis Asymmetric Routing Support for Zone-Based Firewall and NAT
- Interchassis High Availability Support in IPv6 Zone-Based Firewalls
- Firewall Box to Box High Availability Support for Cisco CSR1000v Routers
- Firewall Stateful Inspection of ICMP
- Firewall Support of Skinny Client Control Protocol
- Configuring the VRF-Aware Software Infrastructure
- IPv6 Zone-Based Firewall Support over VASI Interfaces
- Protection Against Distributed Denial of Service Attacks
- Configuring Firewall Resource Management
- IPv6 Firewall Support for Prevention of Distributed Denial of Service Attacks and Resource Management
- Configurable Number of Simultaneous Packets per Flow
- LISP and Zone-Based Firewalls Integration and Interoperability
- Firewall High-Speed Logging
- TCP Reset Segment Control
- Loose Checking Option for TCP Window Scaling in Zone-Based Policy Firewall
- Enabling ALGs and AICs in Zone-Based Policy Firewalls
- Configuring Firewall TCP SYN Cookie
- Object Groups for ACLs
- Cisco Firewall-SIP Enhancements ALG
- MSRPC ALG Support for Firewall and NAT
- Sun RPC ALG Support for Firewalls and NAT
- vTCP for ALG Support
- ALG—H.323 vTCP with High Availability Support for Firewall and NAT
- FTP66 ALG Support for IPv6 Firewalls
- SIP ALG Hardening for NAT and Firewall
- SIP ALG Resilience to DoS Attacks
- Zone-Based Firewall ALG and AIC Conditional Debugging and Packet Tracing Support
- Prerequisites for MSRPC ALG Support for Firewall and NAT
- Restrictions for MSRPC ALG Support for Firewall and NAT
- Information About MSRPC ALG Support for Firewall and NAT
- How to Configure MSRPC ALG Support for Firewall and NAT
- Configuration Examples for MSRPC ALG Support for Firewall and NAT
- Additional References for MSRPC ALG Support for Firewall and NAT
- Feature Information for MSRPC ALG Support for Firewall and NAT
MSRPC ALG Support for
Firewall and NAT
The MSRPC ALG Support for Firewall and NAT feature provides support for the Microsoft (MS) Remote Procedure Call (RPC) application-level gateway (ALG) on the firewall and Network Address Translation (NAT). The MSRPC ALG provides deep packet inspection (DPI) of the MSRPC protocol. The MSRPC ALG works in conjunction with a provisioning system to allow the network administrator to configure match filters to define match criteria that can be searched in an MSRPC packet.
The MSRPC ALG additionally supports the Virtual Transport Control Protocol (vTCP) functionality which provides a framework for various ALG protocols to appropriately handle the TCP segmentation and parse the segments in the Cisco IOS zone-based firewall, Network Address Translation (NAT) and other applications.
- Prerequisites for MSRPC ALG Support for Firewall and NAT
- Restrictions for MSRPC ALG Support for Firewall and NAT
- Information About MSRPC ALG Support for Firewall and NAT
- How to Configure MSRPC ALG Support for Firewall and NAT
- Configuration Examples for MSRPC ALG Support for Firewall and NAT
- Additional References for MSRPC ALG Support for Firewall and NAT
- Feature Information for MSRPC ALG Support for Firewall and NAT
Prerequisites for MSRPC ALG Support for Firewall and NAT
-
You must enable the Cisco IOS XE firewall and Network Address Translation (NAT) before applying the Microsoft (MS) Remote Procedure Call (RPC) application-level gateway (ALG) on packets.
Note | MSRPC ALG is automatically enabled if traffic is sent to TCP port 135 by either Cisco IOS XE firewall or NAT, or both. |
Restrictions for MSRPC ALG Support for Firewall and NAT
Information About MSRPC ALG Support for Firewall and NAT
Application-Level Gateways
-
Allow client applications to use dynamic TCP or UDP ports to communicate with the server application.
-
Recognize application-specific commands and offer granular security control over them.
-
Synchronize multiple streams or sessions of data between two hosts that are exchanging data.
-
Translate the network-layer address information that is available in the application payload.
The firewall opens a pinhole, and NAT performs translation service on any TCP or UDP traffic that does not carry the source and destination IP addresses in the application-layer data stream. Specific protocols or applications that embed IP address information require the support of an ALG.
MSRPC
MSRPC is a framework that developers use to publish a set of applications and services for servers and enterprises. RPC is an interprocess communication technique that allows the client and server software to communicate over the network. MSRPC is an application-layer protocol that is used by a wide array of Microsoft applications. MSRPC supports both connection-oriented (CO) and connectionless (CL) Distributed Computing Environment (DCE) RPC modes over a wide variety of transport protocols. All services of MSRPC establish an initial session that is referred to as the primary connection. A secondary session over a port range between 1024 to 65535 as the destination port is established by some services of MSRPC.
For MSRPC to work when firewall and NAT are enabled, in addition to inspecting MSRPC packets, the ALG is required to handle MSRPC specific issues like establishing dynamic firewall sessions and fixing the packet content after the NAT.
By applying MSRPC protocol inspection, most MSRPC services are supported, eliminating the need for Layer 7 policy filters.
MSRPC ALG on Firewall
PDU |
Number |
Type |
Description |
---|---|---|---|
REQUEST |
0 |
call |
Initiates a call request. |
RESPONSE |
2 |
call |
Responds to a call request. |
FAULT |
3 |
call |
Indicates an RPC runtime, RPC stub, or RPC-specific exception. |
BIND |
11 |
association |
Initiates the presentation negotiation for the body data. |
BIND_ACK |
12 |
association |
Accepts a bind request. |
BIND_NAK |
13 |
association |
Rejects an association request. |
ALTER_CONTEXT |
14 |
association |
Requests additional presentation negotiation for another interface and/or version, or to negotiate a new security context, or both. |
ALTER_CONTEXT_RESP |
15 |
association |
Responds to the ALTER_CONTEXT PDU. Valid values are accept or deny. |
SHUTDOWN |
17 |
call |
Requests a client to terminate the connection and free the related resources. |
CO_CANCEL |
18 |
call |
Cancels or orphans a connection. This message is sent when a client encounters a cancel fault. |
ORPHANED |
19 |
call |
Aborts a request that in progress and that has not been entirely transmitted yet, or aborts a (possibly lengthy) response that is in progress. |
MSRPC ALG on NAT
When NAT receives an MSRPC packet, it invokes the MSRPC ALG that parses the packet payload and forms a token to translate any embedded IP addresses. This token is passed to NAT, which translates addresses or ports as per your NAT configuration. The translated addresses are then written back into the packet payload by the MSRPC ALG.
If you have configured both the firewall and NAT, NAT calls the ALG first.
MSRPC Stateful Parser
The MSRPC state machine or the parser is the brain of the MSRPC ALG. The MSRPC stateful parser keeps all stateful information within the firewall or NAT depending on which feature invokes the parser first. The parser provides DPI of MSRPC protocol packets. It checks for protocol conformance and detects out-of-sequence commands and malformed packets. As the packet is parsed, the state machine records various data and fills in the correct token information for NAT and firewall inspection.
How to Configure MSRPC ALG Support for Firewall and NAT
Note | By default, MSRPC ALG is automatically enabled when NAT is enabled. There is no need to explicitly enable MSRPC ALG in the NAT-only configuration. You can use the no ip nat service msrpc command to disable MSRPC ALG on NAT. |
- Configuring a Layer 4 MSRPC Class Map and Policy Map
- Configuring a Zone Pair and Attaching an MSRPC Policy Map
- Enabling vTCP Support for MSRPC ALG
- Disabling vTCP Support for MSRPC ALG
Configuring a Layer 4 MSRPC Class Map and Policy Map
1.
enable
2.
configure terminal
3.
class-map type inspect match-any
class-map-name
4.
match protocol
protocol-name
5.
exit
6.
policy-map type inspect
policy-map-name
7.
class type inspect
class-map-name
8.
inspect
9.
end
DETAILED STEPS
Configuring a Zone Pair and Attaching an MSRPC Policy Map
1.
enable
2.
configure terminal
3.
zone security
security-zone-name
4.
exit
5.
zone security
security-zone-name
6.
exit
7.
zone-pair security
zone-pair-name
[source
source-zone
destination
[destination-zone]]
8.
service-policy type inspect
policy-map-name
9.
end
DETAILED STEPS
Enabling vTCP Support for MSRPC ALG
1.
enable
2.
configure
terminal
3.
alg vtcp service
msrpc
4.
exit
5.
set platform hardware qfp
active feature alg msrpc tolerance on
DETAILED STEPS
Command or Action | Purpose | |||
---|---|---|---|---|
Step 1 |
enable
Example: Router> enable |
| ||
Step 2 |
configure
terminal
Example: Router# configure terminal |
Enters global configuration mode. | ||
Step 3 |
alg vtcp service
msrpc
Example: Rotuer(config)# alg vtcp service msrpc |
| ||
Step 4 |
exit
Example: Rotuer(config)# exit |
Exits global configuration mode and returns to privileged EXEC mode. | ||
Step 5 |
set platform hardware qfp
active feature alg msrpc tolerance on
Example: Rotuer# set platform hardware qfp active feature alg msrpc tolerance on |
|
Disabling vTCP Support for MSRPC ALG
1.
enable
2.
configure
terminal
3.
no alg vtcp service
msrpc
4.
end
DETAILED STEPS
Command or Action | Purpose | |
---|---|---|
Step 1 |
enable
Example: Router> enable |
|
Step 2 |
configure
terminal
Example: Router# configure terminal |
Enters global configuration mode. |
Step 3 |
no alg vtcp service
msrpc
Example: Rotuer(config)# no alg vtcp service msrpc |
Disables vTCP functionality for MSRPC ALG. |
Step 4 |
end
Example: Rotuer(config)# end |
Exits global configuration mode and returns to privileged EXEC mode. |
Configuration Examples for MSRPC ALG Support for Firewall and NAT
Example: Configuring a Layer 4 MSRPC Class Map and Policy Map
Router# configure terminal Router(config)# class-map type inspect match-any msrpc-cmap Router(config-cmap)# match protocol msrpc Router(config-cmap)# exit Router(config)# policy-map type inspect msrpc-pmap Router(config-pmap)# class type inspect msrpc-cmap Router(config-pmap-c)# inspect Router(config-pmap-c)# end
Example: Configuring a Zone Pair and Attaching an MSRPC Policy Map
Router# configure terminal Router(config)# zone security in-zone Router(config-sec-zone)# exit Router(config)# zone security out-zone Router(config-sec-zone)# exit Router(config)# zone-pair security in-out source in-zone destination out-zone Router(config-sec-zone-pair)# service-policy type inspect msrpc-pmap Router(config-sec-zone-pair)# end
Example: Enabling vTCP Support for MSRPC ALG
Router# configure terminal Router(config)# alg vtcp service msrpc Router(config)# end
Example: Disabling vTCP Support for MSRPC ALG
Router# configure terminal Router(config)# no alg vtcp service msrpc Router(config)# end
Additional References for MSRPC ALG Support for Firewall and NAT
Related Documents
Related Topic |
Document Title |
---|---|
Cisco IOS commands |
|
NAT commands |
|
Security commands |
|
NAT ALGs |
“Using Application-Level Gateways with NAT” module |
ALG support |
NAT and Firewall ALG Support on Cisco ASR 1000 Series Routers |
Technical Assistance
Description |
Link |
---|---|
The Cisco Support and Documentation website provides online resources to download documentation, software, and tools. Use these resources to install and configure the software and to troubleshoot and resolve technical issues with Cisco products and technologies. Access to most tools on the Cisco Support and Documentation website requires a Cisco.com user ID and password. |
Feature Information for MSRPC ALG Support for Firewall and NAT
The following table provides release information about the feature or features described in this module. This table lists only the software release that introduced support for a given feature in a given software release train. Unless noted otherwise, subsequent releases of that software release train also support that feature.
Use Cisco Feature Navigator to find information about platform support and Cisco software image support. To access Cisco Feature Navigator, go to www.cisco.com/go/cfn. An account on Cisco.com is not required.
Feature Name |
Releases |
Feature Information |
---|---|---|
MSRPC ALG Support for Firewall and NAT |
Cisco IOS XE Release 3.5S |
The MSRPC ALG Support for Firewall and NAT feature provides support for the MSRPC ALG on the firewall and NAT. The MSRPC ALG provides deep packet inspection of the MSRPC protocol. The MSRPC ALG works in conjunction with a provisioning system to allow the network administrator to configure match filters that define match criteria that can be searched in an MSRPC packet. The following commands were introduced or modified: ip nat service msrpc, match protocol msrpc. |
MSRPC ALG Inspection Improvements for Zone-based Firewall and NAT |
Cisco IOS XE Release 3.14S |
The MSRPC ALG Inspection Improvements for Zone-based Firewall and NAT feature supports Virtual Transport Control Protocol (vTCP) functionality which provides a framework for various ALG protocols to appropriately handle the TCP segmentation and parse the segments in the Cisco firewall, Network Address Translation (NAT) and other applications. The following command was introduced: alg vtcp service msrpc. |