network-based application recognition.pdf

Upload: sonlamcho18

Post on 02-Jun-2018

221 views

Category:

Documents


0 download

TRANSCRIPT

  • 8/10/2019 Network-Based Application Recognition.pdf

    1/54

    1

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Network-Based Application Recognition andDistributed Network-Based ApplicationRecognition

    Feature History

    Cisco IOS Release Modification

    12.0(5)XE2 The N BAR feature w as i ntroduced. The first i mplementation o f the N BAR

    feature was available on Cisco 7100 and Cisco 7200 series routers.

    12.1(1)E Subport classification of HTTP traffic by host name for NBAR was

    introduced. The variable-field-name value options were also added to the

    match protocolcommand.

    12.1(2)E Support for the Citrix, Novadigm, and Printer protocols for NBAR was

    introduced.

    12.1(5)T This feature was introduced for the Cisco IOS Release 12.1 T train.

    NBAR became available on Cisco 2600 and 3600 series routers.

    12.1(6)E The dNBAR feature, which introduced NBAR functionality on the Cisco

    7500 series router with a VIP and the Catalyst 6000 family switch with a

    FlexWAN module, was introduced.

    12.1(10)EC NBAR was introduced for Cisco 7100 uBR and Cisco 7200 uBR routers.

    12.1(11b)E The match protocol rtpcommand was introduced on the Cisco IOS

    Release 12.1 E train.

    12.1(12c)E The match protocol gnutellaand match protocol fasttrackcommands

    were added because Gnutella and FastTrack became available as

    NBAR-supported protocols.

    12.1(13)E NBAR was released on the Catalyst 6000 family switch without a

    FlexWAN module.

    12.2(2)T This feature was introduced on Cisco 1700 series routers.

    12.2(4)T3 The dNBAR feature introduced NBAR functionality on the Cisco IOS

    Release 12.2 T train. This feature was introduced for the Cisco 7500

    series router with a VIP only.

  • 8/10/2019 Network-Based Application Recognition.pdf

    2/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    2

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    This document provides information for the Network-Based Application Recognition (NBAR) and the

    Distributed Network-Based Application Recognition (dNBAR) features. This document contains all of

    the updates made to the NBAR and dNBAR features.

    Before proceeding, it is important to note that the dNBAR feature, which introduced NBAR on the

    Cisco 7500 with a Versatile Interface Processor (VIP) and the Catalyst 6000 family switch with a

    FlexWAN module, is identical in implementation to NBAR. Therefore, unless otherwise noted, the term

    NBAR is used throughout this document to describe both the NBAR and dNBAR feature. The term

    dNBAR is used only when appropriate.

    This document includes information on the benefits of NBAR, supported platforms, restrictions,definitions, and new and revised command syntax.

    12.2(8)T The match protocol rtpcommand was introduced, allowing NBAR to

    classify Real-Time Transport Protocol (RTP) traffic.

    The Cisco 3700 also became available. The initial release of the Cisco3700 supported NBAR.

    12.2(14)S NBAR and dNBAR were introduced in Cisco IOS Release 12.2 S. The

    12.2 S version of NBAR includes everything available on the 12.1 E and

    12.2 T implementations of NBAR with the exception of platform support

    for platforms not supported by 12.2 S.

    12.3(4)T NBAR PDLM Versioning was introduced. This feature introduced

    versioning of PDLM protocols and the show ip nbar version command.

    See the IP NBAR PDLM Module Versioning section on page 12for

    additional information regarding this feature.

    The NBAR User-Defined Custom Application Classification feature was

    introduced. See the Classification of Custom Applications section onpage 10for additional information on the enhancements to the custom

    protocol that were introduced as part of this feature.

    The NBAR Extended Inspection for HTTP Traffic feature was introduced.

    This feature allows NBAR to scan TCP ports that are not well-known and

    identify HTTP traffic traversing these ports.

    12.3(2)XE NBAR was introduced on Cisco 800 series routers.

    To see if NBAR is supported in other platforms, see the Supported

    Platforms section on page 20of this document.

    12.3(7)T Restrictions on the number of bytes of payload that could be inspected by

    NBAR were removed. NBAR can now inspect the full packet payload.

    12.3(8)T NBAR was introduced on Cisco 800 series routers running Cisco IOS

    Release 12.3 T.

    Feature History (continued)

    Cisco IOS Release Modification

  • 8/10/2019 Network-Based Application Recognition.pdf

    3/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    3

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    This document includes the following sections:

    Feature Overview, page 3

    Supported Platforms, page 20

    Supported Standards, MIBs, and RFCs, page 21

    Prerequisites, page 23

    Configuration Tasks, page 23

    Monitoring and Maintaining NBAR, page 27

    Configuration Examples, page 27

    Command Reference, page 28

    Glossary, page 53

    Appendix, page 53

    Feature OverviewThe purpose of IP Quality of Service (QoS) is to provide appropriate network resources (bandwidth,delay, jitter, and packet loss) to applications. QoS maximizes the return on investments on network

    infrastructure by ensuring that mission critical applications get the required performance and

    noncritical applications do not hamper the performance of critical applications.

    IP QoS can be deployed by defining classes or categories of applications. These classes are defined by

    using various classification techniques available in Cisco IOS software. After these classes are defined

    and attached to an interface, the desired QoS features, such as Marking, Congestion Management,

    Congestion Avoidance, Link Efficiency mechanisms, or Policing and Shaping can then be applied to the

    classified traffic to provide the appropriate network resources amongst the defined classes.

    Classification, therefore, is an important first-step in configuring QoS in a network infrastructure.

    NBAR is a classification engine that recognizes a wide variety of applications, including web-based andother difficult-to-classify protocols that utilize dynamic TCP/UDP port assignments. When an

    application is recognized and classified by NBAR, a network can invoke services for that specific

    application. NBAR ensures that network bandwidth is used efficiently by classifying packets and then

    applying Quality of Service (QoS) to the classified traffic. Some examples of class-based QoS features

    that can be used on traffic after the traffic is classified by NBAR include:

    Class-Based Marking (the setcommand)

    Class-Based Weighted Fair Queueing (the bandwidthand queue-limitcommands)

    Low Latency Queueing (the prioritycommand)

    Traffic Policing (the policecommand)

    Traffic Shaping (the shapecommand)

    Note For an animated example of NBAR being used with other QoS features to solve a network

    problem, click here.

  • 8/10/2019 Network-Based Application Recognition.pdf

    4/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    4

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Note The NBAR feature is used for classifying traffic by protocol. The other class-based QoS

    features determine how the classified traffic is forwarded and are documented separately

    from NBAR. Furthermore, NBAR is not the only method of classifying network traffic so

    that QoS features can be applied to classified traffic.

    For information on the class-based features that can be used to forward NBAR-classified

    traffic, see the individual feature modules for the particular class-based feature as well as

    the Cisco IOS Quality of Service Solutions Guide.

    Many of the non-NBAR classification options for QoS are documented in the Modular

    Quality of Service Command-Line Interface section of the Cisco IOS Quality of Service

    Solutions Guide. These commands are configured using the match command in class map

    configuration mode.

    NBAR introduces several new classification features that identify applications and protocols from

    Layer 4 through Layer 7:

    Statically assigned TCP and UDP port numbers Non-UDP and non-TCP IP protocols

    Dynamically assigned TCP and UDP port numbers. Classification of such applications requires

    stateful inspection; that is, the ability to discover the data connections to be classified by parsing

    the connections where the port assignments are made.

    Sub-port classification or classification based on deep packet inspection; that is, classification by

    looking deeper into the packet.

    NBAR can classify static port protocols. Although access control lists (ACLs) can also be used for this

    purpose, NBAR is easier to configure and can provide classification statistics that are not available when

    using ACLs.

    NBAR includes a Protocol Discovery feature that provides an easy way to discover application

    protocols that are transversing an interface. The Protocol Discovery feature discovers any protocoltraffic supported by NBAR. Protocol Discovery maintains the following per-protocol statistics for

    enabled interfaces: total number of input and output packets and bytes, and input and output bit rates.

    The Protocol Discovery feature captures key statistics associated with each protocol in a network that

    can be used to define traffic classes and QoS policies for each traffic class.

    Benefits

    Ability to Identify and Classify Network Traffic by Protocol

    Identifying and classifying network traffic is an important first step in implementing QoS. A network

    administrator can more effectively implement QoS in a networking environment after identifying the

    amount and the variety of applications and protocols running on a network.

    NBAR gives network administrators the ability to see the variety of protocols and the amount of traffic

    generated by each protocol. After gathering this information, NBAR allows users to implement classes

    of traffic. These classes of traffic can then be used to provide different levels of service for network

    traffic, therefore allowing better network management by providing the right level of network resources

    for network traffic.

  • 8/10/2019 Network-Based Application Recognition.pdf

    5/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    5

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    NBAR Application Notes

    The following section provides information on several topics that could be useful to individuals

    configuring NBAR in their networks. The following topics are covered in this section:

    Catalyst 6000 Family Switches without FlexWAN Modules Application Notes

    Packet Description Language Module

    Classification of HTTP by URL, Host, or MIME

    Classification of Citrix ICA Traffic by Application Name

    RTP Payload Type Classification

    Classification of Custom Applications

    Classification of Peer-to-Peer File-Sharing Applications

    IP NBAR PDLM Module Versioning

    Supported Protocols

    Catalyst 6000 Family Switches without FlexWAN Modules Application Notes

    When NBAR is enabled on a Catalyst 6000 without a FlexWAN module interface, all traffic flows

    entering or leaving the NBAR-enabled interface will be processed in software on the Multilayer Swich

    Feature Card 2 (MSFC2).

    The following other restrictions should also be noted when running NBAR:

    NBAR can only be implemented on an MSFC2 with Supervisor Engine 1 or Supervisor Engine 2.

    NBAR Protocol Discovery or QoS service policies using NBAR to match protocols cannot co-exist

    on an interface that contains Catalyst 6000-specific QoS actions. Refer to the Catalyst 6000 QoS

    Guide for Catalyst 6000-specific QoS actions (at the time of this publication, the current Catalyst

    6000-specific QoS actions were police and trust, but please refer to the Catalyst 6000 QoS Guide

    for additional information).The following table provides configuration results when NBAR is added to an interface. The results

    vary depending on the current configuration of the policy map on the interface.

    Table1 NBAR Behavior Descriptions

    Current Policy Map State Action Result

    At least one service policy

    with platform-specific

    QoS action in the policy

    map is attached to

    interface.

    Enable Protocol

    Discovery on the

    interface.

    Protocol Discovery is

    rejected.

    No service policies on theinterface have NBAR or a

    platform-specific QoS

    action in the policy map.

    Enable ProtocolDiscovery on the

    interface.

    Protocol Discovery isaccepted, but the service

    policy is disabled from the

    interface.

    A service policy on the

    interface contains match

    protocolNBAR

    commands.

    Enable Protocol

    Discovery on the

    interface.

    Protocol Discovery is

    accepted.

  • 8/10/2019 Network-Based Application Recognition.pdf

    6/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    6

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    No policy map is on the

    interface.

    Enable Protocol

    Discovery on the

    interface.

    The command is accepted.

    Traffic is processed on the

    MSFC2 once the command

    is accepted.

    No policy map is on the

    interface

    Disable Protocol

    Discovery.

    The command is accepted.

    Traffic is no longer

    processed on the MSFC2.

    No service policies on the

    interface have

    platform-specific QoS

    actions or match protocol

    NBAR commands.

    Disable Protocol

    Discovery.

    Protocol Discovery is

    disabled. The service policy

    is removed from the

    interface. The service policy

    can be reattached.

    At least one service policy

    on the interface is using

    the match protocol

    NBAR command.

    Disable Protocol

    Discovery.

    Protocol Discovery is

    disabled.

    A service policy with a

    platform-specific QoS

    action and Protocol

    Discovery is enabled on

    the interface.

    Attach the service

    policy to an

    interface.

    Reject the service policy.

    Protocol Discovery and

    platform-specific QoS

    actions cannot be enabled in

    the same policy map.

    Protocol Discovery is

    enabled on an interface

    and the service policy has

    a non-platform specific

    QoS action.

    Attach the service

    policy to an

    interface.

    The policy map is attached.

    The policy map has to be

    attached in IOS QoS mode.

    No match protocol

    NBAR commands are inany service policy on the

    interface and Protocol

    Discovery is not enabled.

    Attach the service

    policy to aninterface.

    The policy map is attached

    in Catalyst 6000 QoS mode.

    Protocol Discovery is not

    enabled on the interface

    and match protocol

    NBAR commands are in at

    least one service policy on

    the interface.

    Attach the service

    policy to an

    interface.

    The service policy is

    attached in IOS mode and

    traffic is processed using the

    MSFC2.

    A service policy that has

    no match protocol NBAR

    commands and noProtocol Discovery needs

    to be removed from the

    interface. The interface

    contains no other service

    policies that contain

    match protocolNBAR

    commands or Protocol

    Discovery.

    Detach the service

    policy from an

    interface

    The service policy is

    detached like any other

    service policy.

    Current Policy Map State Action Result

  • 8/10/2019 Network-Based Application Recognition.pdf

    7/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    7

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Packet Description Language Module

    An external Packet Description Language Module (PDLM) can be loaded at run time to extend the

    NBAR list of recognized protocols. PDLMs can also be used to enhance an existing protocol

    recognition capability. PDLMs allow NBAR to recognize new protocols without requiring a new

    Cisco IOS image or a router reload.

    New PDLMs will only be released by Cisco and can be loaded from Flash memory. Please contact your

    local Cisco representative to request additions or changes to the set of protocols classified by NBAR.

    To view a list of currently available PDLMs or to download a PDLM, go to the following URL:

    http://www.cisco.com/cgi-bin/tablebuild.pl/pdlm

    Classification of HTTP by URL, Host, or MIME

    NBAR can classify application traffic by looking beyond the TCP/UDP port numbers of a packet. This

    is subport classification. NBAR looks into the TCP/UDP payload itself and classifies packets on content

    within the payload such as transaction identifier, message type, or other similar data.

    A service policy with

    match protocolNBAR

    commands needs to be

    detached from the

    interface. Another servicepolicy attached in the

    opposite direction does

    not contain match

    protocolNBAR

    commands. No Protocol

    Discovery is enabled on

    the interface.

    Detach the service

    policy with match

    protocolNBAR

    commands from the

    interface.

    The service policy is

    detached and the other

    service policy in the

    opposite direction is also

    removed. Traffic is nolonger processed using the

    MSFC2.

    A service policy contains

    match protocolNBAR

    commands and the service

    policy in the other

    direction needs matchprotocolNBAR or

    Protocol Discovery needs

    to be enabled on the

    interface.

    Detach the service

    policy from the

    interface.

    The service policy is

    detached. Continue to

    process traffic on the

    MSFC2 so that match

    protocolcan be enabled onthe other service policy or

    Protocol Discovery can be

    enabled on the interface.

    A service policy contains

    match protocolNBAR

    commands. No other

    service policies are on the

    interface and Protocol

    Discovery is not enabled.

    Detach the service

    policy from the

    interface.

    Service policy is detached.

    Traffic is no longer

    processed on the MSFC2.

    Current Policy Map State Action Result

  • 8/10/2019 Network-Based Application Recognition.pdf

    8/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    8

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Classification of HTTP by URL, host, or Multipurpose Internet Mail Extension (MIME) type is an

    example of subport classification. NBAR classifies HTTP traffic by text within the URL or host fields

    of a request using regular expression matching. HTTP URL matching in NBAR supports most HTTP

    request methods such as GET, PUT, HEAD, POST, DELETE, and TRACE. NBAR uses the UNIX

    filename specification as the basis for the URL or host specification format. The NBAR engine then

    converts the specified match string into a regular expression.

    NBAR recognizes HTTP packets containing the URL and classifies all packets that are sent to the

    source of the HTTP request. Figure 1 illustrates a network topology with NBAR in which Router Y is

    the NBAR-enabled router.

    Figure1 Network Topology with NBAR

    When specifying a URL for classification, include only the portion of the URL following the

    www.hostname.domain in the match statement. For example, for the URL

    www.cisco.com/latest/whatsnew.html, include only /latest/whatsnew.html.

    Host specification is identical to URL specification. NBAR performs a regular expression match on the

    host field contents inside an HTTP packet and classifies all packets from that host. For example, for the

    URL www.cisco.com/latest/whatsnew.html, include only www.cisco.com.

    For MIME type matching, the MIME type can contain any user-specified text string. A list of the

    Internet Assigned Numbers Authority (IANA)-supported MIME types can be found at:

    ftp://ftp.isi.edu/in-notes/iana/assignments/media-types/media-typesIn MIME type matching, NBAR classifies the packet containing the MIME type and all subsequent

    packets, which are sent to the source of the HTTP request.

    NBAR supports URL and host classification in the presence of persistent HTTP. NBAR does not

    classify packets that are part of a pipelined request. With pipelined requests, multiple requests are

    pipelined to the server before previous requests are serviced. Pipelined requests are a less commonly

    used type of persistent HTTP request.

    In Cisco IOS Release 12.3(4)T, the NBAR Extended Inspection for HTTP Traffic feature was

    introduced. This feature allows NBAR to scan TCP ports that are not well-known and identify HTTP

    traffic traversing these ports. HTTP traffic classifications are no longer restrained to the well-known and

    defined TCP ports.

    Classification of Citrix ICA Traffic by Application Name

    NBAR can classify Citrix Independent Computing Architecture (ICA) traffic and perform subport

    classification of Citrix traffic based on Citrix published applications. NBAR can monitor Citrix ICA

    client requests for a published application destined to a Citrix ICA Master browser. After the client

    requests to the published application, the Citrix ICA Master browser directs the client to the server with

    the most available memory. The Citrix ICA client then connects to this Citrix ICA server for the

    application.

    Router X Router Y

    HTTP server

    HTTP clients

    HTTP get request

    HTTP get response

    (classified)

    29056

  • 8/10/2019 Network-Based Application Recognition.pdf

    9/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    9

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    NBAR statefully tracks Citrix ICA server client messages and classifies requests for given Citrix

    application names and traffic. A Citrix application is named when published on a Citrix ICA server.

    NBAR performs a regular expression match using a user-specified application name string on the

    contents of the Citrix ICA control packets carrying the published application name. Therefore, users

    need to specify a regular expression that will result in a match for the published application name if they

    want to match a specified application. See the match protocol citrixcommand in the Command

    Reference section for additional information.

    Citrix ICA clients can be configured in various modes. NBAR cannot distinguish among Citrix

    applications in all modes of operation. Therefore, network administrators might need to collaborate

    with Citrix administrators to ensure that NBAR properly classifies Citrix traffic.

    A Citrix administrator can configure Citrix to publish Citrix applications individually or as the entire

    desktop. In the Published Desktop mode of operation, all applications within the published desktop of

    a client use the same TCP session. Therefore, differentiation among applications is impossible, and

    NBAR can only be used to classify Citrix applications as aggregates (by looking at port 1494).

    The Published Application mode for Citrix ICA clients is recommended when you use NBAR. In

    Published Application mode, a Citrix administrator can configure a Citrix client in either seamless or

    non-seamless (windows) modes of operation. In non-seamless mode, each Citrix application uses a

    separate TCP connection, and NBAR can be used to provide interapplication differentiation based onthe name of the published application.

    Seamless mode clients can operate in one of two submodes: session sharing or non-session sharing. In

    seamless session sharing mode, all clients share the same TCP connection, and NBAR cannot

    differentiate among applications. Seamless sharing mode is enabled by default on some software

    releases.

    In seamless non-session sharing mode, each application for each particular client uses a separate TCP

    connection. NBAR can provide interapplication differentiation in seamless non-session sharing mode

    Session sharing can be turned off using the following steps:

    Step 1 At the command prompt of the Citrix server, open the registry editor by entering the regedit command

    Step 2 Create the following registry entry (which overrides session sharing):

    [HKLM]\SYSTEM\CurrentControlSet\Control\Citrix\WFSHELL\TWI

    Value name: "SeamlessFlags", type DWORD, possible value0 or 1

    Setting this registry value to 1 overrides session sharing. Note that this flag is SERVER GLOBAL.

    Note NBAR operates properly in Citrix ICA secure mode. Pipelined Citrix ICA client requests

    are not supported.

    RTP Payload Type Classification

    RTP is a packet format for multimedia data streams. It can be used for media-on-demand as well as

    interactive services such as Internet telephony. RTP consists of a data and a control part. The control

    part is called Real-time Transport Control Protocol (RTCP). It is important to note that the NBAR RTP

    Payload Type Classification feature does not identify RTCP packets, and that RTCP packets run on odd

    numbered ports while RTP packets run on even-numbered ports.

  • 8/10/2019 Network-Based Application Recognition.pdf

    10/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    10

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    The data part of RTP is a thin protocol providing support for applications with real-time properties such

    as continuous media (such as audio and video), which includes timing reconstruction, loss detection,

    and security and content identification. RTP is discussed in RFC 1889 and RFC 1890.

    The RTP payload type is the data transported by RTP in a packet, for example audio samples or

    compressed video data.

    NBAR RTP Payload Type Classification not only allows one to statefully identify real-time audio andvideo traffic, but it also can differentiate on the basis of audio and video CODECs to provide more

    granular Quality of Service. The RTP Payload Type Classification feature, therefore, looks deep into

    the RTP header to classify RTP packets.

    NBAR RTP Payload Type Classification was first introduced in Cisco IOS Release 12.2(8)T and is also

    available in Cisco IOS Release 12.1(11b)E.

    Classification of CustomApplications

    The custom protocol supports static port-based protocols and applications that are not currently

    supported in NBAR. This functionality allows mapping of static TCP and UDP port numbers to custom

    protocol within NBAR. The custom protocol is also available as a PDLM if your version of Cisco IOS

    supports NBAR but not the custom protocol.

    The initial custom NBAR application had the following features that were later enhanced in Cisco IOS

    Release 12.3(4)T:

    The custom protocol had to be named custom-xx, with xx being a number.

    10 custom applications can be assigned using NBAR, and each customer application can have up

    to 16 TCP and 16 UDP ports each mapped to the individual custom protocol. The real-time

    statistics of each custom protocol can be monitored using Protocol Discovery.

    In Cisco IOS Release 12.3(4)T, the User-Defined Custom Application Classification feature was

    introduced and the following enhancements to custom protocols were introduced:

    The ability to inspect the payload for certain matching string patterns at a specific offset.

    The ability to allow users to define the names of their custom protocol applications. Theuser-named protocol can then be used by Protocol Discovery, the Protocol Discovery MIB, match

    protocol, or ip nbar port-mapas an NBAR-supported protocol.

    The ability to allow NBAR inspection for custom protocols to be specified by direction of traffic

    (traffic heading toward a source or destination rather than defaulting to traffic in both directions) if

    desired by user.

    Provides CLI support that allows a user configuring a custom application to specify a range of ports

    rather than have to enter each port individually.

    For additional information on the enhancements to the custom protocol that were introduced in

    Cisco IOS Release 12.3(4)T, see the ip nbar customcommand reference in this document.

    Pre-12.3(4)T CustomApplication Example

    In the following example, a gaming application that runs on TCP port 8877 needs to be classified using

    NBAR. You can use custom-01 to map TCP port 8877 by entering the following command:

    Router(config)# ip nbar port-map custom-01 tcp 8877

    It is important to note that this configuration is also supported on Cisco IOS releases released after

    Release 12.3(4)T but is required on all prior releases.

  • 8/10/2019 Network-Based Application Recognition.pdf

    11/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    11

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    12.3(4)T and Later CustomApplication Examples

    In the following example, the custom protocol app_sales1 will identify TCP packets with a source port

    of 4567 and contain the term SALES in the fifth byte of the payload:

    ip nbar custom app_sales1 5 ascii SALES source tcp 4567

    In the following example, the custom protocol virus_home will identify UDP packets with a destinationport of 3000 and contain 0x56 in the seventh byte of the payload:

    ip nbar custom virus_home 7 hex 0x56 dest udp 3000

    In the following example, custom protocol media_new will identify TCP packets with a destination or

    source port of 4500 and that have a value of 90 at the sixth byte of the payload:

    ip nbar custom media_new 6 decimal 90 tcp 4500

    In the following example, custom protocol msn1 will look for TCP packets with a destination or source

    port of 6700:

    ip nbar custom msn1 tcp 6700

    In the following example, custom protocol mail_x will look for UDP packets with a destination port of8202:

    ip nbar custom mail_x destination udp 8202

    In the following example, custom protocol mail_y will look for UDP packets with destination ports

    between 3000 and 4000 including 3000 and 4000 as well as port 5500:

    ip nbar custom mail_y destination udp range 3000 4000 5500

    Classification of Peer-to-Peer File-Sharing Applications

    Gnutella and FastTrack are peer-to-peer file-sharing protocols that became classifiable using NBAR in

    Cisco IOS Release 12.1(12c)E.The match protocol gnutella file-transferregular-expression and match protocol fasttrack

    file-transfer regular-expression commands are used to enable Gnutella and FastTrack classification

    in a traffic class. The regular-expression variable can be expressed as * to indicate that all FastTrack

    or Gnutella traffic be classified by a traffic class.

    In the following example, all FastTrack traffic is classified into class map nbar:

    class-map match-all nbar

    match protocol fasttrack file-transfer "*"

    Similarly, all Gnutella traffic is classified into class map nbar in this example:

    class-map match-all nbar

    match protocol gnutella file-transfer "*"

    Wildcard characters in a regular expression can also be used to identify specified Gnutella and

    FastTrack traffic. These regular expression matches can be used to match based on a filename extension

    or on a particular string in a filename.

    In the following example, all Gnutella files that have the .mpeg extension will be classified into class

    map nbar.

    class-map match-all nbar

    match protocol gnutella file-transfer "*.mpeg"

  • 8/10/2019 Network-Based Application Recognition.pdf

    12/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    12

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    In the following example, only Gnutella traffic that contains the characters cisco is classified:

    class-map match-all nbar

    match protocol gnutella file-transfer *cisco*

    The same examples can be used for FastTrack traffic:

    class-map match-all nbar

    match protocol fasttrack file-transfer "*.mpeg"

    or

    class-map match-all nbar

    match protocol fasttrack file-transfer *cisco*

    Applications that use FastTrack include KaZaA, Grokster, and Morpheus (although newer versions of

    Morpheus use Gnutella).

    Some of the applications that use Gnutella include:

    BearShare

    Gnewtellium

    Gnucleus

    Gtk-Gnutella

    JTella

    LimeWire

    Morpheus

    Mutella

    Phex

    Qtella

    Swapper

    XoloX

    XCache

    IP NBAR PDLM Module Versioning

    A Packet Description Language Module (PDLM) is used to add a new protocol to the list of supported

    NBAR protocols. Before downloading PDLMs, users should understand some of the interdependencies

    between the versioning of NBAR in the Cisco IOS code and the PDLM file itself. The following

    definitions help define some of the aspects of NBAR and PDLM versioning and the interdependencies

    required between the two before a new protocol can be supported in NBAR via a PDLM download.

    The following version numbers are kept by the Cisco IOS software:

    NBAR Software VersionThis is the version of NBAR software running on the current version ofCisco IOS.

    Resident Module VersionThis is the version of the NBAR-supported PDLM protocol. The

    Resident Module Version must be less than the NBAR PDLM Interdependency Version of the

    PDLM for a PDLM file to be downloaded from cisco.com and accepted within NBAR in the IOS

    software.

    The following version numbers is kept by the PDLM:

  • 8/10/2019 Network-Based Application Recognition.pdf

    13/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    13

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    NBAR Software VersionThe minimum version of the NBAR software required to load this

    PDLM.

    See the show ip nbar versioncommand reference in this document for additional information on IP

    NBAR PDLM Module Versioning.

    Supported Protocols

    NBAR is capable of classifying the following three types of protocols:

    Non-UDP and non-TCP IP protocols

    TCP and UDP protocols that use statically assigned port numbers

    TCP and UDP protocols that dynamically assign port numbers and therefore require stateful

    inspection. This table includes packets that require sub-port classification and classification based

    on deep packet inspection.

    Table2 Non-UDP and Non-TCP Protocols

    Protocol Type Well-KnownPort Number Description Syntax Cisco IOSRelease1

    1. Indicates the Cisco IOS maintenance release that first supported the protocol. This table is updated when a protocol is

    added to a new Cisco IOS release train.

    EGP IP 8 Exterior Gateway Protocol egp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    EIGRP IP 88 Enhanced Interior Gateway

    Routing Protocol

    eigrp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    GRE IP 47 Generic Routing

    Encapsulation

    gre 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    ICMP IP 1 Internet Control MessageProtocol

    icmp 12.0(5)XE212.1(1)E

    12.1(5)T

    IPINIP IP 4 IP in IP ipinip 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    IPSec IP 50, 51 IP Encapsulating Security

    Payload/Authentication

    Header

    ipsec 12.0(5)XE2

    12.1(1)E

    12.1(5)T

  • 8/10/2019 Network-Based Application Recognition.pdf

    14/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    14

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Table3 TCP and UDP Static Port Protocols

    Protocol TypeWell-KnownPort Number Description Syntax

    Cisco IOSRelease1

    BGP TCP/UDP 179 Border Gateway

    Protocol

    bgp 12.0(5)XE2

    12.1(1)E12.1(5)T

    CU-SeeMe TCP/UDP 7648, 7649 Desktop

    videoconferencing

    cuseeme 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    CU-SeeMe UDP 24032 Desktop video

    conferencing

    cuseeme 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    DHCP/

    BOOTP

    UDP 67, 68 Dynamic Host

    ConfigurationProtocol/

    Bootstrap Protocol

    dhcp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    DNS TCP/UDP 53 Domain Name System dns 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Finger TCP 79 Finger user information

    protocol

    finger 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Gopher TCP/UDP 70 Internet Gopher

    Protocol

    gopher 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    HTTP TCP 802 Hypertext Transfer

    Protocol

    http 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    HTTPS TCP 443 Secured HTTP secure-http 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    IMAP TCP/UDP 143, 220 Internet Message

    Access Protocol

    imap 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    IRC TCP/UDP 194 Internet Relay Chat irc 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Kerberos TCP/UDP 88, 749 Kerberos Network Authentication Service

    kerberos 12.0(5)XE212.1(1)E

    12.1(5)T

    L2TP UDP 1701 L2F/L2TP tunnel l2tp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

  • 8/10/2019 Network-Based Application Recognition.pdf

    15/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    15

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    LDAP TCP/UDP 389 Lightweight Directory

    Access Protocol

    ldap 12.0(5)XE2

    12.1(1)E12.1(5)T

    MS-PPTP TCP 1723 Microsoft

    Point-to-Point

    Tunneling Protocol for

    VPN

    pptp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    MS-

    SQLServer

    TCP 1433 Microsoft SQL Server

    Desktop

    Videoconferencing

    sqlserver 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    NetBIOS TCP 137, 139 NetBIOS over IP (MS

    Windows)

    netbios 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    NetBIOS UDP 137, 138 NetBIOS over IP (MS

    Windows)

    netbios 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    NFS TCP/UDP 2049 Network File System nfs 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    NNTP TCP/UDP 119 Network News Transfer

    Protocol

    nntp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Notes TCP/UDP 1352 Lotus Notes notes 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Novadigm TCP/UDP 3460-3465 Novadigm Enterprise

    Desktop

    Manager (EDM)

    novadigm 12.1(2)E

    12.1(5)T

    NTP TCP/UDP 123 Network Time Protocol ntp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    PCAnywhere TCP 5631, 65301 Symantec PCAnywhere pcanywhere 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    PCAnywhere UDP 22, 5632 Symantec PCAnywhere pcanywhere 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    POP3 TCP/UDP 110 Post Office Protocol pop3 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Table3 TCP and UDP Static Port Protocols (continued)

    Protocol TypeWell-KnownPort Number Description Syntax

    Cisco IOSRelease1

  • 8/10/2019 Network-Based Application Recognition.pdf

    16/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    16

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Printer TCP/UDP 515 Printer printer 12.1(2)E

    12.1(5)T

    RIP UDP 520 Routing Information

    Protocol

    rip 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    RSVP UDP 1698, 1699 Resource Reservation

    Protocol

    rsvp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SFTP TCP 990 Secure FTP secure-ftp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SHTTP TCP 443 Secure HTTP secure-http 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SIMAP TCP/UDP 585, 993 Secure IMAP secure-imap 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SIRC TCP/UDP 994 Secure IRC secure-irc 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SLDAP TCP/UDP 636 Secure LDAP secure-ldap 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SMTP TCP 25 Simple Mail Transfer

    Protocol

    smtp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SNMP TCP/UDP 161, 162 Simple Network

    Management Protocol

    snmp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SNNTP TCP/UDP 563 Secure NNTP secure-nntp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SOCKS TCP 1080 Firewall security

    protocol

    socks 12.0(5)XE2

    12.1(1)E12.1(5)T

    SPOP3 TCP/UDP 995 Secure POP3 secure-pop3 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SSH TCP 22 Secured Shell ssh 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Table3 TCP and UDP Static Port Protocols (continued)

    Protocol TypeWell-KnownPort Number Description Syntax

    Cisco IOSRelease1

  • 8/10/2019 Network-Based Application Recognition.pdf

    17/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    17

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    STELNET TCP 992 Secure Telnet secure-telnet 12.0(5)XE2

    12.1(1)E12.1(5)T

    Syslog UDP 514 System Logging Utility syslog 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Telnet TCP 23 Telnet Protocol telnet 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    X Windows TCP 6000-6003 X11, X Windows xwindows 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    1. Indicates the Cisco IOS maintenance release that first supported the protocol. This table is updated when a protocol is addedto a new Cisco IOS release train.

    2. In Release 12.3(4)T, the NBAR Extended Inspection for HTTP Traffic feature was introduced. This feature allows NBAR to

    scan TCP ports that are not well-known and identify HTTP traffic traversing these ports.

    Table4 TCP and UDP Stateful Protocols

    Protocol Type Description SyntaxCisco IOSRelease1

    Citrix ICA TCP/

    UDP

    Citrix ICA traffic by application name citrix

    citrix app

    12.1(2)E

    12.1(5)T

    FTP TCP File Transfer Protocol ftp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    Exchange TCP MS-RPC for Exchange exchange 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    FastTrack FastTrack

    For a list of common FastTrack applications,

    see the Classification of Peer-to-Peer

    File-Sharing Applications section of this

    document.

    fasttrack 12.1(12c)E

    Gnutella TCP Gnutella

    For a list of common Gnutella applications, see

    the Classification of Peer-to-Peer File-Sharing

    Applications section of this document.

    gnutella 12.1(12c)E

    Table3 TCP and UDP Static Port Protocols (continued)

    Protocol TypeWell-KnownPort Number Description Syntax

    Cisco IOSRelease1

  • 8/10/2019 Network-Based Application Recognition.pdf

    18/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    18

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    HTTP TCP HTTP with URL, MIME, or host classification http 12.0(5)XE2

    12.1(1)E12.1(5)T

    (HTTP host

    classification

    is not available

    onthe12.0 XE

    release train)

    Napster TCP Napster traffic napster 12.1(5)T

    Netshow TCP/

    UDP

    Microsoft Netshow netshow 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    r-commands TCP rsh, rlogin, rexec rcmd 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    RealAudio TCP/

    UDP

    RealAudio Streaming Protocol realaudio 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    RTP TCP/

    UDP

    Real-Time Transport Protocol Payload

    Classification

    rtp 12.2(8)T

    SQL*NET TCP/

    UDP

    SQL*NET for Oracle sqlnet 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    StreamWorks UDP Xing Technology Stream Works audio and

    video

    streamwork 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    SunRPC TCP/

    UDP

    Sun Remote Procedure Call sunrpc 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    TFTP UDP Trivial File Transfer Protocol tftp 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    VDOLive TCP/

    UDP

    VDOLive Streaming Video vdolive 12.0(5)XE2

    12.1(1)E

    12.1(5)T

    1. Indicates the Cisco IOS maintenance release that first supported the protocol. This table is updated when a protocol is added to a

    new Cisco IOS release train.

    Table4 TCP and UDP Stateful Protocols (continued)

    Protocol Type Description SyntaxCisco IOSRelease1

  • 8/10/2019 Network-Based Application Recognition.pdf

    19/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Feature Overview

    19

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Restrictions

    The NBAR feature does not support the following:

    More than 24 concurrent URLs, hosts, or MIME type matches

    Matching beyond the first 400 bytes in a packet payload in Cisco IOS Releases before Cisco IOS

    Release 12.3(7)T. In Cisco IOS Release 12.3(7)T, this restriction was removed and NBAR now

    support full payload inspection. The only exception is that NBAR can only inspect custom protocol

    traffic for 255 bytes into the payload.

    Non-IP traffic

    MPLS-labelled packets. NBAR only classifies IP packets. You can, however, use NBAR to classify

    IP traffic before the traffic is handed over to MPLS. Use the Modular QoS CLI (MQC ) to set the

    IP DSCP field on the NBAR-classified packets and make MPLS map the DSCP setting to the MPLS

    EXP setting inside the MPLS header.

    Multicast and other non-CEF switching modes

    Fragmented packets

    Pipelined persistent HTTP requests

    URL/host/MIME classification with secure HTTP

    Asymmetric flows with stateful protocols

    Packets originating from or destined to the router running NBAR

    NBAR is not supported on the following logical interfaces:

    Fast EtherChannel

    Interfaces where tunneling or encryption is used

    NBAR was not supported on Dialer interfaces until Cisco IOS Release 12.2(4)T

    Note NBAR cannot be used to classify output traffic on a WAN link where tunneling orencryption is used. Therefore, NBAR should be configured on other interfaces on the

    router (such as a LAN link) to perform input classification before the traffic is switched to

    the WAN link for output.

    However, NBAR Protocol Discovery is supported on interfaces where tunneling or

    encryption is used. You can enable Protocol Discovery directly on the tunnel or on the

    interface where encryption is performed to gather key statistics on the various applications

    that are traversing the interface. The input statistics also show the total number of

    encrypted/tunneled packets received in addition to the per-protocol breakdowns.

    In order to run Distributed NBAR on a Cisco 7500 series router, you must be using a processor that has

    64 MB of DRAM or more. At the time of this publication, the following processors met this

    requirement:

    VIP2-50, VIP4-50, VIP4-80, and VIP6-80

    GEIP and GEIP+

    SRPIP

  • 8/10/2019 Network-Based Application Recognition.pdf

    20/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Supported Platforms

    20

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Memory Management

    NBAR uses approximately 150 bytes of DRAM for each flow that requires stateful inspection. (See

    Table 4for a list of stateful protocols supported by NBAR that require stateful inspection.) When

    NBAR is configured, it allocates 1 MB of DRAM to support up to 5000 concurrent flows. NBAR checks

    to see if it needs more memory to handle additional concurrent stateful flows. If such a need is detected,NBAR expands its memory usage in increments of 200 Kb to 400 Kb.

    Related Features and Technologies

    Access control lists (ACLs)

    Traffic Policing

    Traffic Shaping

    Class-Based Weighted Fair Queueing (CBWFQ)

    Class-Based Marking

    Low Latency Queueing

    Modular Quality of Service Command-Line Interface (Modular QoS CLI)

    Related Documents

    NBAR animation

    Quality of Service (QoS) Networking

    Quality of Service Solutions Configuration Guide

    Quality of Service Solutions Command Reference

    Access Control Lists: Overview and Guidelines

    Network-Based Application Recognition Management Information Base document

    Supported PlatformsTo view the platforms that support NBAR and when NBAR support was introduced, check Feature

    Navigator.

    Determining PlatformSupport Through Feature Navigator

    Cisco IOS software is packaged in feature sets that support specific platforms. To get updated

    information regarding platform support for this feature, access Feature Navigator. Feature Navigatordynamically updates the list of supported platforms as new platform support is added for the feature.

    Feature Navigator is a web-based tool that enables you to quickly determine which Cisco IOS software

    images support a specific set of features and which features are supported in a specific Cisco IOS image.

    To access Feature Navigator, you must have an account on Cisco.com. If you have forgotten or lost your

    account information, send a blank e-mail to [email protected]. An automatic check will verify

    that your e-mail address is registered with Cisco.com. If the check is successful, account details with a

    new random password will be e-mailed to you. Qualified users can establish an account on Cisco.com

    by following the directions at http://www.cisco.com/register.

    http://www.cisco.com/registerhttp://www.cisco.com/registerhttp://www.cisco.com/registerhttp://www.cisco.com/registerhttp://www.cisco.com/registerhttp://www.cisco.com/registerhttp://www.cisco.com/register
  • 8/10/2019 Network-Based Application Recognition.pdf

    21/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Supported Standards, MIBs, and RFCs

    21

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Feature Navigator is updated regularly when major Cisco IOS software releases and technology

    releases occur. For the most current information, go to the Feature Navigator home page at the following

    URL:

    http://www.cisco.com/go/fn

    Supported Standards, MIBs, and RFCs

    Standards

    0009, File Transfer Protocol (FTP)

    0013,Domain Names - Concepts and Facilities

    0033, The TFTP Protocol (Revision 2)

    0034,Routing Information Protocol

    0053, Post Office Protocol - Version 3

    0056,RIP Version 2

    MIBs

    The CISCO-NBAR-PROTOCOL-DISCOVERY MIB is a MIB that utilizes Cisco NBAR Protocol

    Discovery in SNMP. For information on the CISCO-NBAR-PROTOCOL-DISCOVERY MIB, see the

    Network-Based Application Recognition Management Information Base document.

    To obtain lists of supported MIBs by platform and Cisco IOS Release, and to download MIB modules,

    go to the Cisco MIB web site on cisco.com at the following URL:

    http://www.cisco.com/public/sw-center/netmgmt/cmtk/mibs.shtml.

    RFCs

    RFC 742,NAME/FINGER Protocol

    RFC 759,Internet Message Protocol

    RFC 792,Internet Control Message Protocol

    RFC 793, Transmission Control Protocol

    RFC 821,Simple Mail Transfer Protocol

    RFC 827,Exterior Gateway Protocol

    RFC 854, Telnet Protocol Specification

    RFC 888, STUB Exterior Gateway Protocol

    RFC 904, Exterior Gateway Protocol formal specification.

    RFC 951,Bootstrap Protocol

    RFC 959, File Transfer Protocol

    RFC 977,Network News Transfer Protocol

    RFC 1001, Protocol Standard for a NetBIOS Service on a TCP/UDP Transport: Concepts and

    Methods

    RFC 1002, Protocol Standard for a NetBIOS Service on a TCP/UDP Transport: Detailed

    Specifications

    http://www.cisco.com/go/fnhttp://www.cisco.com/go/fn
  • 8/10/2019 Network-Based Application Recognition.pdf

    22/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Supported Standards, MIBs, and RFCs

    22

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    RFC 1057,RPC: Remote Procedure Call

    RFC 1094,NFS: Network File System Protocol Specification

    RFC 1112,Host Extensions for IP multicasting

    RFC 1157,Simple Network Management Protocol

    RFC 1282,BSD Rlogin

    RFC 1288,The Finger User Information Protocol

    RFC 1305,Network Time Protocol

    RFC 1350, The TFTP Protocol (Revision 2)

    RFC 1436, The Internet Gopher Protocol

    RFC 1459,Internet Relay Chat Protocol

    RFC 1510, The Kerberos Network Authentication Service

    RFC 1542, Clarifications and Extensions for the Bootstrap Protocol

    RFC 1579, Firewall-Friendly FTP

    RFC 1583,OSPF Version 2

    RFC 1657,Definitions of Managed Objects for the Fourth Version of the Border Gateway Protocol

    RFC 1701,Generic Routing Encapsulation

    RFC 1730,Internet Message Access Protocol - Version 4

    RFC 1771,A Border Gateway Protocol 4 (BGP-4)

    RFC 1777,Lightweight Directory Access Protocol

    RFC 1831,RPC: Remote Procedure Call Protocol Specification Version 2

    RFC 1889,A Transport Protocol for Real-Time Applications

    RFC 1890,RTP Profile for Audio and Video Conferences with Minimal Control

    RFC 1928, SOCKS Protocol Version 5

    RFC 1939, Post Office Protocol - Version 3

    RFC 1945,Hypertext Transfer Protocol -- HTTP/1.0.

    RFC 1964, The Kerberos Version 5 GSS-API Mechanism

    RFC 2060,Internet Message Access Protocol - Version 4rev1

    RFC 2068,Hypertext Transfer Protocol -- HTTP/1.1

    RFC 2131,Dynamic Host Configuration Protocol

    RFC 2205,Resource ReSerVation Protocol (RSVP) -- Version 1 Functional Specification

    RFC 2236, Internet Group Management Protocol, Version 2

    RFC 2251,Lightweight Directory Access Protocol (v3)

    RFC 2252,Lightweight Directory Access Protocol (v3): Attribute Syntax Definitions

    RFC 2253,Lightweight Directory Access Protocol (v3): UTF-8 String Representation of

    Distinguished Names

    RFC 2326,Real Time Streaming Protocol (RTSP)

    RFC 2401,Security Architecture for the Internet Protocol

    RFC 2406,IP Encapsulating Security Payload

  • 8/10/2019 Network-Based Application Recognition.pdf

    23/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Prerequisites

    23

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    RFC 2453,RIP Version 2

    RFC 2616,Hypertext Transfer Protocol -- HTTP/1.1

    PrerequisitesCEF

    You must enable Cisco Express Forwarding (CEF) before you configure NBAR. For more information

    on CEF, refer to the Cisco IOS Release 12.2 Cisco IOS Switching Services Configuration Guide.

    Configuration TasksThe NBAR feature has two components: one component monitors applications traversing a network,

    and the other that classifies traffic by protocol.

    In order to monitor applications traversing a network, Protocol Discovery needs to be enabled.

    The ability to classify traffic by protocol using NBAR and then applying QoS to the classified traffic is

    configured using the Modular QoS CLI.

    The Modular QoS CLI is a CLI structure that allows users to create traffic policies and attach these

    policies to interfaces. A traffic policy contains a traffic class and one or more QoS features. A traffic

    class is used to classify traffic, while the QoS features in the traffic policy determine how to treat the

    classified traffic.

    Modular QoS CLI configuration includes the following three steps:

    Step 1 Define a traffic class with the class-mapcommand.

    Step 2 Create a traffic policy by associating the traffic class with one or more QoS features (using the

    policy-mapcommand).Step 3 Attach the traffic policy to the interface with the service-policycommand.

    NBAR traffic classification occurs as part of the traffic class configuration.

    For additional information on the Modular Quality of Service Command-Line Interface, see the

    Configuring the Modular Quality of Service Command-Line Interface section of the Cisco IOS

    Quality of Service Solution Guideon Cisco.com.

    See the following sections for configuration tasks for the NBAR feature. Each task in the list is

    identified as either optional or required:

    Enabling Protocol Discovery(optional)

    Configuring a Traffic Class(required)

    Configuring a Traffic Policy(required)

    Attaching a Traffic Policy to an Interface(required)

    Downloading PDLMs(optional)

  • 8/10/2019 Network-Based Application Recognition.pdf

    24/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Configuration Tasks

    24

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Enabling Protocol Discovery

    Use the ip nbar protocol-discoverycommand in order to enable monitoring of applications on a

    particular interface:

    Configuring a Traffic Class

    Use the class-mapconfiguration command to define a traffic class and the match criteria that will be

    used to classify network traffic when attached to an interface. When using NBAR to classify traffic, the

    match protocolcommand will be entered in class map configuration mode.

    Command Purpose

    Router(config)# interfaceinterface-name Specifies the interface to configure.

    Router(config-if)# ip nbar protocol-discovery Enables monitoring by application on a particular

    interface.

    Command Purpose

    Router(config)# class-map

    [match-all |match-any]class-nameSpecifies the user-defined name of the traffic class. The match-all

    option specifies that all match criteria in the class map must be

    matched. The match-anyoption specifies that one or more match

    criteria must match.

    Router(config-cmap)#match protocol

    protocol-name

    Specifies a protocol supported by NBAR as a matching criterion.

  • 8/10/2019 Network-Based Application Recognition.pdf

    25/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Configuration Tasks

    25

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Configuring a Traffic Policy

    Use the policy-map configuration command to specify the QoS policies, such as Traffic Policing,

    Traffic Shaping, Low Latency Queueing, Class-Based Marking, Class-Based Weighted Fair Queueing

    or others, to apply to traffic classes defined by a traffic class. A traffic policy does not classify and

    forward traffic until being attached to an interface.

    For additional information on policy map options in the Modular Quality of Service Command-Line

    Interface, see theModular Quality of Service Command-Line Interface document on Cisco.com.

    Attaching a Traffic Policy to an Interface

    A traffic policy is not active until it has been attached to an interface. Use the service-policy interface

    configuration command to attach a traffic policy to an interface and to specify the direction in which

    the policy should be applied (on either packets coming into the interface or packets leaving the

    interface).

    .

    Use the no service-policy [input | output]policy-map-name command to detach a policy map from an

    interface.

    Command Purpose

    Router(config)#policy-mappolicy-name User-specified policy map name.

    Router(config-pmap)# classclass-name Specifies the name of a previously defined class map.

    Router(config-pmap-c)# Enter QoS policies in this configuration mode (policy map class).

    Command Purpose

    Router(config)# interfaceinterface-name Specifies the interface to configure.

    Router(config-if)# service-policy outputpolicy-map-name Attaches the previously configured traffic policy in the

    outbound direction of the interface. When thiscommand is entered, all traffic leaving the interface

    will be classified and forwarded based on the traffic

    policy configuration.

    Router(config-if)# service-policy inputpolicy-map-name Attaches the previously configured traffic policy in the

    input direction of the interface. When this command is

    entered, all traffic entering the interface will be

    classified and forwarded based on the traffic policy

    configuration.

  • 8/10/2019 Network-Based Application Recognition.pdf

    26/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Configuration Tasks

    26

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Downloading PDLMs

    To extend or enhance the list of protocols recognized by NBAR through a Cisco-provided PDLM, use

    the ip nbar pdlmcommand after downloading the PDLM.

    Note To view a list of currently available PDLMs or to download a PDLM, go to the following

    URL:

    http://www.cisco.com/cgi-bin/tablebuild.pl/pdlm

    Verifying the Configuration

    Use the show policy-map [interface [interface-spec [input | output[class class-name]]]] command to

    display the configuration of a policy map and its associated class maps. Forms of this command are

    listed in the table below.

    Troubleshooting Tips

    You must enable Cisco Express Forwarding (CEF) on the router prior to configuring the NBAR

    feature.

    Some error messages use the term heuristic to refer to a set of NBAR-supported protocols, and

    some error message documentation recommends actions to these heuristic protocols.

    Command Purpose

    Router(config)# ip nbar pdlmpdlm-name Specifies the PDLM used to extend or enhance the

    NBAR list of protocols.

    Command Purpose

    Router# show class-map Displays all traffic class information.

    Router# show class-mapclass-name Displays the traffic class information of the

    user-specified traffic class.

    Router# show policy-map Displays all configured traffic policies.

    Router# show policy-mappolicy-map-name Displays the user-specified traffic policies.

    Router# show policy-map interface Displays configurations and statistics of all input and

    output policies, which are attached to an interface.

    Router# show policy-mapinterface-spec Displays configuration and statistics of the input and

    output policies attached to a particular interface.

    Router#show policy-mapinterface-spec [input] Displays configuration and statistics of the input

    policy attached to an interface.

    Router# show policy-mapinterface-spec [output] Displays configuration and statistics of the output

    policy attached to an interface.

    Router# show policy-map interface-spec [input | output]

    classclass-nameDisplays configuration and statistics for the class name

    configured in the policy.

  • 8/10/2019 Network-Based Application Recognition.pdf

    27/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Monitoring and Maintaining NBAR

    27

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    RTP is the only currently available heuristic protocol. If the error message or the error message

    documentation recommends an action to a heuristic protocol, take the recommended action on RTP

    Monitoring and Maintaining NBARNBAR can determine which protocols and applications are currently running on a network. NBAR

    includes the Protocol Discovery feature that provides an easy way of discovering application protocols

    operating on an interface so that appropriate QoS policies can be developed and applied. With Protocol

    Discovery, you can discover any protocol traffic supported by NBAR and obtain statistics associated

    with that protocol. To monitor and maintain the NBAR feature, use the following commands:

    Configuration ExamplesThis section provides the following configuration examples:

    Configuring a Traffic Policy with NBAR

    Adding a PDLM

    Configuring a Traffic Policy with NBAR

    In the following example, all SQL*Net traffic leaving fastethernet interface 0/1 is marked with the IP

    precedence value of 4. In the example, NBAR is used to identify SQL*Net traffic, while the treatment

    of SQL*Net traffic (in this case, it is forwarded with the IP precedence bit set as 4) is determined by

    the traffic policy configuration (the set ip precedence 4command in policy-map class configuration

    mode).

    Router(config)# class-map sqlnettraffic

    Router(config-cmap)#match protocol sqlnet

    Router(config)#policy-map sqlsetipprec1

    Router(config-pmap)# class sqlnettraffic

    Router(config-pmap-c)# set ip precedence 4

    Router(config)# interface fastethernet 0/1

    Router(config-if)# service-policy output sqlsetipprec1

    Adding a PDLM

    In the following example, the FastTrack PDLM, which has already been downloaded to the Flash drive,

    is added as an NBAR-supported protocol:

    Router(config)# ip nbar pdlm flash://fasttrack.pdlm

    Command Purpose

    Router# show ip nbar port-map [protocol-name] Displays the TCP/UDP port numbers used by

    NBAR to classify a given protocol.

    Router# show ip nbar protocol-discovery Displays the statistics for all interfaces on which

    Protocol Discovery is enabled.

  • 8/10/2019 Network-Based Application Recognition.pdf

    28/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    Command Reference

    28

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Command ReferenceThis section documents new and enhanced commands. All other commands used with this feature are

    documented in the Cisco IOS Release 12.2 command reference publications.

    ip nbar custom

    ip nbar pdlm

    ip nbar port-map

    ip nbar protocol-discovery

    match protocol

    match protocol citrix

    match protocol fasttrack

    match protocol gnutella

    match protocol http

    match protocol rtp

    show ip nbar pdlm

    show ip nbar port-map

    show ip nbar protocol-discovery

    show ip nbar version

    Note In this section, match protocol citrix, match protocol fasttrack, match protocol

    gnutella, match protocol http, and match protocol rtp are included while other match

    protocolprotocol-namecommands are not because these commands require more

    information than the other match protocolprotocol-namecommands for NBAR.

  • 8/10/2019 Network-Based Application Recognition.pdf

    29/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar custom

    29

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    ip nbar customTo extend the capability of NBAR Protocol Discovery to classify and monitor additional static port

    applications or to allow NBAR to classify non-supported static port traffic, use theip nbar custom

    global configuration command.

    ip nbar customname [offset format value] [source|destination] [tcp | udp] [rangestart end|

    port-number]

    no ip nbar custom name [offset format value] [source|destination] [tcp | udp] [range start end|

    port-number]

    Syntax Description

    Defaults If source or destination is not specified, traffic flowing in both directions is inspected if the customprotocol is enabled in NBAR.

    name The name given to the custom protocol. This name would be reflected

    wherever the name was used, including NBAR Protocol Discovery,

    match protocol, ip nbar port-map, and the NBAR Protocol Discovery

    MIB.

    The name must be no longer than 24 characters and can only containuppercase and lowercase letters, digits, and the _(underscore)

    character.

    offset A digit representing the byte location for payload inspection. The offset

    is based off the beginning of the payload directly after the TCP or UDP

    header.

    format Defines the format of the value that is being inspected in the packet

    payload. Current options are ascii, hex, and decimal.

    value The value being searched in the packet inspection. The length of the

    value is dependant on the chosenformat. The length restrictions for each

    format are listed below:

    asciiUp to 16 characters can be searched. Regular expressions are

    not supported.

    hexUp to 4 bytes.

    decimalup to 4 bytes.

    source| destination Specifies the direction in which packets are inspected. If source or

    destination is not specified, all packets travelling in either direction are

    monitored by NBAR.

    tcp| udp Specifies the TCP or UDP protocol implemented by the application.

    range start end Specifies a range of ports that the custom application monitors. The start

    is the first port in the range and the end is the last port in the range. One

    range of up to 1000 ports can be specified for each custom protocol.

    port-number The port that the custom application monitors. Up to 16 individual ports

    can be specified as a single custom protocol.

  • 8/10/2019 Network-Based Application Recognition.pdf

    30/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar custom

    30

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Command Modes Global configuration

    Command History

    Usage Guidelines More than 30 custom applications can be created on the router.

    NBAR can support up to 128 protocols total.

    If the variablekeyword is entered while configuring the custom protocol, traffic statistics for the

    variable will appear in some NBAR class map showoutputs.

    Up to 24 variable values per custom protocol can be expressed in class maps. For instance, in the

    following configuration, 4 variables are used and 20 more scid values could be used.

    ip nbar custom ftdd field scid 125 variable 1 tcp range 5001 5005

    class-map active-craft

    match protocol ftdd scid 0x15

    match protocol ftdd scid 0x21

    class-map passive-craft

    match protocol ftdd scid 0x11

    match protocol ftdd scid 0x22

    Examples In the following example, the custom protocol app_sales1 will identify TCP packets with a source portof 4567 and contain the term SALES in the fifth byte of the payload:

    ip nbar custom app_sales1 5 ascii SALES source tcp 4567

    In the following example, the custom protocol virus_home will identify UDP packets with a destination

    port of 3000 and contain 0x56 in the seventh byte of the payload:

    ip nbar custom virus_home 7 hex 0x56 dest udp 3000

    In the following example, custom protocol media_new will identify TCP packets with a destination or

    source port of 4500 and that have a value of 90 at the sixth byte of the payload:

    ip nbar custom media_new 6 decimal 90 tcp 4500

    In the following example, custom protocol msn1 will look for TCP packets with a destination or source

    port of 6700:

    ip nbar custom msn1 tcp 6700

    In the following example, custom protocol mail_x will look for UDP packets with a destination port of8202:

    ip nbar custom mail_x destination udp 8202

    In the following example, custom protocol mail_y will look for UDP packets with destination ports

    between 3000 and 4000 including 3000 and 4000 as well as port 5500:

    ip nbar custom mail_y destination udp range 3000 4000 5500

    Release Modification

    12.3(4)T This command was introduced.

  • 8/10/2019 Network-Based Application Recognition.pdf

    31/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar pdlm

    31

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    ip nbar pdlmTo extend or enhance the list of protocols recognized by NBAR through a Cisco-provided Packet

    Description Language Module (PDLM), use the ip nbar pdlm global configuration command. Use the

    noform of this command to unload a PDLM if it was previously loaded.

    ip nbar pdlmpdlm-name

    no ip nbar pdlmpdlm-name

    Syntax Description

    Defaults No default behavior or values.

    Command Modes Global configuration

    Command History

    Usage Guidelines This command is used in global configuration mode to extend the list of protocols recognized by a givenversion of NBAR or to enhance an existing protocol-recognition capability. NBAR can be given an

    external PDLM at run time. In most cases, the PDLM enables NBAR to recognize new protocols

    without requiring a new Cisco IOS image or a router reload. Only Cisco can provide you with a new

    PDLM.

    To view a list of currently available PDLMs or to download a PDLM, go to the following URL:

    http://www.cisco.com/cgi-bin/tablebuild.pl/pdlm

    Examples The following example configures NBAR to load the citrix.pdlm PDLM from Flash memory on therouter:

    ip nbar pdlm flash://citrix.pdlm

    pdlm-name The URL where the PDLM can be found in Flash memory.

    Release Modification

    12.0(5)XE2 This command was introduced.

    12.1(1)E This command was introduced for the Cisco IOS

    Release 12.1 E train.

    12.1(5)T This command was introduced for the Cisco IOS

    Release 12.1 T train.

    12.1(13)E This command became available on Catalyst 6000

    family switches without FlexWAN modules.

    12.2(14)S This command was introduced for the Cisco IOS

    Release 12.2 S train.

  • 8/10/2019 Network-Based Application Recognition.pdf

    32/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar pdlm

    32

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Related Commands Command Description

    show ip nbar pdlmpdlm-name Displays the current PDLM in use by NBAR.

  • 8/10/2019 Network-Based Application Recognition.pdf

    33/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar port-map

    33

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    ip nbar port-mapTo configure NBAR to search for a protocol or protocol name using a port number other than the

    well-known port, use the ip nbar port-map global configuration command. Use the noform of this

    command to look for the protocol name using only the well-known port number.

    ip nbar port-mapprotocol-name [tcp | udp]port-number

    no ip nbar port-mapprotocol-name [tcp | udp]port-number

    Syntax Description

    Defaults No default behavior or values.

    Command Modes Global configuration

    Command History

    Usage Guidelines This command is used in global configuration mode to tell NBAR to look for the protocolprotocol-name, using a port number or numbers other than the well-known (IANA-assigned)

    port number. For example, use this command to configure NBAR to look for Telnet on a port other than

    23. From 1 to 16 ports can be specified with this command. Port number values can range from 0 to

    65535.

    protocol-name Name of protocol known to NBAR.

    tcp Specifies that a TCP port will be searched for the specified

    protocol-name.

    udp Specifies that a UDP port will be searched for the specified

    protocol-name.

    port-number Assigned port for named protocol. Theport-numberis either a UDP or

    a TCP port number, depending on which protocol is specified in thiscommand line. Up to 16port-numbers can be specified in one command

    line.

    Release Modification12.0(5)XE2 This command was introduced.

    12.1(1)E This command was introduced for the Cisco IOS

    Release 12.1 E train.

    12.1(5)T This command was introduced for the Cisco IOS

    Release 12.1 T train.

    12.1(13)E This command became available on Catalyst 6000

    family switches without FlexWAN modules.

    12.2(14)S This command was introduced for the Cisco IOS

    Release 12.2 S train.

  • 8/10/2019 Network-Based Application Recognition.pdf

    34/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar port-map

    34

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    Examples The following example configures NBAR to look for the protocol SQL*NET on port numbers 63000and 63001 instead of on the well-known port number:

    ip nbar port-map sqlnet tcp 63000 63001

    Related Commands Command Description

    show ip nbar port-map Displays the current protocol-to-port mappings in use by NBAR.

  • 8/10/2019 Network-Based Application Recognition.pdf

    35/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    ip nbar protocol-discovery

    35

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    ip nbar protocol-discoveryTo configure NBAR to discover traffic for all protocols known to NBAR on a particular interface, use

    the ip nbar protocol-discovery interface configuration command. Use the no form of this command to

    disable traffic discovery.

    ip nbar protocol-discovery

    no ip nbar protocol-discovery

    Syntax Description None

    Defaults No default behavior or values.

    Command Modes Interface configuration

    Command History

    Usage Guidelines Use theip nbar protocol-discoverycommand to configure NBAR to keep traffic statistics for allprotocols known to NBAR. Protocol Discovery provides an easy way to discover application protocols

    traversing an interface so that QoS policies can be developed and applied. The Protocol Discovery

    feature discovers any protocol traffic supported by NBAR. Protocol Discovery can be used to monitor

    both input and output traffic and may be applied with or without a service policy enabled.

    Examples The following example configures Protocol Discovery on an Ethernet interface:interface ethernet 1/3

    ip nbar protocol-discovery

    Related Commands

    Release Modification

    12.0(5)XE2 This command was introduced.

    12.1(1)E This command was introduced for the Cisco IOS

    Release 12.1 E train.

    12.1(5)T This command was introduced for the Cisco IOS

    Release 12.1 T train.

    12.1(13)E This command became available on Catalyst 6000

    family switches without FlexWAN modules.

    12.2(14)S This command was introduced for the Cisco IOS

    Release 12.2 S train.

    Command Description

    show ip nbar protocol-discovery Displays the statistics gathered by the NBAR Protocol

    Discovery feature.

  • 8/10/2019 Network-Based Application Recognition.pdf

    36/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    match protocol

    36

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    match protocolTo match traffic by a particular protocol, use the match protocol class map configuration mode

    command. Use the noform of this command to turn off traffic matching by protocol type.

    match protocolprotocol-name [variable-field-name value]

    no match protocolprotocol-name [variable-field-name value]

    Syntax Description

    Defaults No default behavior or values.

    Command Modes Class map configuration

    Command History

    Usage Guidelines This command can be used to match protocols that are known to NBAR. See the tables in theSupported Protocols section on page 13for a list of protocols currently supported by NBAR.

    The variable-field-name value is used in conjunction with the variablefield-name field-length options

    that are entered when you create a custom protocol using the ip nbar custom command. The variable

    option allows NBAR to match based on a specific value of a custom protocol. For instance, ifip nbar

    protocol-name (Required) Identifies a particular protocol as a matching criterion.

    variable-field-name (Optional and only usable with custom protocols) Used for specifying

    a pre-defined variable that was created when you created a custom

    protocol. The variable-field-name will match thefield-name variable

    entered when you created the custom protocol.

    value (Optional and only usable with custom protocols) A specific value in

    the custom payload to match. A value can only be entered along with

    a variable-field-name. The value can be expressed in decimal orhexadecimal format.

    Release Modification

    12.0(5)XE2 This command was introduced.

    12.1(1)E This command was introduced for the Cisco IOS

    Release 12.1 E train. The variable-field-name value

    option was introduced.

    12.1(5)T This command was introduced for the Cisco IOS

    Release 12.1 T train.

    12.1(13)E This command became available on Catalyst 6000

    family switches without FlexWAN modules.

    12.2(14)S This command was introduced for the Cisco IOS

    Release 12.2 S train.

  • 8/10/2019 Network-Based Application Recognition.pdf

    37/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    match protocol

    37

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    custom ftdd 125 variable scid 2 tcp range 5001 5005 is entered to create a custom protocol, and then

    a class map using thematch protocol ftdd scid 804is created, the created class map will match all

    traffic entering or leaving TCP ports 5001-5005 that have value 804 at byte 125.

    Up to 24 variable values per custom protocol can be expressed in class maps. For instance, in the

    following configuration, 4 variables are used and 20 more scid values could be used.

    ip nbar custom ftdd field scid 125 variable 1 tcp range 5001 5005

    class-map active-craft

    match protocol ftdd scid 0x15

    match protocol ftdd scid 0x21

    class-map passive-craft

    match protocol ftdd scid 0x11

    match protocol ftdd scid 0x22

    Examples The following example configures NBAR to match FTP traffic:

    match protocol ftp

    In the following example, custom protocol ftdd is created using a variable. A class map matching this

    custom protocol based on the variable is also created. In this example, class map matchscidinftdd will

    match all traffic entering or leaving TCP ports 5001-5005 that has the value 804 at byte 125. The

    variable scid is 2 bytes in length.

    ip nbar custom ftdd 125 variable scid 2 tcp range 5001 5005

    class-map matchscidinftdd

    match protocol ftdd scid 804

    The same example above can also be done using hexadecimal values in the class map as follows:

    ip nbar custom ftdd 125 variable scid 2 tcp range 5001 5005

    class-map matchscidinftdd

    match protocol ftdd scid 0x324

    In the following example, the variablekeyword is used while creating a custom protocol, and class

    maps are configured to classify different values within the variable field into different traffic classes.

    Specifically, in the example below, variable scid values 0x15, 0x21, and 0x27 will be classified into

    class map active-craft while scid values 0x11, 0x22, and 0x25 will be classified into class map

    passive-craft.

    ip nbar custom ftdd field scid 125 variable 1 tcp range 5001 5005

    class-map active-craft

    match protocol ftdd scid 0x15

    match protocol ftdd scid 0x21

    match protocol ftdd scid 0x27

    class-map passive-craft

    match protocol ftdd scid 0x11

    match protocol ftdd scid 0x22

    match protocol ftdd scid 0x25

  • 8/10/2019 Network-Based Application Recognition.pdf

    38/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    match protocol citrix

    38

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    match protocol citrixTo configure NBAR to match Citrix traffic, use the match protocol citrixclass map configuration

    mode command. Use the noform of this command to disable NBAR from matching Citrix traffic.

    match protocol citrix [app application-name-string]

    no match protocol citrix [app application-name-string]

    Syntax Description

    Defaults No default behavior or values.

    Command Modes Class map configuration

    Command History

    Usage Guidelines Entering the match protocol citrix command without any other keywords establishes all Citrix trafficas successful match criteria.

    Examples The following example configures NBAR to match all Citrix traffic:

    match protocol citrix

    The following example configures NBAR to match Citrix traffic with the application name of packet1:

    match protocol citrix app packet1

    app Specifies matching of an application name string.

    application-name-string Specifies string to be used as the subprotocol parameter.

    Release Modification

    12.1(2)E This command was introduced.

    12.1(5)T This command was introduced for the Cisco IOS Release 12.1 T train.

    12.1(13)E This command became available on Catalyst 6000 family switches

    without FlexWAN modules.

    12.2(14)S This command was introduced for the Cisco IOS Release 12.2 S train.

  • 8/10/2019 Network-Based Application Recognition.pdf

    39/54

    Network-Based Application Recognition and Distributed Network-Based Application Recognition

    match protocol fasttrack

    39

    Releases 12.0XE, 12.1E, 12.1EC, 12.2S, 12.2T, and 12.3T

    match protocol fasttrackTo configure NBAR to match FastTrack peer-to-peer traffic, use the match protocol fasttrackclass

    map configuration mode command. Use the no form of this command to disable NBAR from matching

    FastTrack traffic.

    match protocol fasttrack file-transfer regular-expression

    no match protocol fasttrack file-transfer regular-expression

    Syntax Description

    Defaults No default behavior or values.

    Command Modes Class map configuration

    Command History

    Usage Guidelines To specify that all FastTrack traffic be identified by the traffic class,