KEMBAR78
Cisco Operating ACI PDF | PDF | Bracket | Computer Network
0% found this document useful (0 votes)
632 views298 pages

Cisco Operating ACI PDF

Uploaded by

Prasanna
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
632 views298 pages

Cisco Operating ACI PDF

Uploaded by

Prasanna
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 298

Operating Cisco Application Centric Infrastructure

First Published: 2015-03-24


Last Modified: 2018-10-08

Americas Headquarters
Cisco Systems, Inc.
170 West Tasman Drive
San Jose, CA 95134-1706
USA
http://www.cisco.com
Tel: 408 526-4000
800 553-NETS (6387)
Fax: 408 527-0883
THE SPECIFICATIONS AND INFORMATION REGARDING THE PRODUCTS IN THIS MANUAL ARE SUBJECT TO CHANGE WITHOUT NOTICE. ALL STATEMENTS,
INFORMATION, AND RECOMMENDATIONS IN THIS MANUAL ARE BELIEVED TO BE ACCURATE BUT ARE PRESENTED WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED. USERS MUST TAKE FULL RESPONSIBILITY FOR THEIR APPLICATION OF ANY PRODUCTS.

THE SOFTWARE LICENSE AND LIMITED WARRANTY FOR THE ACCOMPANYING PRODUCT ARE SET FORTH IN THE INFORMATION PACKET THAT SHIPPED WITH
THE PRODUCT AND ARE INCORPORATED HEREIN BY THIS REFERENCE. IF YOU ARE UNABLE TO LOCATE THE SOFTWARE LICENSE OR LIMITED WARRANTY,
CONTACT YOUR CISCO REPRESENTATIVE FOR A COPY.

The Cisco implementation of TCP header compression is an adaptation of a program developed by the University of California, Berkeley (UCB) as part of UCB's public domain version of
the UNIX operating system. All rights reserved. Copyright © 1981, Regents of the University of California.

NOTWITHSTANDING ANY OTHER WARRANTY HEREIN, ALL DOCUMENT FILES AND SOFTWARE OF THESE SUPPLIERS ARE PROVIDED “AS IS" WITH ALL FAULTS.
CISCO AND THE ABOVE-NAMED SUPPLIERS DISCLAIM ALL WARRANTIES, EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, THOSE OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OR ARISING FROM A COURSE OF DEALING, USAGE, OR TRADE PRACTICE.

IN NO EVENT SHALL CISCO OR ITS SUPPLIERS BE LIABLE FOR ANY INDIRECT, SPECIAL, CONSEQUENTIAL, OR INCIDENTAL DAMAGES, INCLUDING, WITHOUT
LIMITATION, LOST PROFITS OR LOSS OR DAMAGE TO DATA ARISING OUT OF THE USE OR INABILITY TO USE THIS MANUAL, EVEN IF CISCO OR ITS SUPPLIERS
HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

Any Internet Protocol (IP) addresses and phone numbers used in this document are not intended to be actual addresses and phone numbers. Any examples, command display output, network
topology diagrams, and other figures included in the document are shown for illustrative purposes only. Any use of actual IP addresses or phone numbers in illustrative content is unintentional
and coincidental.

All printed copies and duplicate soft copies of this document are considered uncontrolled. See the current online version for the latest version.

Cisco has more than 200 offices worldwide. Addresses and phone numbers are listed on the Cisco website at www.cisco.com/go/offices.

Cisco and the Cisco logo are trademarks or registered trademarks of Cisco and/or its affiliates in the U.S. and other countries. To view a list of Cisco trademarks, go to this URL: www.cisco.com
go trademarks. Third-party trademarks mentioned are the property of their respective owners. The use of the word partner does not imply a partnership relationship between Cisco and any
other company. (1721R)
© 2015–2018 Cisco Systems, Inc. All rights reserved.
CONTENTS

PREFACE Preface xv
Audience xv
Document Conventions xv
Related Documentation xvii
Documentation Feedback xviii
Obtaining Documentation and Submitting a Service Request xviii

CHAPTER 1 Introduction 1
Abstract 1
Introduction 2
What Is New in APIC 1.2(1) 7

CHAPTER 2 Management 13
APIC Overview 13
Configuring Management Protocols 14
Creating a Cisco Discovery Protocol Policy Using the GUI 14
Creating a Link Layer Discovery Protocol Policy Using the GUI 15
Time Synchronization and NTP 16
Configuring Out-of-Band Management NTP Using the GUI 17
Configuring Out-of-Band Management NTP Using the NX-OS-Style CLI 17
In-Band Management NTP 18
Verifying NTP Operation Using the GUI 18
Verifying the NTP Policy Configuration Using the NX-OS-Style CLI 18
Verifying that the NTP Policy is Deployed on Each Fabric Switch Using the NX-OS-Style CLI 19
Verifying that the NTP Policy is Deployed on Each Fabric Switch Using the Object Model CLI 20
Verifying that the NTP Policy is Deployed on Each APIC Using the NX-OS-Style CLI 21

Operating Cisco Application Centric Infrastructure


iii
Contents

Verifying that the NTP Policy is Deployed on Each APIC Using the Object Model CLI 21
Domain Name Services (DNS) 22
Verifying DNS Operation Using the Object Model CLI 22
Viewing Control Plane Policing Using the NX-OS-Style CLI 23
Role-Based Access Control 23
Multiple Tenant Support 24
Viewing the User Roles Using the GUI 24
Security Domains 25
Creating a Security Domain Using the GUI 25
Adding Users Using the GUI 25
Import and Export Policies 26
Configuration Export (Backup) 26
Adding a Remote Location (SCP) Using the GUI 27
Creating a One Time Export Policy Using the GUI 27
Verifing That Exporting a Policy was Successful Using the GUI 28
Extracting and Viewing Configuration Files Using the GUI 28
Importing a Configuration (Restoring/Merging) Using the GUI 28
Rolling Back a Configuration Using the GUI 29

CHAPTER 3 Upgrading and Downgrading Firmware 31

Firmware Management 31
Firmware Versions 31
Firmware Components 32
Firmware Policies 32
Upgrading and Downgrading Considerations 33
Upgrading the Fabric 34
Downloading the Firmware Images Using the GUI 34
Downloading the Firmware Images Using the Object Model CLI 35
Upgrading an APIC Using the GUI 35
Upgrading an APIC Using the NX-OS-Style CLI 36
Upgrading an APIC Using the Object Model CLI 37
Upgrading a Switch Using the GUI 38
Upgrading a Switch Using the NX-OS-Style CLI 39
Upgrading a Switch Using the Object Model CLI 41

Operating Cisco Application Centric Infrastructure


iv
Contents

Verifying Cluster Convergence Using the GUI 41


Troubleshooting Failures During the Upgrade Process 42

CHAPTER 4 Fabric Connectivity 43

Understanding Fabric Policies 43


Fabric - Access Policies 44
Domains 44
VLAN Pools 44
Attachable Access Entity Profiles 44
Policy Types 44
Best Practices 50
Adding New Devices to the Fabric 50
Sample Configuration 52
Creating VLAN Pools 55
Creating a Physical Domain 57
Creating an Attachable Access Entity Profile Using the GUI 57
Creating an Attachable Access Entity Profile Using the REST API 58
Create Interface Policies 59
Create Interface Policy Groups 63
Interface Profile 65
Switch Profiles 69
Reusability 70
Sample vPC Creation 71
Server Connectivity 73
Virtual Machine Networking 74
Understanding VM Networking in ACI 74
ACI VM Integration Workflow 75
VMware Integration 76
VMM Policy Model Interaction 76
Publishing EPGs to a VMM Domain 77
Connecting Virtual Machines to the Endpoint Group Port Groups on vCenter 77
Microsoft SCVMM Integration 77
Verifying Virtual Endpoint Learning 82
VMware Integration Use Case 83

Operating Cisco Application Centric Infrastructure


v
Contents

Deploying the Application Virtual Switch 83


Prerequisites for Deploying the Application Virtual Switch 83
Getting Started 84
Install the AVS VIB 84
Attachable Access Entity Profile (AEP) and AVS 85
Create a New AEP 85
Modify an Existing AEP 86
VMM Domains for vCenter 86
AVS Switching Modes 86
Create the VMM Domain for AVS 87
Verify AVS Deployment on vCenter 88
Adding vSphere Hosts to the AVS 89
Verify AVS on ESX 89
VXLAN Load Balancing 90
IGMP Snooping Policy for AVS 90
Microsegmentation with the Cisco Application Virtual Switch 91
External Connectivity 92
Extending ACI to External Layer 2 92

Extending Endpoint Groups Outside the ACI Fabric 92


Extending an ACI Bridge Domain Outside of the Fabric 93
Extending ACI to External Layer 3 94

Supported Routing Protocols 95


Configure MP-BGP Spine Route Reflectors 95
Layer 3 Integration Through Tenant Network with OSPF NSSA 97
External Layer 3 for Multiple Tenants 99
Application Migration Use Case 99
Extending the Network to ACI 100

CHAPTER 5 Tenants 103


ACI Tenancy Models 103
Application Profile 105
Application Profile Configuration 106
Creating a New Application Profile Using the GUI 106
Modifying an Application Profile Using the GUI 106

Operating Cisco Application Centric Infrastructure


vi
Contents

Removing Application Profile Using the GUI 106


Verify Application Profile 107
Endpoint Group 107
Endpoint Group Subtypes 108
Creating a New Endpoint Group 108
Modify Endpoint Group 109
Remove Endpoint Group 109
Verify Endpoint Group 110
Endpoint 110
Verify Endpoint 110
Private Networks 110
Private Network Configuration Parameters 111
Creating a New Private Network 111
Modifying a Private Network Using the GUI 112
Removing Private Network Using the GUI 112
Verify Private Network 112
Bridge Domain 113
Bridge Domain Configuration Parameters 115
Creating a New Bridge Domain Using the GUI 116
Creating a New Bridge Domain Using the NX-OS-Style CLI 116
Modifying a Bridge Domain Using the GUI 117
Modifying a Bridge Domain Using NX-OS-Style CLI 117
Removing a Bridge Domain Using the GUI 118
Removing a Bridge Domain Using NX-OS-Style CLI 118
Verifying a Bridge Domain Using the Object Model CLI 118
Tenant Networking Use Cases 119
Common Private Network for All Tenants 119
Multiple Private Networks with Intra-Tenant Communication 122
Multiple Private Networks with Inter-Tenant Communication 124
Dual Fabrics with a Common Pervasive Gateway 128

CHAPTER 6 Working with Contracts 135


Contracts 135
Contract Configuration Parameters 137

Operating Cisco Application Centric Infrastructure


vii
Contents

Create/Modify/Remove Regular Contracts 138


Create Contracts 138
Modify Contracts 139
Remove Contracts 140
Verify Contracts 140
Apply/Remove EPG Contracts 140
Apply a Contract to an EPG 140
Remove a Contract from an EPG 140
Verify Contract on an EPG 141
Apply/Remove External Network Contracts 141
Apply a Contract to an External Network 141
Remove a Contract from an External Network 141
Verify External Network Contracts 141
Applying or Removing VRF Contracts 142
Applying a Contract to a VRF (vzAny) Using the GUI 142
Removing a Contract from a VRF (vzAny) Using the GUI 143
Verifying VRF Contracts 143
Filters 143
Filter Entry Configuration Parameters 143
Creating Filters Using the GUI 144
Modifying Filters Using the GUI 145
Removing Filters Using the GUI 145
Configuring Filters Using the NX-OS-Style CLI 146
Removing and Deleting Filters Using the NX-OS-Style CLI 147
Verifying Filters 147
Taboo Contracts 147
Taboo Contract Configuration Parameters 147
Create/Modify/Delete Taboo Contracts 148
Create Taboo Contracts 148
Modify Taboo Contracts 148
Delete Taboo Contracts 149
Verify Taboo Contracts 149
Apply/Remove Taboo Contracts 149
Apply a Taboo Contract to an EPG 149

Operating Cisco Application Centric Infrastructure


viii
Contents

Remove a Taboo Contract from an EPG 149


Verify Taboo Contracts Applied to an EPG 149
Inter-Tenant Contracts 150
Configuration Parameters 150
Create/Modify/Remove Export Contracts 150
Export Contract 150
Modify Exported Contracts 151
Remove Exported Contracts 151
Verify Exported Contracts 151
Ingress-Based ACLs 151

Configuring Ingress-Based ACLs Using the GUI 152


Verifying Ingress-Based ACLs 152
Contracts Use Cases 152
Inter-Tenant Contracts 152
Inter-Private Network Contracts Communication 153
Single Contract Bidirectional Reverse Filter 154
Single Contract Unidirectional with Multiple Filters 155
Multiple Contracts Uni-Directional Single Filter 155

CHAPTER 7 Layer 4 to Layer 7 Service Insertion 157

Understanding Layer 4 to Layer 7 Integration 157


Service Insertion Design Principles 158
Applying service graphs to EPG Communications 158
Rendering Service Graphs 158
Integration Support Function 159
Services Deployment Guide Reference 159
Service Graph Monitoring 161
Monitoring a Service Graph Instance 161
Monitoring and Resolving Service Graph Faults 161
Monitoring a Device Cluster 162
ASAv Sample Configuration 163
Verifying the ASAv Virtual Machine Configuration 163
Removing the Gateway IP Address from the Relevant Fabric Bridge Domains 164
Creating a Layer 4 to Layer 7 Device 164

Operating Cisco Application Centric Infrastructure


ix
Contents

Creating a Layer 4 to Layer 7 Service Graph Template 166


Apply the Service Graph Template 166
Verifying Service Node Configuration 167

CHAPTER 8 Health Scores 169

Understanding Health Scores 169


Understanding Faults 172
How Health Scores Are Calculated 173
Health Score Use Cases 175
Using Health Scores for Proactive Monitoring 175
Using Health Scores for Reactive Monitoring 175

CHAPTER 9 Monitoring 177

Proactive Monitoring - Tenant and Fabric Policies 177


Create Tenant Monitor Policy 178
Stats Collection Policies 178
Stats Export Policies 179
Diagnostics Policies Using the GUI 180
Call Home/SNMP/Syslog 181
Event Severity and Fault Severity Assignments 181
Fault Lifecycle Policies 182
TCAM Policy Usage 182
Create TCAM Policy Monitor 183
TCAM Prefix Usage 183
Health Score Evaluation Policy 183
Communication Policy 184
Monitoring APICs 184
CPU Utilization and Memory 184
Disk Utilization 185
Physical and Bond Interface Statistics 186
Fan Status 186
Temperature Status 187
Power Supply Status 188
Monitoring Switch CPU Utilization 188

Operating Cisco Application Centric Infrastructure


x
Contents

Monitoring Switch Memory Utilization 190


Monitoring File System Health 191
Monitoring CoPP (Control Plane Policing) Statistics 193
Physical Interface Statistics and Link State 194
Module Status 195
Switch Fan Status 196
Switch Power Supply Status 197
LLDP Neighbor Status 198
CDP Neighbor Status 198
GOLD Diagnostic Results 199
Proactive Monitoring Use Cases 200
Monitoring Workload Bandwidth 200
EPG Level Statistics 201
Reactive Monitoring 201
Operations Tab 202

Visibility and Troubleshooting—Enhanced Troubleshooting Wizard 203


Capacity Dashboard 203
Endpoint Tracker 204
Reactive Monitoring Tools 204
Switch Port Analyzer (SPAN) 204
Configuring a SPAN Session 205
Traceroute 206
Performing a Traceroute Between Endpoints 206
Atomic Counters 207
Configuring Atomic Counters 208
Traffic Map 209
Configuring Traffic Map 209
IPing 209
Audit Logs 210
Viewing Audit Logs 210
Reactive Monitoring Use Cases 210
Loss of Connectivity to Endpoint 210
Users Report that an Application Running in the Fabric is Slow 212

Operating Cisco Application Centric Infrastructure


xi
Contents

CHAPTER 10 Scripting 213

Leveraging Network Programmability 213


ACI and Scripting 214
Reference to Object Model 214
Programmatic Interfaces 214
About the REST API 215
API Inspector 218
Development Techniques 219
POSTman 220
Cobra SDK and Arya 222
Establish Session 223
Work with Objects 223
Cisco APIC REST to Python Adapter 224
ACI Toolkit 226
ACI Toolkit Applications 226
Endpoint Tracker 226
ACI Lint 228
ACI Cable Plan Module 229
ACI CLI Emulator Module 229

ACI Multisite Application 229

ACI Configuration Snapshot and Rollback 229

ACI EventsFeeds: ACI Events to Atom Feed 230

GitHub 230

CHAPTER 11 Hardware Expansion and Replacement 233

Expanding and Shrinking the Fabric 233


Switches 233
Add a Connected Switch 233
Pre-Provision Switch Before Connection 234
Decommission Existing Switch 235
Cisco Nexus 9300 Platform Switches to Cisco Nexus 9300-EX Platform Switches Migration 235
Cisco APICs 236
Add New APIC 236

Operating Cisco Application Centric Infrastructure


xii
Contents

Decommission an Existing Cisco APIC 237


Hardware Diagnostics and Replacement 238
Identify Hardware Failure 238
Resolve Leaf Hardware Failure 239
Resolve APIC Hardware Failure 241
Diagnose Equipment Failures 242
Guidelines When Replacing a Leaf Switch That is Part of a vPC Pair 243

APPENDIX A Appendix 245


Classes 245
Fabric Monitoring 245
VM_Monitoring 248
Layer 4 to Layer 7 Monitoring 249
Statistics 251
Authentication, Authorization, and Accounting 251
Fabric Capacity 252
SNMP and Syslog 252
Use Cases 253
Package Decoder 256
Acronyms and Definitions 261
Reference Material 278

Operating Cisco Application Centric Infrastructure


xiii
Contents

Operating Cisco Application Centric Infrastructure


xiv
Preface
• Audience, on page xv
• Document Conventions, on page xv
• Related Documentation, on page xvii
• Documentation Feedback, on page xviii
• Obtaining Documentation and Submitting a Service Request, on page xviii

Audience
This guide is intended primarily for data center administrators with responsibilities and expertise in one or
more of the following:
• Virtual machine installation and administration
• Server administration
• Switch and network administration
• Cloud administration

Document Conventions
Command descriptions use the following conventions:

Convention Description
bold Bold text indicates the commands and keywords that you enter literally
as shown.

Italic Italic text indicates arguments for which the user supplies the values.

[x] Square brackets enclose an optional element (keyword or argument).

[x | y] Square brackets enclosing keywords or arguments separated by a vertical


bar indicate an optional choice.

{x | y} Braces enclosing keywords or arguments separated by a vertical bar


indicate a required choice.

Operating Cisco Application Centric Infrastructure


xv
Preface
Preface

Convention Description
[x {y | z}] Nested set of square brackets or braces indicate optional or required
choices within optional or required elements. Braces and a vertical bar
within square brackets indicate a required choice within an optional
element.

variable Indicates a variable for which you supply values, in context where italics
cannot be used.

string A nonquoted set of characters. Do not use quotation marks around the
string or the string will include the quotation marks.

Examples use the following conventions:

Convention Description
screen font Terminal sessions and information the switch displays are in screen font.

boldface screen font Information you must enter is in boldface screen font.

italic screen font Arguments for which you supply values are in italic screen font.

<> Nonprinting characters, such as passwords, are in angle brackets.

[] Default responses to system prompts are in square brackets.

!, # An exclamation point (!) or a pound sign (#) at the beginning of a line


of code indicates a comment line.

This document uses the following conventions:

Note Means reader take note. Notes contain helpful suggestions or references to material not covered in the manual.

Caution Means reader be careful. In this situation, you might do something that could result in equipment damage or
loss of data.

Warning IMPORTANT SAFETY INSTRUCTIONS


This warning symbol means danger. You are in a situation that could cause bodily injury. Before you work
on any equipment, be aware of the hazards involved with electrical circuitry and be familiar with standard
practices for preventing accidents. Use the statement number provided at the end of each warning to locate
its translation in the translated safety warnings that accompanied this device.
SAVE THESE INSTRUCTIONS

Operating Cisco Application Centric Infrastructure


xvi
Preface
Related Documentation

Related Documentation
Cisco Cloud APIC Documentation
The Cisco Cloud APIC documentation is available at the following URL: https://www.cisco.com/c/en/us/
support/cloud-systems-management/cloud-application-policy-infrastructure-controller/
tsd-products-support-series-home.html

Cisco Application Policy Infrastructure Controller (APIC) Documentation


The following companion guides provide documentation for Cisco APIC:
• Cisco APIC Getting Started Guide
• Cisco APIC Basic Configuration Guide
• Cisco ACI Fundamentals
• Cisco APIC Layer 2 Networking Configuration Guide
• Cisco APIC Layer 3 Networking Configuration Guide
• Cisco APIC NX-OS Style Command-Line Interface Configuration Guide
• Cisco APIC REST API Configuration Guide
• Cisco APIC Layer 4 to Layer 7 Services Deployment Guide
• Cisco ACI Virtualization Guide
• Cisco Application Centric Infrastructure Best Practices Guide

All these documents are available at the following URL: http://www.cisco.com/c/en/us/support/


cloud-systems-management/application-policy-infrastructure-controller-apic/
tsd-products-support-series-home.html

Cisco Application Centric Infrastructure (ACI) Documentation


The broader Cisco ACI documentation is available at the following URL: http://www.cisco.com/c/en/us/
support/cloud-systems-management/application-policy-infrastructure-controller-apic/
tsd-products-support-series-home.html.

Cisco Application Centric Infrastructure (ACI) Simulator Documentation


The Cisco ACI Simulator documentation is available at http://www.cisco.com/c/en/us/support/
cloud-systems-management/application-centric-infrastructure-simulator/tsd-products-support-series-home.html.

Cisco Nexus 9000 Series Switches Documentation


The Cisco Nexus 9000 Series Switches documentation is available at http://www.cisco.com/c/en/us/support/
switches/nexus-9000-series-switches/tsd-products-support-series-home.html.

Operating Cisco Application Centric Infrastructure


xvii
Preface
Documentation Feedback

Cisco Application Virtual Switch Documentation


The Cisco Application Virtual Switch (AVS) documentation is available at http://www.cisco.com/c/en/us/
support/switches/application-virtual-switch/tsd-products-support-series-home.html.

Cisco ACI Virtual Edge Documentation


The Cisco Application Virtual Edge documentation is available at https://www.cisco.com/c/en/us/support/
cloud-systems-management/application-policy-infrastructure-controller-apic/
tsd-products-support-series-home.html.

Cisco ACI Virtual Pod Documentation


The Cisco Application Virtual Pod (vPod) documentation is available at https://www.cisco.com/c/en/us/
support/cloud-systems-management/application-policy-infrastructure-controller-apic/
tsd-products-support-series-home.html.

Cisco Application Centric Infrastructure (ACI) Integration with OpenStack Documentation


Cisco ACI integration with OpenStack documentation is available at http://www.cisco.com/c/en/us/support/
cloud-systems-management/application-policy-infrastructure-controller-apic/
tsd-products-support-series-home.html.

Documentation Feedback
To provide technical feedback on this document, or to report an error or omission, please send your comments
to apic-docfeedback@cisco.com. We appreciate your feedback.

Obtaining Documentation and Submitting a Service Request


For information on obtaining documentation, using the Cisco Bug Search Tool (BST), submitting a service
request, and gathering additional information, see What's New in Cisco Product Documentation at:
http://www.cisco.com/c/en/us/td/docs/general/whatsnew/whatsnew.html
Subscribe to What’s New in Cisco Product Documentation, which lists all new and revised Cisco technical
documentation as an RSS feed and delivers content directly to your desktop using a reader application. The
RSS feeds are a free service.

Operating Cisco Application Centric Infrastructure


xviii
CHAPTER 1
Introduction
• Abstract, on page 1
• Introduction, on page 2
• What Is New in APIC 1.2(1), on page 7

Abstract
The Cisco Application Centric Infrastructure (ACI) provides powerful new ways to dynamically manage
infrastructure in the modern world of IT automation and DevOps. Having the tools to change how infrastructure
is built is one thing, but being able to effectively operate the infrastructure beyond the day zero build activities
is crucial to long term effectiveness and efficiency. To effectively harness the power of ACI, organizations
will need to understand how to incorporate ACI into their daily operations. This book examines some of the
common operational activities that IT teams use to provide continued infrastructure operations and gives the
reader exposure to the tools, methodologies, and processes that can be employed to support day 1+ operations
within an ACI-based fabric.

Hardware and Software Included in the Book


The Cisco Application Centric Infrastructure (ACI) combines hardware, software, and ASIC innovations into
an integrated systems approach and provides a common management framework for network, application,
security, and virtualization.
For the purpose of writing this book, the following hardware devices were used:
• Application Policy Infrastructure Controller (APIC)
• ACI Spine switches, including Cisco Nexus 9508 and 9336PQ
• ACI Leaf switches, including Cisco Nexus 9396PX, 9396TX, and 93128TX
• Cisco Application Virtual Switch (AVS)
• Cisco UCS B and C series servers
• Several models of switches and routers, including Cisco Nexus 5000 switches and Cisco Integrated
Services Routers (ISR)
• A variety of hypervisors, including KVM, Microsoft Hyper-V, and VMware vSphere
• IXIA IxVM product family traffic generators
This book was written based on the ACI 1.2 software release.

Operating Cisco Application Centric Infrastructure


1
Introduction
Introduction

Introduction
The Story of ACME Inc.
ACME Inc. is a multi-national corporation that specializes in manufacturing, sales, and distribution of a diverse
product portfolio, including rocket-powered roller skates, jet-propelled unicycles, and various explosive
materials. These product groups operate as separate business groups within the company, and have previously
maintained separate infrastructure and applications. They have largely focused on retail routes to market, but
have recently decided to pursue a more direct-to-consumer business model due to intense pressure from new
competitors who have dominated the online sales channels. In an effort to be more competitive, ACME has
undertaken a project to build a mobile application platform to support ordering and logistics for product
delivery to their customers for their entire portfolio.
Traditionally, ACME business units have leveraged third party software companies and commercially available
software to meet their IT demands, but would like to create a more intimate relationship with their consumers
and be able to take feedback on the platform directly from those users, while incorporating an ongoing
improvement cycle so they can react to changing market dynamics in a more nimble fashion. Where they
have used custom software in the past, they have leveraged a traditional infrastructure and software model
that does not allow them to keep up with the changing requirements, and therefore ACME is looking for a
new approach to both application and infrastructure life cycle management. The application developers have
been looking at new application development trends such as Continuous Delivery and Continuous Integration,
and the new application platform is to be developed in this manner. To support this, the infrastructure
components need to be capable of mapping to these new paradigms in a way that is not possible using traditional
concepts.
One of the largest challenges ACME has historically faced is that operations and infrastructure has been an
afterthought to product development. This has led to several situations where application deployments have
meant long weekend hours for all of the teams, caused customer-impacting outages, and taken longer to
accomplish than the business leaders would have liked. For this reason, ACME Inc. has decided to change
by creating an environment where infrastructure artifacts are treated as part of the application, can be checked
into version control, can be tested alongside the actual application, and can continually improve.
While ACME is intensely focused on delivering the new application platform in a timely manner, ACME is
also interested in creating a foundation on which it can grow to deliver a common pool of infrastructure that
is shared across all business groups and operated in a multi-tenant fashion to increase efficiency.
At an executive briefing, John Chambers, the CEO of Cisco Systems at the time, told ACME: "The world is
changing. Every company is a technology company, and if you don't adapt, you'll get left behind."
As evidenced by the success of cloud platforms, such as Amazon Web Services (AWS) and OpenStack,
consumption models of technology delivery have the ability to adapt technology more quickly to rapid business
requirements changes. This is the type of consumption that ACME Inc.'s business owners need. Control of
operations is what operations groups are focused on, but control can be a barrier to a pure consumption model.
Unless companies make investments in technologies that allow for consumption of automated components,
the only other way to scale is by breaking the human level component, and few people would really choose
to work for that type of company.
After analyzing current offers from various technology vendors, ACME Inc. selected Cisco Application
Centric Infrastructure (ACI). The ability to abstract all physical and virtual infrastructure configuration into
a single configuration that is consistent across dev, test, and prod environments, as well as portable across the
various data center locations currently maintained by ACME, is highly desirable. ACI has been built from
the ground up to change the substructure used to build network devices and protocols. Innovation at this level

Operating Cisco Application Centric Infrastructure


2
Introduction
Introduction

will provide more opportunities for expanding the tools with which users interact. This is where the fulcrum
will tilt in the favor of IT and infrastructure being more dynamic, thus allowing IT to operate and manage at
the speed of business. However, with a change of this nature comes fear, uncertainty, and doubt. This book
will attempt to bring some level of comfort and familiarity with operations activities within an ACI fabric.
While ACME Inc. is a fictitious company, this is the true story of every company, and just important this is
the story of the employees of those companies. Workers in the IT industry need to adapt to keep up with the
rapid change of the business. However, this runs contrary to how most operations groups exist in the relationship
between business and technology. Most IT operations groups invest a lot of time in the tools needed to deliver
services today and there is an organic resistance to re-investing. The thought is, "Why fix what is already
working?"

The Why, Who, What, When and How


Within ACI, ACME is looking to simplify how it operates infrastructure, but recognizes that this initiative,
this application, and this infrastructure are new to ACME Inc. ACME must address fundamental questions
including Who manages What, and How they go about their tasks. When different groups perform regular
operations, and Where they go to perform these operations, are also considerations, but more tactical and
point-in-time-relevant. This section discusses the relevant aspects of these monikers as it relates to ACI fabric
operations and how a company such as ACME Inc. can divide the workload.
Why
"Why" is the most important aspect of what should be considered in operationalizing an ACI fabric. In the
case of ACME Inc. the key success criteria is to streamline processes and procedures related to the deployment
of infrastructure required to support the application initiatives. To achieve the desired result, a high degree of
automation is required. Automation adds speed to repetitive tasks and eliminates errors or missed steps.
Initially, automation can be a scary proposition for some of the key stakeholders, as it could be looked at as
a threat to their own job. Quite the opposite, automation is about making work more enjoyable for all team
members, allowing them the freedom to innovate and add value, while removing mundane, repetitive tasks.
Looking at why an automated fabric is beneficial to an organization is important for setting expectations of
return on investment. Also, looking at why an operational practice is done a specific way can help with framing
the tools and processes that are employed.
Who
As with most organizations, ACME Inc. traditionally had different types of stakeholders involved in making
any IT initiative successful, and each has a specific element of the infrastructure in which they have specific
expertise and about which they care most. In any IT organization, these groups can have distinct organizational
boundaries, but more likely the boundaries are blurred to some degree. Listed below are some characteristics
of these groups, but keep in mind that some of these characteristics might be combined. At the macro level,
the fact that these different organizations exist should not be evident to the end-user. Instead, the entire
organization should be seen as one team with a common goal of delivering value to their organization.
ACME's Development and Application Team is focused on the software and applications the company uses
internally and the software that it delivers to its customers. The Application part of the team contains application
owners and subject matter experts that ensure other business units are able to do their jobs by utilizing the
business applications available. The Development part of the team will be writing the mobile application
software platform. Both parts of this team will need to work closely with the other teams in this section to
enable the best design, performance, and availability of applications for the end users.
ACME's Network Team is primarily focused on creating and managing networking constructs to forward
packets at Layer 2 (MAC/switching) and Layer 3 (IP routing). The team is challenged with juggling application
requirements, managing SLA, and assisting in the enforcement of information security, all while maintaining
high levels of availability. What the team needs to know is how to configure the networking constructs, how

Operating Cisco Application Centric Infrastructure


3
Introduction
Introduction

to tie Layer 2 to Layer 3, how to verify forwarding, and how to troubleshoot network forwarding aspects in
the fabric. With ACI, the team is the most interested in decoupling overloaded network constructs and returning
to the specific network problems that the team was intended to solve, while allowing other groups to leverage
their specific expertise to manipulate security and application level policies. The team is also interested in
allowing more transparency in the performance of the network forwarding, and the team is making key metrics
available on demand in a self-service capacity.
ACME's Storage Team is primarily focused on delivery of data storage resources to the organization. The
storage team is concerned with protecting the data in terms of availability, as well as making sure that sensitive
data is secure. The storage team has been very successful in maintaining very tight SLAs and has traditionally
managed separate infrastructure for storage access. The capabilities provided by the ACI fabric allow them
to confidently deploy newer IP-based storage and clustering technologies. The team is also very interested in
being able to see how the storage access is performing and would like to be notified in the event of contention.
The team typically has some specific requirements around QoS, multi-pathing, and so on. Historically, the
team had to worry about delivering a storage fabric in addition to managing storage devices themselves. ACI
will provide the storage team with the visibility they will require. These capabilities are primarily discussed
in the monitoring sections.
The Compute and Virtualization Team at ACME Inc. is wrapping up a major initiative to virtualize the server
farms that it is responsible for maintaining. The team also recently employed new configuration management
tools to account for new workloads that fell outside of the virtualization effort to get similar agility for bare
metal servers that the team gained from its virtualization efforts. This is timely as the application rollout will
have both virtualized and non-virtualized workloads. Additionally, the application developers are increasingly
interested in leveraging Linux container technologies to allow for even greater application portability. The
Compute and Virtualization teams are interested in ACI for its ability to provide common access to physical
and virtual servers, allowing the team to publish endpoint groups to virtualization clusters from a centralized
place across multiple hypervisors. These capabilities are discussed further in the Fabric Connectivity chapter.
The Information Security Team at ACME Inc. has traditionally been engaged late in an application deployment
process, and has been responsible for performing vulnerability assessment and data classification efforts. With
the current project, the new application will be storing sensitive customer information, including credit card
numbers. Due to the sensitivity of this information and the security aspects of the ACI fabric, the Information
Security Team is able to provide input earlier in the process and avoid re-doing work because of security or
compliance issues. The Information Security Team is interested in the operational aspects of the ACI security
model as it relates to the following capabilities: tenancy, Role Based Access Control (RBAC), monitoring,
and Layer 4 to Layer 7 services.
What
The aspect of "what" can be looked at in many different ways, but the main concept in the context of this
book is what tools are used to manage operations of an ACI fabric. In a traditional network, you have some
traditional tools, such as CLI and SNMP, to manage network operations, and these tools integrate into
management platforms and configuration and management processes.
In ACI, there are some elements of the traditional tools, but the fabric management is rooted in an abstracted
object model that provides a more flexible base. With this base, the operator of the fabric can choose from
multiple modes of management, such as GUI, CLI, API integration, programming, scripting, or some
combination of these. How a tool is selected in ACI will often be a product of what is being done and the
aspects of how the tool is used. For example, if an operations staff is trying to gather a bunch of information
across a number of interfaces and switches or is managing the configuration of many different objects at once,
scripting might be more efficient, whereas simple dashboard monitoring might be more suited to a GUI.
When

Operating Cisco Application Centric Infrastructure


4
Introduction
Introduction

"When" refers to when the teams listed above are involved in the planning. It is a good idea to involve the
different teams early when building policies and processes for how the fabric is implemented and then managed.
The collaborative nature of ACI allows for a high degree of parallelization of work flow. This is a key difference
between ACI and traditional processes that were very serial in nature, resulting in a longer deployment time
for applications and a higher mean-time to resolution when issues arise.
How
"How" answers the following basic questions:
• How does a networking person go about configuring the network forwarding?
• How does the compute team get information from the infrastructure to make optimal workload placement
decisions?
• How do the application team track performance and usage metrics?
• How does a storage team track the access to storage subsystems and ensure that it is performant?
When "how" involves making a change to the configuration of an environment, an important consideration
is change control. Change control is a fact of life in the mission-critical environments that ACI has been
designed to support. The ACI policy model has been designed to reduce the overall size of a fault domain and
provide a mechanism for incremental change. There are mechanisms for backup and restore that will be
discussed in follow-on chapters. We will also discuss the model and which objects affect the tenants and the
fabric as a whole.
An evaluation of current change control and continuous integration/delivery strategies is warranted as
operational procedures evolve. Throughout this book we will highlight the methods and procedures to
pro-actively and reactively manage the fabric.
As a baseline, most organizations are implementing some kind of structured change-control methodology to
mitigate business risk and enhance system availability. There are a number of change/IT management principles
(Cisco life cycle services, FCAPS, and ITIL) that are good guides from which to start. A common sense
approach to change management and continuous integration should be a premise that is discussed early in the
design and implementation cycle before handing the fabric to the operations teams for day-to-day maintenance,
monitoring, and provisioning. Training operations teams on norms (a stated goal of this book) is also key.
Applying change management principles based on technology from five years ago would not enable the rapid
deployment of technology that ACI can deliver.
The multi-tenant and role-based access control features inherent to the ACI solution allow the isolation or
drawing of a very clean box around the scope and impact of the changes that can be made. For more information,
see Role-Based Access Control, on page 23.
Ultimately each change must be evaluated primarily in terms of both its risk and value to the business. A way
to enable a low-overhead change management process is to reduce the risk of each change and increase its
value. Continuous delivery does exactly this by ensuring that releases are performed regularly from early on
in the delivery process, and ensuring that delivery teams are working on the most valuable thing they could
be at any given time, based on feedback from users.
In the Information Management Systems world, there are three fundamental kinds of changes:
• Emergency changes
• Normal
• Standard
Emergency changes are by definition a response to some kind of technical outage (hardware, software,
infrastructure) and are performed to restore service to affected systems.
Normal changes are those that go through the regular change management process, which starts with the
creation of a request for change which is then reviewed, assessed, and then either authorized or rejected, and

Operating Cisco Application Centric Infrastructure


5
Introduction
Introduction

then (assuming it is authorized) planned and implemented. In an ACI environment a normal change could
apply to anything within the following components:
• Fabric Policies (fabric internal and access will be discussed in detail later)
• Configuration objects in the Common tenant that are shared with all other tenants (things that affect the
entire fabric)
• Private Networks
• Bridge Domains
• Subnets
• Virtual Machine Manager (VMM) integrations
• Layer 4 to Layer 7 devices
• Device packages
• Creation of logical devices
• Creation of concrete devices
• Layer 2 or Layer 3 external configuration
• Attachable Entity Profile (AEP) creation
• Server or external network attachment
• Changes to currently deployed contracts and filters that would materially change the way traffic flows
Standard changes are low-risk changes that are pre-authorized. Each organization will decide the kind of
standard changes that they allow, who is allowed to approve them, the criteria for a change to be considered
"standard", and the process for managing them. As with normal changes, they must still be recorded and
approved. In the ACI environment some examples of "standard" changes could be:
• Tenant creation
• Application profile creation
• Endpoint group (EPG) creation
• Contracts scoped at a tenant level
• Layer 4 to Layer 7 service graphs
• Domain associations for endpoint groups
The items mentioned above are not intended to be all-inclusive, but are representative of common tasks
performed day-to-day and week-to-week.
The ability to audit changes that are happening to the environment is a requirement for ACME Inc. Application
Policy Infrastructure Controller (APIC) maintains an audit log for all configuration changes to the system.
This is a key troubleshooting tool for "when something magically stops working". Immediate action should
be to check the audit log as it will tell who made what change and when, correlating this to any faults that
result from said change. This enables the change to be reverted quickly.
A more in-depth discussion of continuous delivery in the context of infrastructure management is outside of
the scope of this book.
The remainder of this book answers these questions, providing you with a framework of how to take the
concepts and procedures and apply them to similar initiatives within your organizations. The book is laid out
in a specific order. However, ACI enables ACME Inc. to complete these tasks in parallel with the various
stakeholders who are highlighted throughout, and this book illustrates how the stakeholders can work together
in a more collaborative manner than they have in the past. While some scripting opportunities are called out
throughout the book, there is a more in-depth section at the end that explains how to use the ACI API to
automate most operational tasks. While organizational structures might be siloed into these teams, to provide

Operating Cisco Application Centric Infrastructure


6
Introduction
What Is New in APIC 1.2(1)

the greatest value to the customer, user, and ultimately the business, the most important thing is for these
groups to work insieme (together).
Figure 1: ACI addresses IT requirements from across the organization

What Is New in APIC 1.2(1)


The Application Policy Infrastructure Controller (APIC) release 1.2(1) introduces many new features and
enhancements. This section highlights the new features and provides a brief overview. For additional
information, including new hardware support, see the Release Notes for your version of Cisco Application
Centric Infrastructure (ACI) software.

Operating Cisco Application Centric Infrastructure


7
Introduction
What Is New in APIC 1.2(1)

Basic GUI
A new "basic" GUI mode of operation has been added. You are given the option at the APIC login screen to
select the Basic or Advanced GUI mode. The goal of the simplified GUI is to offer a simple interface to
enable common workflows. The GUI operational mode enables administrators to get started easily with ACI
with a minimal knowledge of the object model. The simplified GUI allows the configuration of leaf ports and
tenants without the need to configure advanced policies, such as switch profiles, interface profiles, policy
groups, or access entity profiles (AEPs). The ACI administrator can still use the advanced (regular) GUI mode
as desired. Although the basic GUI is great for those users who are new to ACI, Cisco recommends leveraging
the advanced GUI for scale operations, existing fabric deployments, and more granular policy control.

NX-OS-Style CLI
The existing approach to configuring the APIC allows the user access to almost all aspects of the policy model
while it requires a comprehensive understanding of the policy model and the framework. Prior to the
NX-OS-style CLI, the APIC CLI configuration mechanism required an understanding of all related Managed
Objects (MO) for the ACI policy model, and the CLI allowed creating, editing, and saving those managed
objects that were represented as a UNIX file system by using commands such as mocreate and moconfig.
This approach was radically different from Cisco IOS/NX-OS CLI features that hide most of the internal
details to simplify the configuration process as much as possible. To align better with existing NX-OS-style
command interfaces, an NX-OS-style CLI for APIC was introduced with the goal of harnessing the power of
APIC without the burden of learning the details of the ACI policy model.
The new NX-OS-style CLI for the APIC uses the familiar NX-OS syntax as much possible. The NX-OS-style
CLI provides intelligence to user inputs to create or modify the underlying ACI policy model as applicable
without sacrificing the power of the ACI policy model to deploy applications at scale.
Depending on the mode that you are in, commands might not be active in that context. For example, if you
are in the POD configuration mode [apic1(config-pod)#], the "show running-config ntp" command shows
the current NTP configuration. If you are in the NTP configuration mode [apic1(config-ntp)#], the "show
running-config server" command shows the current NTP configuration. Use the where command to determine
your current mode. For example:
apic1# where
exec
apic1# configure
apic1(config)# where
configure
apic1(config)# pod 1
apic1(config-pod)# where
configure; pod 1
apic1(config-pod)# ntp
apic1(config-ntp)# where
configure; pod 1; ntp

Note By default, when you ssh into an APIC running version 1.2(1) or later, you will automatically be placed into
the NX-OS-style CLI and not into the object model CLI of the previous releases. To use the object model
CLI, use the bash command. You can execute a single command in the bash shell by using the following
command:
bash -c 'path/command'

For example:
bash -c '/controller/sbin/acidiag avread'

Operating Cisco Application Centric Infrastructure


8
Introduction
What Is New in APIC 1.2(1)

Role-Based Access Control Rule Enhancements for Layer 4 to Layer 7 Services


Layer 4 to Layer 7 policy configurations in a multi tenant environment required administrator intervention to
create certain objects that cannot be created by tenant administrators using the classic role-based access control
(RBAC) domains and roles. This introduces a requirement for more fine-grained RBAC privileges in the ACI
policy model. Tenant administrators can now create RBAC rules via self-service without global administrator
intervention to grant permissions for resources under their tenant subtree to other tenants and users in the
system.

Ingress-Based ACL
Typically, the fabric uses ingress endpoint group-based access control lists (ACLs) for policy enforcement,
except in a few cases such as when the destination endpoint group is an L3Out or for when the ingress leaf
switch does not know which endpoint group a destination end host is in with the bridge domain in hardware
proxy mode. In the case of these exceptions, policy enforcement occurs as the packet is leaving the fabric.
ACI administrators can now move policy enforcement from the border leaf (where the L3Out connection is
located and the ingress/egress policy has been traditionally enforced) to the non-border leaf where the incoming
connection is being sourced. The goal is to reduce the number of ACL rules that need to be programmed on
the border leafs for tenants leveraging L3Out connectivity and to migrate those to the ingress leaf switch of
the connection source instead.
A new configuration property called "Policy Control Enforcement Direction" has been added to the Layer 3
External Outside endpoint group. This property is used for defining policy enforcement direction for the egress
traffic on an L3Out. The new default configuration is ingress for newly created Layer 3 External endpoint
groups, but for any pre-existing L3Outs prior to this software version, the old default behavior will continue
in egress mode so that previous behavior is unchanged. Previously created L3Outs can be manually changed
to ingress mode by the ACI administrator.

Troubleshooting Wizard Enhancements


The troubleshooting wizard (TSW) introduced in version 1.1(1) was limited to testing endpoint connectivity
from within a single tenant. This presented a problem if one of the endpoints were outside of the user tenant
(such as the Common tenant). This feature has been improved to now support endpoint testing between tenants.

APIC Configuration Rollback


The configuration rollback feature allows for configuration snapshots to be created and saved locally or to a
remote location. Two saved snapshots can also be compared to identify differences between the two. In the
event that a fabric policy change is made inadvertently or that causes an issue, a snapshot can be rolled back
reverting only the modified policies. Existing and unchanged policies remain unaffected during this operation.
The feature also includes a built-in recurring feature to automate and schedule snapshots. Snapshots can be
created at either the fabric-wide or user tenant level.

vRealize Integration
An ACI-specific plugin for VMware's vRealize Suite has been introduced that allows the management of
APIC policies from the vRealize automation application. Users can now provision the underlying fabric in
addition to the virtual compute and services using this orchestration and automation software. The plugin
provides access to pre-defined APIC policies, workflows, and blueprints.

Operating Cisco Application Centric Infrastructure


9
Introduction
What Is New in APIC 1.2(1)

Unmanaged Mode for Layer 4 to Layer 7 Services


The Layer 4 to Layer 7 service insertion feature enables an administrator to insert one or more services between
two endpoint groups. The APIC allocates the fabric resources (VLANs) for the services and programs fabric
(leafs) and service appliances as per the configuration specified in service graph. Previously, the APIC required
a device package for Layer 4 to Layer 7 services to be used as part of the service graph. Part of this operation
also involved the APIC programming the service appliance during graph instantiation.
In some environments, it may be desirable that the APIC only allocate network resources for the service graph
and program only the fabric side during graph instantiation. This may be needed for various reasons. For
example, environments that may already have an existing orchestrator or a DevOps tool responsible for
programming the service appliance. Another common instance is where a device package for the service
appliance may not be available for that platform.
Unmanaged mode for services adds the desired flexibility. If enabled, it restricts APIC to only allocate the
network resources for a service appliance and only program the fabric (leaf). The configuration of the device
is left to be done externally by the customer.

Simple Network Management Protocol support for APIC


The following enhancements have been added to the existing SNMP agent on the APIC and fabric switches:
• ISIS adjacency state change Trap
• Temperature sensor threshold trap
• Power supply in-let line/cable status change trap
• CPU usage threshold trap

vSphere 6 Support
VMM integration with vSphere 6.0 & vCenter 6.0 was introduced in APIC version 1.1(2). Support only
included the integration of the VMware Virtual Distributed Switch (vDS). Additional support for the Cisco
AVS has now been included in this release. The only support restriction for the 1.2(1) release is that
cross-vCenter and cross-vDS vMotion is not supported on the AVS. These features are fully supported for
the VMware vDS.

Common Pervasive Gateway


In ACI deployments where there are multiple fabrics deployed, moving an endpoint from one fabric to another
fabric required changing its default gateway or IP address to avoid hairpin traffic. This feature allows the
seamless movement of endpoints between fabrics without having to change anything.
Configuring this feature requires the setup of two similarly configured bridge domains on each fabric. The
bridge domain in each fabric is configured with the same virtual IP address and virtual MAC address, which
results in reachability from the endpoints in that bridge domain, regardless of in which physical fabric they
reside.

Microsoft Microsegmentation (uSeg) Support


In the APIC software release 1.1(1), ACI introduced the concept of attribute-based endpoint groups (aka
uSeg). This allows for special endpoint groups called "uSeg EGPs" to be defined with various attributes,
including virtual machine attributes (such as VM Name, OS Type, and Hypervisor), IP address, and MAC
sets that would be matched against virtual machines. Matches for any of the attributes apply the policy for

Operating Cisco Application Centric Infrastructure


10
Introduction
What Is New in APIC 1.2(1)

that uSeg endpoint group against the virtual endpoint dynamically without having to re-assign the Virtual
Port Group binding. Previous to this release, only VMware virtual machines were supported. Now, support
has been extended to include Microsoft HyperV virtual machines.

Direct Server Return


When endpoints sit behind a load balancer, the client request gets sent to the load balancer and then is relayed
to the destination server. When the server responds to the client, it follows the same path back to the load
balancer and then onto the client. This can often make the load balancer a bottleneck for communications and
this can degrade network performance. Direct server return allows the destination server to respond directly
to the client without having to be relayed through the load balancer.

Shared Layer 3 Out


In previous software releases, there were limitations on how Layer 3 Out connections could be deployed and
used by multiple tenants. For many cases the user had to define a Layer 3 Out policy for each tenant, despite
those tenants using the same gateway device.
In this release, improvements to this feature add the ability for a tenant or VRF to use a Layer 3 Out connection
that is configured in a different tenant. The common use case for this feature is a fabric with a Layer 3 Out in
the "Common" tenant, which is shared by multiple user tenants. This is accomplished by leaking learned
routes between two tenants.
One limitation of this feature is that the passing of learned routes in one tenant that are to be passed out of the
shared L3Out connection, which is also known as transit routing, is not supported.

Operating Cisco Application Centric Infrastructure


11
Introduction
What Is New in APIC 1.2(1)

Operating Cisco Application Centric Infrastructure


12
CHAPTER 2
Management
• APIC Overview, on page 13
• Configuring Management Protocols, on page 14
• Role-Based Access Control, on page 23
• Import and Export Policies, on page 26

APIC Overview
There are a number of fundamental differences between the operations of traditional networking hardware
and an Cisco Application Centric Infrastructure (ACI) fabric. These differences serve to simplify the
management greatly, reduce the number of touch points, and decouple the switching hardware from the desired
configuration intent. These changes include:
• Single point of management controller-based architecture
• Stateless hardware
• Desired state-driven eventual consistency model

The single point of management within the ACI architecture is known as the Application Policy Infrastructure
Controller (APIC). This controller provides access to all configuration, management, monitoring, and health
functions. Having a centralized controller with an application programming interface (API) means that all
functions configured or accessed through the fabric can be uniformly approached through a graphical user
interface (GUI), command line interface (CLI), and API, with no risk of inconsistency between the various
data interfaces. This results in a clean and predictable transition between the interfaces. The underlying
interface for all access methods is provided through a REST-based API, which modifies the contents of a
synchronized database that is replicated across APICs in a cluster and provides an abstraction layer between
all of the interfaces.
This controller-based architecture also makes possible a stateless configuration model that decouples the
hardware from the configuration running on it. This translates to an APIC cluster that manages individual
fabric nodes of leaf and spine switches that derive their identity from what the controller defines as being the
desired intent, and not from the serial number of the chassis, nor from a configuration file residing on the
devices. Each node receives a unique node identifier, which allows for the device to download the correct
configuration attributes from the controller. The device can also be substituted in a stateless fashion, meaning
that hardware swaps can be faster, topology changes are less impactful, and network management is simplified.
The desired state model for configuration further complements these concepts of controller-based management
and statelessness by taking advantage of a concept known as declarative control-based management, based

Operating Cisco Application Centric Infrastructure


13
Management
Configuring Management Protocols

on a concept known as the promise theory. Declarative control dictates that each object is asked to achieve a
desired state and makes a "promise" to reach this state without being told precisely how to do so. This stands
in contrast with the traditional model of imperative control, where each managed element must be told precisely
what to do, be told how to do it, and take into account the specific situational aspects that will impact its ability
to get from its current state to the configured state. A system based on declarative control is able to scale much
more efficiently than an imperative-based system, since each entity within the domain is responsible for
knowing its current state and the steps required to get to the desired state, dictated by the managing controller.
For information about new APIC features, see the Cisco Application Policy Infrastructure Controller Release
Notes for your release of the software:
http://www.cisco.com/c/en/us/support/cloud-systems-management/application-policy-infrastructure-controller-apic/
tsd-products-support-series-home.html

Configuring Management Protocols


For the optimization of ACME's Cisco Application Centric Infrastructure (ACI) fabric, the network team
created the following management protocol policies:
• Cisco Discovery Protocol (CDP) - These policies are primarily consumed by the network team, as CDP
is the standard for their existing network equipment.
• Link Layer Discovery Protocol (LLDP) - Discovery protocols are no longer limited to just network
devices. LLDP is a standards-based protocol for discovering topology relationships. ACME is deploying
LLDP on servers, Layer 4 to Layer 7 services devices, and storage arrays. Therefore, these policies will
be available for consumption by all of the teams.
• Network Time Protocol (NTP) - Maintaining accurate time across the application logs and infrastructure
components is extremely important for being able to correlate events. ACME has existing NTP servers
and will leverage them for maintaining time in their ACI fabric deployment. With ACI, maintaining
accurate time is of increased importance as accurate time is a prerequisite for features such as atomic
counters.
• Domain Name Services (DNS) - providing name resolution to fabric components consistent with the
application and server teams. In addition to be able to resolve names within the fabric, the important ACI
components are also registered with ACME's DNS server so teams can easily access them in their
management tasks.

Creating a Cisco Discovery Protocol Policy Using the GUI


Cisco Discovery Protocol (CDP) is a valuable source of information in troubleshooting physical and data-link
layer issues. In the course of ACI operations, there may be times when you must provision a particular
host-facing port manually with a CDP on or off policy. By default, the ACI fabric provides a default policy
where CDP is disabled. As a recommended practice, manually create a "CDP-ENABLED" policy with CDP
enabled, as well as a "CDP-DISABLED" policy with CDP disabled that can be referenced throughout all
interface policy configurations.
To create CDP policies:
1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Interface Policies > Policies > CDP Interface.
3. In the Work pane, choose Actions > Create CDP Interface Policy.

Operating Cisco Application Centric Infrastructure


14
Management
Creating a Link Layer Discovery Protocol Policy Using the GUI

4. In the Create CDP Interface Policy dialog box, perform the following actions:
1. In the Name field enter the name of the policy, such as "CDP-ENABLED".
2. For the Admin State radio buttons, click Enabled.
3. Click Submit.

5. In the Work pane, choose Actions > Create CDP Interface Policy.
6. In the Create CDP Interface Policy dialog box, perform the following actions:
1. In the Name field enter the name of the policy, such as "CDP-DISABLED".
2. For the Admin State radio buttons, click Disabled.
3. Click Submit.

Your CDP policy is now ready to be assigned to an Interface Policy Group.

Creating a Link Layer Discovery Protocol Policy Using the GUI


Link Layer Discovery Protocol (LLDP) is a valuable source of information for troubleshooting physical and
data-link layer issues. In the course of ACI operations, by default, the LLDP feature is enabled on the fabric.
There might be times in the operation of the ACI fabric in which you must manually adjust the LLDP protocol
to conform with interoperability requirements of end-host devices. For example, when connecting to Cisco
Unified Computing System (UCS) Blade servers, you must disable LLDP.
Cisco recommends that you pre-provision LLDP enable and disable protocol policies to make future interface
policy deployment decisions streamlined and easily configured.
To create an LLDP policy:
1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Interface Policies > Policies > LLDP Interface.
3. In the Work pane, choose Actions > Create LLDP Interface Policy.
4. In the Create LLDP Interface Policy dialog box, perform the following actions:
1. In the Name field, enter "LLDP-TX-ON-RX-ON".
2. For the Receive State radio buttons, click Enabled.
3. For the Transmit State radio buttons, click Enabled.
4. Click Submit.

5. In the Work pane, choose Actions > Create LLDP Interface Policy.
6. In the Create LLDP Interface Policy dialog box, perform the following actions:
1. In the Name field, enter "LLDP-TX-ON-RX-OFF".
2. For the Receive State radio buttons, click Disabled.
3. For the Transmit State radio buttons, click Enabled.

Operating Cisco Application Centric Infrastructure


15
Management
Time Synchronization and NTP

4. Click Submit.

7. In the Work pane, choose Actions > Create LLDP Interface Policy.
8. In the Create LLDP Interface Policy dialog box, perform the following actions:
1. In the Name field, enter "LLDP-TX-OFF-RX-ON".
2. For the Receive State radio buttons, click Enabled.
3. For the Transmit State radio buttons, click Disabled.
4. Click Submit.

9. In the Create LLDP Interface Policy dialog box, perform the following actions:
1. In the Name field, enter "LLDP-TX-OFF-RX-OFF".
2. For the Receive State radio buttons, click Disabled.
3. For the Transmit State radio buttons, click Disabled.
4. Click Submit.

Your LLDP policies are now ready to be leverage as part of an Interface Policy Group.

Time Synchronization and NTP


Within the Cisco Application Centric Infrastructure (ACI) fabric, time synchronization is a crucial capability
upon which many of the monitoring, operational, and troubleshooting tasks depend, including the following
tasks:
• The Application Policy Infrastructure Controllers (APICs) and fabric switches use certificates to establish
encrypted communication channels between themselves. If the time difference between the APIC and
switches is significantly large (greater than 7 hours), the switch might tear down existing communication
channels or never create new communication channels with the APIC, which isolates the switch from
the fabric until the time is manually set on the switch.
• Clock synchronization is important for proper analysis of traffic flows as well as for correlating debug
and fault time stamps across multiple fabric nodes. An offset present on one or more devices can hamper
the ability to diagnose properly and resolve many common operational issues. In addition, clock
synchronization allows for the full utilization of the atomic counter capability that is built into the ACI
upon which the application health scores depend.

While you should configure time synchronization before deploying a full fabric or applications so as to enable
proper usage of these features, nonexistent or improper configuration of time synchronization does not
necessarily trigger a fault or a low health score. The most widely adopted method for synchronizing a device
clock is to use Network Time Protocol (NTP). For more information on atomic counters, see Atomic Counters,
on page 207.
Prior to configuring NTP, consider what management IP address scheme is in place within the ACI fabric.
There are two options for configuring management of all ACI nodes and APICs, in-band management and/or
out-of-band management. Depending on which management option was chosen for the fabric, configuration
of NTP will vary.

Operating Cisco Application Centric Infrastructure


16
Management
Configuring Out-of-Band Management NTP Using the GUI

Another consideration in deploying time synchronization where the time source is located. The reliability of
the source must be carefully considered when determining if you will use a private internal clock or an external
public clock.

Configuring Out-of-Band Management NTP Using the GUI


When an ACI fabric is deployed with out-of-band management, each node of the fabric, inclusive of spines,
leaves and all members of the APIC cluster, is managed from outside the ACI fabric. This IP reachability will
be leveraged so that each node can individually query the same NTP server as a consistent clock source.
To configure NTP, a Date and Time policy must be created that references an out-of-band management
endpoint group. Date and Time policies are confined to a single pod and must be deployed across all pods
provisioned in the ACI fabric. As of the publishing of this document, only one pod per ACI fabric is allowed.
To configure NTP using the GUI:
1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Pod Policies > Policies.
3. In the Work pane, choose Actions > Create Date and Time Policy.
4. In the Create Date and Time Policy dialog box, perform the following actions:
1. Provide a name for the policy to easily distinguish between your environment's different NTP
configurations, such as "Production-NTP".
2. Click Next.
3. Click the + sign to specify the NTP server information (provider) to be used.
4. In the Create Providers dialog box, enter all relevant information, including the following fields:
Name, Description, and Minimum Polling Intervals, and Maximum Polling Intervals.
1. If you are creating multiple providers, click the Preferred check box for the most reliable NTP
source.
2. In the Management EPG drop-down list, if the NTP server is reachable by all nodes on the fabric
through out-of-band management, choose Out-of-Band. If you have deployed in-band management,
see the "In-Band Management NTP" section.
3. Click OK.

5. Repeat steps c and d for each provider that you want to create.

Your NTP policy is now ready for deployment to the ACI fabric nodes.

Configuring Out-of-Band Management NTP Using the NX-OS-Style CLI


You can configure the NTP server for POD 1, the default POD for the fabric, by using the NX-OS-style CLI.

Procedure

Step 1 SSH to an APIC in the fabric.

Operating Cisco Application Centric Infrastructure


17
Management
In-Band Management NTP

# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure

Step 3 Enter the configure mode for POD 1:


apic1(config)# pod 1

Step 4 Enter the NTP configure mode:


apic1(config-pod)# ntp

Step 5 Configure the NTP server:


apic1(config-ntp)# server 192.168.29.35 prefer use-vrf oob-mgmt

This configuration prefers IP address 192.168.29.35 as an NTP source and uses VRF oob-mgmt (out-of-band
management) to reach it.

In-Band Management NTP


When an ACI Fabric is deployed with in-band management, consider the reachability of the NTP server from
within the ACI in-band management network, that is from a source that is reachable through the front panel
leaf ports. To leverage an NTP server external to the fabric with in-band management, you must construct a
policy to enable this communication. The steps used to configure in-band management policies are identical
to those used to establish an out-of-band management policy: the distinction is around how to allow the fabric
to connect to the NTP server.
Once you have established a policy to allow communication, you can create the NTP policy as established in
the "Out-of-Band Management NTP" section.

Verifying NTP Operation Using the GUI


Full verification of NTP functionality is best accomplished by leveraging both the Cisco Application Centric
Infrastructure (ACI) CLI and the Application Policy Infrastructure Controller (APIC) GUI. Start verifying
time synchronization configuration by ensuring that all policies are configured properly inside of the APIC
GUI. Policy configuration can be verified by using the following procedure:
1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Pod Policies > Policies > Date and Time > ntp_policy > server_name.
The ntp_policy is the previously created policy.
3. In the Work pane, verify the details of the server.

Verifying the NTP Policy Configuration Using the NX-OS-Style CLI


You can verify the NTP policy configuration using the NX-OS-style CLI.

Operating Cisco Application Centric Infrastructure


18
Management
Verifying that the NTP Policy is Deployed on Each Fabric Switch Using the NX-OS-Style CLI

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure

Step 3 Show the configuration of POD 1:


apic1(config)# show running pod 1 ntp
# Command: show running-config pod 1 ntp
# Time: Mon Nov 9 17:17:18 2015

Step 4 Enter the configure mode for POD 1:


apic1(config)# pod 1

Step 5 Enter the NTP configure mode:


apic1(config-pod)# ntp

Step 6 Configure the NTP server:


apic1(config-ntp)# server 192.168.29.35 prefer use-vrf oob-mgmt

Step 7 Exit to the configure mode:


apic1(config-ntp)# exit
apic1(config-pod)# exit

Verifying that the NTP Policy is Deployed on Each Fabric Switch Using the
NX-OS-Style CLI
To verify that the policy has been successfully deployed on each fabric switch, you should use the NX-OS
Virtual Shell that is present in the APIC. To access the NX-OS Virtual Shell, open an SSH session to the
out-of-band management IP interface of any of the APIC nodes. From this prompt, execute the "version"
command to obtain a consolidated list of node hostnames.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Look for the switches that the APIC knows about:
apic1# show switch
ID Address In-Band Address OOB Address Version Flags Serial Number
Name
--- ----------- --------------- -------------- ------------ ----- -------------
------
101 10.0.136.64 192.168.1.14 10.122.254.241 n9000-11.2(1 aliv ABC1234DEF5

Operating Cisco Application Centric Infrastructure


19
Management
Verifying that the NTP Policy is Deployed on Each Fabric Switch Using the Object Model CLI

Leaf-1
k)
...

Step 3 Connect to a switch:


apic1# ssh admin@Leaf-1

Step 4 Check the NTP peer status:


Leaf-1# show ntp peer-status
Total peers : 1
* - selected for sync, + - peer mode(active),
- - peer mode(passive), = - polled in client mode
remote local st poll reach delay vrf
-----------------------------------------------------------------------------
*192.168.129.235 0.0.0.0 3 64 377 0.00142 management

A reachable NTP server has its IP address prefixed by an asterisk (*), and the delay is a non-zero value.

Step 5 Repeat steps 3 and 4 for each node on the fabric.

Verifying that the NTP Policy is Deployed on Each Fabric Switch Using the
Object Model CLI
To verify that the policy has been successfully deployed on each fabric switch, you should use the NX-OS
Virtual Shell that is present in the APIC. To access the NX-OS Virtual Shell, open an SSH session to the
out-of-band management IP interface of any of the APIC nodes. From this prompt, execute the "version"
command to obtain a consolidated list of node hostnames.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Switch to the object model CLI:


apic1# bash
admin@apic1:~>

Step 3 Press the Tab key twice after the entering the attach command to list all of the available node names:
admin@apic1:~> attach <Tab> <Tab>
Leaf-1 Node name
Leaf-2 Node name
Spine-1 Node name
apic-1 Node name
apic-2 Node name
apic-3 Node name

Step 4 Log in to one of the nodes using the same password that you used to access the APIC:
admin@apic1:~> attach Leaf-1
# Executing command: ssh Fab2-Leaf1
...

Operating Cisco Application Centric Infrastructure


20
Management
Verifying that the NTP Policy is Deployed on Each APIC Using the NX-OS-Style CLI

Step 5 Check the NTP peer status:


Leaf-1# show ntp peer-status
Total peers : 1
* - selected for sync, + - peer mode(active),
- - peer mode(passive), = - polled in client mode
remote local st poll reach delay vrf
-----------------------------------------------------------------------------
*192.168.129.235 0.0.0.0 3 64 377 0.00142 management

A reachable NTP server has its IP address prefixed by an asterisk (*), and the delay is a non-zero value.

Step 6 Repeat steps 3 and 4 for each node on the fabric.

Verifying that the NTP Policy is Deployed on Each APIC Using the NX-OS-Style
CLI
You can use the NX-OS-style CLI to verify that the policy has been successfully deployed on each Application
Policy Infrastructure Controller (APIC).

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Execute the show ntpq command to obtain a list of NTP servers and their statuses:
apic1# show ntpq
nodeid remote refid st t when poll reach delay offset jitter

------ - ------------- -------- ---- -- ----- ----- ------- ------ ------- -------

1 * 192.168.38.65 .GPS. u 27 64 377 76.427 0.087 0.067


2 * 192.168.38.66 .GPS. u 3 64 377 75.932 0.001 0.021

Verifying that the NTP Policy is Deployed on Each APIC Using the Object Model
CLI
You can use the object model CLI to verify that the policy has been successfully deployed on each APIC.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Switch to the object model CLI:

Operating Cisco Application Centric Infrastructure


21
Management
Domain Name Services (DNS)

apic1# bash
admin@apic1:~>

Step 3 Execute the ntpq -p command to obtain a list of NTP servers and their status:
admin@apic1:~> ntpq -p
remote refid st t when poll reach delay offset jitter
=======================================================================
*adc-mtv5-c1-1.c 192.168.1.5 3 u 58 64 377 1.712 6.180 5.170

Use the man ntpq command on the APIC to see additional commands.

Domain Name Services (DNS)


Setting up a DNS server allows the APIC to resolve various hostnames to IP addresses. This is useful when
integrating VMM domains or other Layer 4 to Layer 7 devices and the hostname is referenced.

Verifying DNS Operation Using the Object Model CLI

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Switch to the object model CLI:


apic1# bash
admin@apic1:~>

Step 3 Check the resolv.conf file:

admin@apic1:~> cat /etc/resolv.conf


# Generated by IFC
search acme.com
nameserver 192.168.168.183
nameserver 192.168.131.10

Step 4 Ping a host by DNS name that will be reachable from the APIC out-of-band management:

admin@apic1:~> ping acme.com


PING acme.com (192.168.4.161) 56(84) bytes of data.
64 bytes from www.acme.com (192.168.4.161): icmp_seq=1 ttl=241 time=42.7 ms
64 bytes from www.acme.com (192.168.4.161): icmp_seq=2 ttl=241 time=42.4 ms
64 bytes from www.acme.com (192.168.4.161): icmp_seq=3 ttl=241 time=43.9 ms
^C
--- acme.com ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2102ms
rtt min/avg/max/mdev = 42.485/43.038/43.903/0.619 ms
admin@apic1:~>

Operating Cisco Application Centric Infrastructure


22
Management
Viewing Control Plane Policing Using the NX-OS-Style CLI

Viewing Control Plane Policing Using the NX-OS-Style CLI


You can use the show system internal aclqos brcm copp entries unit 0 command to view the control plane
policing for the protocols that are listed on a leaf or spine switch. The output from the command helps you
to understand the default behavior of the switch and to monitor switch performance issues due to unnecessary
control plane load. You can use this command for ad hoc monitoring of these parameters to find any
discrepancies in network behavior.
The following example shows output from the command:
module-1# show system internal aclqos brcm copp entries unit 0
Protocol CPUQ Entry-ID Priority Counter-ID Rate Burst GreenPkts
OSPF 1 603 0 603 2000 2000 2584133
EIGRP 30 575 0 575 2000 2000 0

GreenBytes RedPkts RedBytes


373659784 0 0
0 0 0

Role-Based Access Control


Role-based access control (RBAC) and tenancy are important concepts to master when operating a Cisco
Application Centric Infrastructure (ACI) fabric. Role-based access and the concept of tenancy are two core
foundations upon which the ACI management and policy models are built.
In an ACI fabric, the Cisco Application Policy Infrastructure Controller (APIC) grants access to all objects
based on a user's established role in the configuration. Each user can be assigned to a set of roles, a privilege
type, and a security domain. Think of this in terms of Who, What, and Where. The role is the Who (logical
collection of privileges), privileges define What functions a user can perform, and the security domain defines
Where the user can perform these actions. When combining these objects, you can implement very granular
access control in the system.
The role classification is an established grouping of permissions. For example, a fabric-admin can have access
to the entire fabric as well as to assigning other user roles and associate them to security domains, whereas a
tenant-admin can only have access to the components within the tenant to which they're associated, and is
unable to manage other user roles at a fabric wide level. ACME's IT organization fits perfectly into this access
control model.
The APIC provides access according to a user's role through RBAC. An ACI fabric user is associated with
the following:
• A set of roles
• For each role, privileges and privilege types (which can be "no access", "read-only", or "read-write")
• One or more security domain tags that identify the portions of the management information tree (MIT)
that a user can access

Operating Cisco Application Centric Infrastructure


23
Management
Multiple Tenant Support

Figure 2: Authenticated user creation lifecycle

The ACI fabric manages access privileges at the managed object (MO) level. A privilege is an MO that enables
or restricts access to a particular function within the system. For example, fabric-equipment is a privilege
flag. This flag is set by the APIC on all objects that correspond to equipment in the physical fabric.
APIC policies manage the access, authentication, and accounting (AAA) functions of the Cisco ACI fabric.
The combination of user privileges, roles, and security domains with access rights inheritance enables
administrators to configure AAA functions at the managed object level in a very granular fashion. These
configurations can be implemented using the REST API, CLI, or GUI.

Multiple Tenant Support


A core APIC internal data access control system provides multi-tenant isolation and prevents information
privacy from being compromised across tenants. Read/write restrictions prevent any tenant from seeing any
other tenant's configuration, statistics, faults, or event data. Unless the administrator assigns permissions to
do so, tenants are restricted from reading fabric configuration, policies, statistics, faults, or events.
If a virtual machine management (VMM) domain is tagged with a security domain, the users contained in the
security domain can access the corresponding VMM domain. For example, if a tenant named solar is tagged
with the security domain called sun and a VMM domain is also tagged with the security domain called sun,
then users in the solar tenant can access the VMM domain according to their access rights.

Viewing the User Roles Using the GUI


You can view the built-in user roles as well as create custom roles to meet specific requirements.
1. On the menu bar, choose Admin > AAA.
2. In the Navigation pane, choose Security Management Roles. From here, you can see each built-in role
and the associated privileges. Additionally, you can create a custom role from the Actions menu.

Operating Cisco Application Centric Infrastructure


24
Management
Security Domains

Security Domains
The security domain concept is crucial to proper operation of the ACI fabric. By using security domains, users
can be organized into various permission structures, most commonly applied to tenants. Using the tenancy
capabilities of the ACI fabric in conjunction with properly configured security domains, it will be possible to
completely separate configuration of application workloads while only providing access to those who need
it.
A key concept to keep in mind when configuring security domains is that the configuration only applies at a
tenant level. The policies cannot currently be applied to individual objects despite references at the object
level inside of the RBAC screen in the APIC.
Cisco recommends that you configure security domains and access levels prior to deployment of tenants.
Cisco does not recommend that you provide user access configuration by modifing permissions of the "all"
domain. Changes in the "all" domain will affect access permissions for all users. If you need to make selective
changes to allow access outside of a user's security domain, be sure to set up a discrete user access policy just
for that communication.

Creating a Security Domain Using the GUI


There are three security domains that are provisioned by default on the ACI fabric: "all", "common", and
"mgmt". The "all" security domain usually includes access to everything within the management information
tree (MIT). "Common" is usually used when there is a need for shared resources between tenants, such as
DNS or directory services. The "mgmt" security domain is for management traffic policies. You can add
security domains as necessary. For example, for a multi-tenant environment, a security domain would be
created for each tenant. Users are then created and assigned to certain security domains, or tenants.
For more information about the MIT, see the document at the following URL:
http://www.cisco.com/c/en/us/products/collateral/cloud-systems-management/aci-fabric-controller/
white-paper-c11-729586.html
To create a security domain:
1. On the menu bar, choose Admin > AAA.
2. In the Navigation pane, choose Security Management > Security Management.
3. In the Work pane, choose Actions > Create a Security Domain.
4. In the Create a Security Domain dialog box, perform the following actions:
1. Give the security domain a name and an optional description.

Adding Users Using the GUI


You might need to add new users within the ACI fabric. ACI can have local users manually entered by an
admin, or use something such as LDAP, RADIUS, Active Directory, or TACACS+ to specify users that will
be allowed to manage certai,n parts of the ACI network.
Configure Local Users:
1. On the menu bar, choose Admin > AAA.
2. In the Navigation pane, choose AAA Authentication.

Operating Cisco Application Centric Infrastructure


25
Management
Import and Export Policies

3. In the Work pane, in the Realm drop-down list, choose Local and click Submit if Local is not already
chosen.
4. In the Navigation pane, choose Security Management.
5. In the Work pane, choose Actions > Create Local User.
6. In the Create Local User dialog box, perform the following actions:
1. Specify any security information that is necessary and click Next.
2. Select the roles to be given to this user, such as Read/Write for admin or tenant admin, and click Next.
3. Specify login information for the user.

7. Click Finish.

Import and Export Policies


All of the stakeholders at ACME involved in the deployment and administration of the new mobile application
platform need to know that they will be able to easily recover from any loss of configuration quickly and
easily. Since all APIC policies and configuration data can be exported to create backups and tech support files
for Disaster Recovery, troubleshooting, and offline analysis, ACI is a good choice on this front as well. As
with all things APIC, a policy needs to be configured to export or backup the configuration policies. This can
be done from any active and fully fit APIC within the ACI fabric. The backup and restore process does not
require backup of individual components.
Backups are configurable through an export policy that allows either scheduled or immediate backups to a
remote server (preferred) or, in the case where an external SCP/FTP server is not available, backups to be
written to the local APIC file system.
Backup/export policies can be configured to be run on-demand or based on a recurring schedule. Cisco
recommends that a current Backup be performed before making any major system configuration changes or
applying software updates. Configuration Import policies (policy restore) will be discussed later in this section.
By default, all policies and tenants are backed up, but the administrator can optionally specify only a specific
subtree of the management information tree. This is useful in multi-tenant deployments where individual
tenants wish to backup or restore their respective policies.
Another Export policy required on occasion is for gathering technical support information. If issues are
encountered within the system, you might need to contact the Cisco Technical Assistance Center (TAC).
Providing a technical support bundle will give Cisco support engineers the information needed to help identify
and suggest remediation to issues. Technical support export policies can be configured to run on-demand or
scheduled for recurring purposes. Technical support bundles are configured very similar to configuration
export policies, and so the bundles will not be covered in detail here. For details on technical support export
policies, see the Cisco APIC Troubleshooting Guide that is referenced in the Appendix of this book.

Configuration Export (Backup)


Since ACI is policy driven, more than a backup job is required. First, a remote location is created (the external
server to which you want to export information), then an Export policy task, and optionally a Scheduler (for
recurring tasks). The procedure below details how to create a remote location and export policy in ACI to
transfer the configuration file bundle to an SCP server. The individual XML files can be extracted and viewed

Operating Cisco Application Centric Infrastructure


26
Management
Adding a Remote Location (SCP) Using the GUI

after the configuration bundle is transferred to the desktop. An extraction utility is needed to decompress the
tar.gz file that is created.
Figure 3: Configuration Export Policy

Adding a Remote Location (SCP) Using the GUI


1. On the menu bar, choose Admin > Import/Export.
2. In the Navigation pane, choose Remote Locations.
3. In the Work pane, choose Actions > Create Remote Location.
4. In the Create Remote Location dialog box, perform the following actions:
1. Enter a remote location name.
2. Enter a hostname/IP address.
3. Choose a protocol.
4. Enter a remote path.
5. Enter a remote port.
6. Enter a username.
7. Enter a password.
8. Choose a management EPG. The default is Out-of-Band.

5. Click Submit.

Creating a One Time Export Policy Using the GUI


The procedure below details a configuration export policy, but the procedure for a technical support export
policy is similar.
1. On the menu bar, choose Admin > Import/Export.
2. In the Navigation pane, choose Export Policies > Configuration.
3. In the Work pane, choose Actions > Create Configuration Export Policy.
4. In the Create Configuration Export Policy dialog box, perform the following actions:
1. Name = Export_Policy_Name

Operating Cisco Application Centric Infrastructure


27
Management
Verifing That Exporting a Policy was Successful Using the GUI

2. Format = XML
3. Start Now = Yes
4. Export Destination = Choose_the_Remote_location_created_above

5. Click Submit.

Two optional configurations are applying a scheduler policy if you want to setup a recurring operation, and
specifying a specific Distinguished Name (DN) if you want to backup only a subset of the Management
Information Tree (MIT).

Verifing That Exporting a Policy was Successful Using the GUI


1. On the menu bar, choose Admin > Import/Export.
2. In the Navigation pane, choose Export Policies > Configuration > Export_Name.
3. In the Work pane, choose the Operational tab.
1. The State should change from "pending" to "success" when the export completes correctly.
2. (Optional) Confirm on the SCP server that the backup filename exists.

Extracting and Viewing Configuration Files Using the GUI


A configuration export task exports a compressed bundle of individual XML files. These XML configuration
files can be extracted and viewed on another workstation.
1. From the workstation where the exported bundle has been copied, select the archive utility of choice.
2. Navigate to the folder where the config export is located (tar.gz), highlight the file, and then select Extract.
3. Double-click one of the XML files to view the contents in a browser.
4. Examine the various XML configuration files for parameters that have been configured.

Importing a Configuration (Restoring/Merging) Using the GUI


You must have a remote location to import a configuration. If the remote location does not exist, create a
remote location as per the "Adding a Remote Location (SCP)" section.
To restore a configuration from a previous backup:
1. On the menu bar, choose Admin > Import/Export.
2. In the Navigation pane, choose Import Policies > Configuration.
3. In the Work pane, choose Actions > Create Import Configuration Policy.
4. In the Create Import Configuration Policy dialog box, perform the following actions:
1. Enter a name and the filename for the import policy, such as "backup-file.tar.gz". Do not include the
file path.

Operating Cisco Application Centric Infrastructure


28
Management
Rolling Back a Configuration Using the GUI

2. Choose the import type:


• Merge - Will merge backup configuration with existing running configurations. Will not overrite
any existing policies.
• Replace - Will replace all configurations with those only from the backup file.

3. The import mode must be specified when you attempt to perform a Merge import. The configuration
data is imported per shard with each shard holding a certain part of the system configuration objects.
The default is best-effort. The Replace Import Mode can be either:
• best-effort - Each shard is imported, skipping any invalid objects.
• atomic - Attempts to import each shard, skipping those which contain an invalid configuration.
A shard's entire configuration must be valid to be imported in this mode.

4. Choose Start Now.


5. Choose the Remote Location that was previously created in the "Adding a Remote Location (SCP)"
section.

Rolling Back a Configuration Using the GUI


You can take a configuration snapshot of the APIC. This allows for faster rollback of any unwanted
configuration changes. The configuration rollback can be manual or set as a recurring policy. The difference
between a configuration export and configuration rollback is that configuration rollbacks can remain on the
APIC. Configuration exports require an external location, such as an SCP/FTP/SFTP server. Configuration
snapshots can be taken at the fabric or tenant level.
ACME Inc. has decide to configure a daily fabric-wide snapshot of their configuration as a protective measure
in addition to their daily configuration export policy.

Procedure

Step 1 On the menu bar, choose Admin > Config Rollbacks.


Step 2 In the Work pane, click the recurring snapshot policy icon along the top right.
Step 3 In the Automatic Snapshot dialog box, ensure the policy is enabled. Click to toggle Enable/Disable.
Step 4 In the Automatic Snapshot dialog box, select the Days of the Week and Time for the recurring snapshot to
run.
By default, the snapshots will remain stored on the APICs.

Step 5 (Optional) If you prefer for the snapshots be saved to a remote location, you can choose the Remote Location,
or create a new one.
Step 6 Click Submit to save your changes.

Operating Cisco Application Centric Infrastructure


29
Management
Rolling Back a Configuration Using the GUI

Operating Cisco Application Centric Infrastructure


30
CHAPTER 3
Upgrading and Downgrading Firmware
• Firmware Management, on page 31
• Upgrading and Downgrading Considerations, on page 33
• Upgrading the Fabric, on page 34

Firmware Management
ACME Inc., in partnership with Cisco, has evaluated the requirements for their deployment based on the
software features required, the support for the hardware platforms they have selected, and the maturity of the
software releases. They have selected a target version of software for their deployment. Additionally, they
have put a proactive plan in place to revisit this decision periodically to determine if future upgrades are
required.

Firmware Versions
The software versions for Cisco Application Centric Infrastructure (ACI) are listed in the following format:
major.minor(maintenance)

• major—Represents major changes in the product architecture, platform, or features content.


• minor—Represents a minor release with new software features.
• maintenance—Represents bug fixes to a feature release of Application Policy Infrastructure Controller
(APIC). This changes when there are fixes for product defects in the software, but no additional new
features.

The following example shows some APIC versions:


1.0(1e)
1.1(1j)
1.2(1i)

Both the software for the APIC and the fabric nodes are denoted by the same version scheme. For example,
the APIC 1.2(1i) release corresponds to the switch software 11.2(1i) release. The release notes for the APIC
versions reference the corresponding switch versions, and vice versa.
All components of the ACI infrastructure including the APIC, leaf switches, and spine switches, should be
on the same version. While at the time of upgrading, disparate versions may exist between APIC and the
switches, do not operate the fabric for extended periods of time in this state.

Operating Cisco Application Centric Infrastructure


31
Upgrading and Downgrading Firmware
Firmware Components

When considering the impact and risk of upgrading, you can assume that a maintenance version upgrade,
such as upgrading from 1.1(1j) to 1.1(1o), will have less impact than a major/minor version upgrade, as there
will be only bug fixes and no new features added.

Firmware Components
There are three main components that can be upgraded:
• Switches (leaf and spine)
• Application Policy Infrastructure Controller (APIC)
• Catalog firmware

Firmware Policies
Firmware Groups
Firmware group policies on the Application Policy Infrastructure Controller (APIC) define the group of nodes
on which firmware will be upgraded. For most deployments, a single firmware group is adequate.

Maintenance Groups
Maintenance group policies define a group of switches that will be jointly upgraded to the associated firmware
set. Maintenance groups can be upgraded on demand or according to a schedule, making it possible to defer
an upgrade task to a business maintenance window. Typically, there are two maintenance groups, each
containing a set of leafs and spines. Each maintenance group is upgraded separately.

Controller Firmware
The APIC firmware policy applies to all controllers in the cluster, but the upgrade is always done sequentially.
The APIC GUI provides real-time status information about firmware upgrades. Controller firmware policies
can be upgraded on demand or according to a schedule.

Catalog Firmware
Each firmware image includes a compatibility catalog that identifies supported switch models. The APIC
maintains a catalog of the firmware images, switch types, and models that are allowed to use that firmware
image. The APIC, which performs image management, has an image repository for compatibility catalogs,
APIC firmware images, and switch images.

Operating Cisco Application Centric Infrastructure


32
Upgrading and Downgrading Firmware
Upgrading and Downgrading Considerations

Figure 4: Firmware Upgrade Policy Relationships

Upgrading and Downgrading Considerations


Before starting the upgrade or downgrade process, verify the following things:
• Application Policy Infrastructure Controller (APIC) cluster health—Before starting the upgrade process,
your controllers should be in good health. Verify that the health state of all of the controllers in the cluster
are Fully Fit before you proceed. To resolve issues for controllers that are not fully fit see the
Troubleshooting Cisco Application Centric Infrastructure document.
• Configuration backup—Before starting any upgrade, always export your configuration to an external
source. For information about exporting configurations, see the "Import and Export Policies."
• Permissions—A user must have the fabric administrator role to perform firmware upgrade tasks.
• Verify free space—Confirm that the /firmware partition is not filled beyond 75%. If the partition is
filled beyond 75%, you might be required to remove some unused firmware files from the repository to
accommodate the compressed image as well as provide adequate space to extract the image. The APIC
automatically extracts the image.
• Upgrade order—Typically, the controllers should be upgraded first, followed by the switch nodes. Always
refer to the relevant release notes of the destination firmware version for any changes to this order.
• Maintenance windows—Although it is possible to upgrade the fabric without impacting the dataplane,
you should perform an upgrade during a scheduled maintenance window according to your change control
policy. This window should account for any unforeseen issues that might arise during the upgrade, and
allocate enough time to troubleshoot or perform a rollback.
• Maintenance groups—To help minimize the impact to hosts during an upgrade, you should set up at least
two separate maintenance groups. A common separation is by odd and even node IDs. Assuming that
your hosts are dual-connected to at least one odd and one even leaf node, there should not be any impact
to your hosts. Maintenance group creation is covered in detail later in the chapter. Another consideration
is that your leaf vPC pairs should contain one odd and one even node.

Operating Cisco Application Centric Infrastructure


33
Upgrading and Downgrading Firmware
Upgrading the Fabric

• Upgrading a fabric with the Application Virtual Switch (AVS) deployed—The AVS software is not
specifically tied to the APIC or switch software version.
• Device packages—Device packages are not always tied to the APIC software. You can confirm the
device compatibility for Layer 4 to Layer 7 devices using the online Cisco Application Centric
Infrastructure (ACI) Compatibility tool.

Upgrading the Fabric


Downloading the Firmware Images Using the GUI
You must download both the controller software package and switch software package for the Application
Policy Infrastructure Controller (APIC) from Cisco.com.

Procedure

Step 1 On the menu bar, choose Admin > Firmware.


Step 2 In the Navigation Pane, choose Fabric Node Firmware.
In the Work pane, the list of all switches in the fabric and the status of when the firmware was last upgraded
are displayed.

Step 3 In the Navigation Pane, choose Download Tasks.


Step 4 In the Work pane, choose Actions > Create Firmware Download Task.
Step 5 In the Create Firmware Download Task dialog box, perform the following actions:
a) In the Source Name field, enter a name for the switch image, such as "apic_1.2.1i".
b) For the Protocol radio buttons, click the Secure copy or HTTP radio button.
c) In the URL field, enter the URL from where the image must be downloaded.
• HTTP Example: http://192.168.0.50/aci-apic-dk9.1.2.1i.iso
• SCP Example: 192.168.0.50:/tmp/aci-firmware/aci-apic-dk9.1.2.1i.iso
• For SCP, enter your username and password.

d) Click Submit.
Step 6 (Optional) You can instead upload the image from your local machine by performing the following actions:
a) In the Navigation pane, choose Download Tasks.
b) Right click and choose Upload Firmware to APIC.
c) Browse to the image that is saved on your local machine.
d) Click Submit.
Step 7 In the Navigation Pane, choose Download Tasks.
Step 8 In the Work pane, choose the Operational tab to view the download status of the images.
Step 9 Repeat this procedure for the switch image.
Step 10 After the download reaches 100%, in the Navigation pane, choose Firmware Repository.

Operating Cisco Application Centric Infrastructure


34
Upgrading and Downgrading Firmware
Downloading the Firmware Images Using the Object Model CLI

Step 11 In the Work pane, choose the Images tab to view the downloaded version numbers and image sizes.

Downloading the Firmware Images Using the Object Model CLI


You must download both the controller software package and switch software package for the Application
Policy Infrastructure Controller (APIC) from Cisco.com.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Switch to the object model CLI:


apic1# bash
admin@apic1:~>

Step 3 Place the image into the image repository:


admin@apic1:~> firmware add ver_no.iso

Step 4 Verify that the software has been added to the repository:
admin@apic1:~> firmware list
Name : aci-apic-dk9.1.2.1i.bin
Type : controller
Version : 1.2(1i)

Upgrading an APIC Using the GUI


The catalog firmware image is upgraded when an Application Policy Infrastructure Controller (APIC) image
is upgraded. You do not need to upgrade the catalog firmware image separately.
To upgrade an APIC:
1. On the menu bar, choose Admin > Firmware.
2. In the Navigation pane, click Controller Firmware.
3. In the Work pane, choose Actions > Upgrade Controller Firmware Policy.
4. In the Upgrade Controller Firmware Policy dialog box, perform the following actions:
1. In the Target Firmware Version field, from the drop-down list, choose the image version to which
you want to upgrade.
2. In the Apply Policy field, click the Apply now radio button. Alternately, you can apply a schedule
policy if you wish to defer the task to a specific date/time.
3. Click Submit to complete the task.

Operating Cisco Application Centric Infrastructure


35
Upgrading and Downgrading Firmware
Upgrading an APIC Using the NX-OS-Style CLI

The Status dialog box displays the "Changes Saved Successfully" message, and the upgrade process
begins. The APICs are upgraded serially so that the APIC cluster is available during the upgrade.

5. Verify the status of the upgrade in the Work pane.


Each APIC takes about 10 minutes to upgrade. Once an APIC image is upgraded, it drops from the cluster
and reboots with the newer version while the other APICs in the cluster are still operational. Once the
APIC reboots, it joins the cluster again. Then, the cluster converges and the next APIC image starts to
upgrade. If the cluster does not immediately converge, and is not fully fit, the upgrade will wait until the
cluster converges and is Fully Fit. During this period, a "Waiting for Cluster Convergence" message is
displayed in the Status column for each APIC as it upgrades.
When the APIC that the browser is connected to is upgraded and it reboots, the browser displays an error
message.

Note During the upgrade process, while the APIC reboots with the newer image, you will not be able to use the
GUI of that specific APIC. If you are logged into the APIC GUI during the upgrade process, you may receive
a browser error message and may be logged off. Once the status of that specific APIC if Fully Fit, you can
log in to that APIC again.

Upgrading an APIC Using the NX-OS-Style CLI


You can upgrade an Application Policy Infrastructure Controller (APIC) using the NX-OS-style CLI. Before
you upgrade the switches, the APICs must have completed upgrading and have a health state of Fully Fit. In
the NX-OS-style CLI, you must first set the catalog firmware. The following procedure sets the catalog
firmware and starts the upgrade.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure
apic1(config)#

Step 3 Enter the firmware mode:


apic1(config)# firmware
apic1(config-firmware)#

The firmware mode allows you to set the catalog version.

Step 4 Set the catalog version:


apic1(config-firmware)# catalog-version aci-catalog-dk9.1.2.0.225.bin

Now you are ready to update the controller firmware.

Step 5 Enter the controller-group mode and verify the current version:

Operating Cisco Application Centric Infrastructure


36
Upgrading and Downgrading Firmware
Upgrading an APIC Using the Object Model CLI

apic1(config-firmware)# controller-group
apic1(config-firmware-controller)# show version
Role Id Name Version
---------- ---------- ------------------------ --------------------
controller 1 apic1 1.2(0.139g)
controller 2 apic2 1.2(0.139g)
controller 3 apic3 1.2(0.139g)

Step 6 Set the controller firmware to the version that you want:
apic1(config-firmware-controller)# firmware-version aci-apic-dk9.1.2.0.225.bin

Step 7 Start the upgrade.


You can specify a time for the upgrade to start, or you can start the upgrade immediately.
• To specify the time for the upgrade to start, enter:
apic1(config-firmware-controller)# time start 23:30

You must always specify a time; specifying the date is optional.


• To start the upgrade immediately, enter:
apic1(config-firmware-controller)# exit
apic1(config-firmware)# exit
apic1(config)# exit
apic1# firmware upgrade controller-group

Upgrading an APIC Using the Object Model CLI


The catalog firmware image is upgraded when an Application Policy Infrastructure Controller (APIC) image
is upgraded. You do not need to upgrade the catalog firmware image separately. Cisco recommends that you
perform the firmware upgrade from the GUI. When you use the GUI, the APIC performs additional verification
and integrity checks on the software image.
To upgrade an APIC using the object model CLI:
1. List the current software in the repository that was previously downloaded.
Example:
admin@apic1:~> firmware list
Name : aci-apic-dk9.1.1.1j.bin
Type : controller
Version : 1.1(1j)

2. Upgrade the firmware on the APICs.


Example:
admin@apic1:~> firmware upgrade controllers ver_no .bin

The APICs are upgraded serially so that the APIC cluster is available during the upgrade. The upgrade
occurs in the background.
3. Check the status of the upgrade.
Example:

Operating Cisco Application Centric Infrastructure


37
Upgrading and Downgrading Firmware
Upgrading a Switch Using the GUI

admin@apic1:~> firmware upgrade status


Node-Id Role Current- Target- Upgrade- Progress-Percent
Firmware Firmware Status (if inprogress)
--------- ----------- ------------ ------------------ ---------- ------------------
1 controller 1.1(1.200j) apic-1.2(1.202i) complete 0
2 controller 1.1(1.200j) apic-1.2(1.202i) inprogress 0
3 controller 1.1(1.200j) apic-1.2(1.202i) inqueue 0

The Upgrade-Status field will show "inqueue", "inprogress", or "completeok". If you see "unknown" in this
field, the APIC has upgraded and is rebooting. During this time, you may lose connectivity to the APIC CLI
and have to relog in to the CLI.

Upgrading a Switch Using the GUI


Before you upgrade the switches, the Application Policy Infrastructure Controllers (APICs) must have
completed upgrading and have a health state of Fully Fit.
To upgrade a switch using the GUI:
1. On the menu bar, choose Admin > Firmware.
2. In the Navigation pane, choose Fabric Node Firmware.
In the Work pane, the switches that are operating in the fabric are displayed.
3. If you have not created a firmware group, perform the following substeps:
1. In the Navigation pane, choose Fabric Node Firmware > Firmware Groups.
2. In the Work pane, choose the Policy tab.
3. Choose Actions > Create Firmware Group.
4. In the Create Firmware Group dialog box, perform the following actions:
1. In the Group Name field, enter the name of the firmware group.
2. In the Target Firmware Version drop-down list, choose the firmware version to which you will
upgrade.
3. In the Group Node IDs field, enter a comma-separated list or a range of node IDs to include in
the group. For example, "101, 103-105, 108".
4. Click Submit.
5. To verify that the firmware group was created, in the Navigation pane, choose Fabric Node Firmware
> Firmware Groups > new_firmware_group. The Work pane displays details about the firmware
policy that was created earlier.
4. If you have not created maintenance groups, perform the following substeps:
1. In the Navigation pane, choose Fabric Node Firmware > Maintenance Groups.
Cisco recommends that you create two maintenance groups for all of the switches. For example, create
one group with the even-numbered nodes and the other group with the odd-numbered nodes. Ensure
at least one spine and one leaf are in a different maintenance group than others so as not to lose total
connectivity.
2. In the Work pane, choose Action > Create POD Maintenance Group.
3. In the Create POD Maintenance Group dialog box, perform the following actions:
1. In the Group Name field, enter the name of the maintenance group. For example, "Even-Nodes".

Operating Cisco Application Centric Infrastructure


38
Upgrading and Downgrading Firmware
Upgrading a Switch Using the NX-OS-Style CLI

2. For the Run Mode drop-down list, choose Pause Upon Upgrade Failure. This is the default
mode.
3. In the Group Node IDs field, enter a comma-separated list or a range of node IDs to include in
the group. For example, "102, 104, 106, 108, 110".
4. In the Scheduler drop-down list, you can choose to create a schedule for upgrading or leave the
drop-down list blank so that you can upgrade on demand.
5. Click Submit.
6. Repeat this step for the second maintenance group. For example, a group named "Odd-Nodes".
4. Verify that the maintenance group was created.
1. In the Navigation pane, choose Fabric Node Firmware > Maintenance Groups >
new_maintenance_group
2. Choose the name of the maintenance group that you created.
3. In the Work pane, verify that the nodes are attached to that maintenance group.

5. Right-click one of the maintenance groups that you created and choose Upgrade Now.
6. In the Upgrade Now dialog box, for Do you want to upgrade the maintenance group policy now?,
click Yes.
Note: In the Work pane, the Status displays that all the switches in the group are being upgraded
simultaneously. The default concurrency in a group is set at 20. Therefore, up to 20 switches at a time
will get upgraded, and then the next set of 20 switches are upgraded. In case of any failures, the scheduler
pauses and manual intervention is required by the APIC administrator. The switch upgrade takes up to
12 minutes for each group. The switches will reboot when they upgrade, connectivity drops, and the
controllers in the cluster will not communicate for some time with the switches in the group. Once the
switches rejoin the cluster after rebooting, you will see all the switches listed under the controller node.
If there are any VPC configurations in the cluster, the upgrade process will upgrade only one switch at a
time out of the two switches in a vPC domain.
7. In the Navigation pane, click Fabric Node Firmware.
Note: In the Work pane, view all of the switches that are listed. In the Current Firmware column, view
the upgrade image details listed against each switch. Verify that the switches in the fabric are upgraded
to the new image.

Upgrading a Switch Using the NX-OS-Style CLI


You can upgrade a switch using the NX-OS-style CLI. Before you upgrade the switches, the APICs must
have completed upgrading and have a health state of Fully Fit. The following procedure upgrades a switch.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Add images to the firmware repository:


apic1# firmware repository add aci-n9000-dk9.11.2.0.225.bin

Operating Cisco Application Centric Infrastructure


39
Upgrading and Downgrading Firmware
Upgrading a Switch Using the NX-OS-Style CLI

Step 3 Enter the configure mode:


apic1# configure
apic1(config)#

Step 4 Enter the firmware mode:


apic1(config)# firmware
apic1(config-firmware)#

Step 5 Check the firmware version:


apic1(config-firmware)# show version
Role Id Name Version
---------- ---------- ------------------------ --------------------
leaf 101 176-Leaf-1 n9000-11.2(0.65l)
leaf 102 176-Leaf-2 n9000-11.2(0.65l)
spine 201 176-Spine-1 n9000-11.2(0.65l)
spine 202 176-Spine-2 n9000-11.2(0.65l)

Step 6 Enter the firmware-switch mode by creating a switch-group:


apic1(config-firmware)# switch-group EvenNodes
apic1(config-firmware-switch)#

Step 7 Add switches to the switch-group:


apic1(config-firmware-switch)# switch 102, 202

Step 8 (Optional) Verify that the switches were added:


apic1(config-firmware-switch)# show run
# Command: show running-config firmware switch-group all-nodes
# Time: Fri Nov 6 15:18:34 2015
firmware
switch-group EvenNodes
switch 102
switch 202

Step 9 Set the switch firmware to the version that you want:
apic1(config-firmware-controller)# firmware-version aci-apic-dk9.1.2.0.225.bin

Step 10 Set the switch run-mode to pause-on-failure so that the upgrade will pause in the event of any failures:
apic1(config-firmware-switch)# run-mode pause-on-failure

Step 11 Start the upgrade.


You can use a scheduler specify a time for the upgrade to start, or you can start the upgrade immediately.
• To use a scheduler, enter:
apic3(config-firmware-switch)# schedule upgradetimerEvenNodes

• To start the upgrade immediately, go back to execsh mode and enter:


apic1# firmware upgrade switch-group

Operating Cisco Application Centric Infrastructure


40
Upgrading and Downgrading Firmware
Upgrading a Switch Using the Object Model CLI

Upgrading a Switch Using the Object Model CLI


Before you upgrade the switches, the Application Policy Infrastructure Controllers (APICs) must have
completed upgrading and have a health state of Fully Fit.
To upgrade a switch using the object model CLI:
1. Check that the output of the following command appears like the output shown below, with the correct
version number:
Example:
admin@apic1:~> firmware list
Name : aci-n9000-dk9.11.2.1i.bin
Type : switch
Version : 11.2(1i)

The name changes from ".iso" to ".bin".


2. Upgrade the switches.
Example:
admin@apic1:~> firmware upgrade switch node 101 ver_no.bin
Firmware Installation on Switch Scheduled

You must upgrade each switch separately.


3. Check the upgrade status for the switch. The output that appears from the following command will appear
like the following sample:
Example:
admin@apic1:~> firmware upgrade status node node_id
Node-Id Role Current- Target- Upgrade- Progress-Percent

Firmware Firmware Status (if inprogress)


--------- ----------- ------------------- ------------------ ---------- ------------------
1017 leaf n9000-11.1(1.869S1) n9000-11.2(1i) completeok 100

You can check the status of all nodes at once, by entering the firmware upgrade status command.
4. Repeat Steps 2 and 3 for each additional switch.

Verifying Cluster Convergence Using the GUI


You can monitor the progress of the cluster convergence after a scheduled maintenance. You can view the
progress on the Controller Firmware screen of the GUI, which presents you with a series of messages during
the process of converging. These messages are displayed in the Status field.
As the controller and switches move through the upgrade, you will see messages about the number of nodes
queued and the number in the process of upgrading, as well as how many have upgraded successfully.
The following are the possible upgrade states for a node:
• NotScheduled: No upgrade is currently scheduled for this node.
• Scheduled: Upgrade is scheduled for this node.
• Queued: There is a currently active window (schedule) and the node is requesting permission to upgrade.
• Inprogress: Upgrade is currently in progress on this node.
• CompleteOK: Upgrade completed successfully.

Operating Cisco Application Centric Infrastructure


41
Upgrading and Downgrading Firmware
Troubleshooting Failures During the Upgrade Process

• CompleteNOK: Upgrade failed on this node.


• Inretryqueue: Node is queued again for upgrade retry (5 attempts are made before declaring failure).
This may take a while. When all the clusters have converged successfully, you will see "No" in the Waiting
for Cluster Convergence field of the Controller Firmware screen.

Troubleshooting Failures During the Upgrade Process


There is one scheduler per maintenance policy. By default, when an upgrade failure is detected, the scheduler
pauses, and no more nodes in that group begin to upgrade. The scheduler expects manual intervention to
debug any upgrade failures. Once manual intervention is complete, you must resume the paused scheduler.
If you notice that switches are in the "queued" state, then check the following:
• Is the controller cluster healthy? The controller cluster must be healthy. If you see
"waitingForClusterHealth = yes" in the API or "Waiting for Cluster Convergence" showing "Yes" in the
GUI, that means the controller cluster is not healthy. Until the controller cluster is healthy, switches
which have not already started their upgrade will be in "queued" state.
• Is the switch maintenance group paused? The group will be paused if any switch fails its upgrade.
If the system takes longer than about 60 minutes for a switch to display "waitingForClusterHealth = no" in
the API or "Waiting for Cluster Convergence" showing "No" in the GUI, you should work through the steps
for verifying a pause in the scheduler.
For additional troubleshooting procedures, see Troubleshooting Cisco Application Centric Infrastructure.

Operating Cisco Application Centric Infrastructure


42
CHAPTER 4
Fabric Connectivity
• Understanding Fabric Policies, on page 43
• Adding New Devices to the Fabric, on page 50
• Server Connectivity, on page 73
• Virtual Machine Networking, on page 74
• Deploying the Application Virtual Switch, on page 83
• External Connectivity, on page 92
• Application Migration Use Case, on page 99

Understanding Fabric Policies


Now that ACME has been provisioned with ACI fabric and infrastructure space has been configured between
the leaf and spine switches, access privileges, and basic management policies, it is time to start creating
connectivity policies within the ACI fabric. The fabric tab in the APIC GUI is used to configure system-level
features including, but not limited to, device discovery and inventory management, diagnostic tools, configuring
domains, and switch and port behavior. The fabric pane is split into three sections: inventory, fabric policies,
and access policies. Understanding how fabric and access policies configure the fabric is key for the ACME
network teams, as they will be maintaining these policies for the purposes of internal connections between
fabric leaf nodes, connections to external entities such as servers, networking equipment, and storage arrays.
It is important that other teams such as server teams understand these concepts as well, as they will be interacting
with them, particularly in the case of their build processes for adding additional capacity.
This chapter will review the key objects in the access policies subsection of the fabric tab -- many of which
are reusable; demonstrate how to add and pre-provision switches, and walk through the steps and objects
required when new devices are added to the fabric to effectively operate an ACI fabric. While many policies
are reusable, it is also key to understand the implications of deleting policies on the ACI fabric.
The access policies subsection is split into folders separating out different types of policies and objects that
affect fabric behavior. For example, the interface policies folder is where port behavior is configured, like
port speed, or whether or not to run protocols like LACP on leaf switch interfaces is set. Domains and AEPs
are also created in the access policies view. The fabric access policies provide the fabric with the base
configuration of the access ports on the leaf switches.

Operating Cisco Application Centric Infrastructure


43
Fabric Connectivity
Fabric - Access Policies

Fabric - Access Policies


Domains
Endpoint groups are considered the "who" in ACI; contracts are considered the "what/when/why"; AEPs can
be considered the "where" and domains can be thought of as the "how" of the fabric. Different domain types
are created depending on how a device is connected to the leaf switch. There are four different domain types:
physical domains, external bridged domains, external routed domains, and VMM domains.
• Physical domains are generally used for bare metal servers or servers where hypervisor integration is
not an option.
• External bridged domains are used for Layer 2 connections. For example, an external bridged domain
could be used to connect an existing switch trunked-up to a leaf switch.
• External routed domains are used for Layer 3 connections. For example, an external routed domain could
be used to connect a WAN router to the leaf switch.
• Domains act as the glue between the configuration done in the fabric tab to the policy model and endpoint
group configuration found in the tenant pane. The fabric operator creates the domains, and the tenant
administrators associate domains to endpoint groups.

Ideally, policies should be created once and reused when connecting new devices to the fabric. Maximizing
the reusability of policy and objects makes day-to-day operations exponentially faster and easier to make
large-scale changes. The usage of these policies can be viewed by clicking the Show Usage button in the
Application Policy Infrastructure Controller (APIC) GUI. Use this to determine what objects are using a
certain policy to understand the impact when making changes.
For an in-depth whiteboard explanation on domains, watch the following video titled "How Devices Connect
to the Fabric: Understanding Cisco ACI Domains": https://www.youtube.com/watch?v=_iQvoC9zQ_A.

VLAN Pools
VLAN pools contain the VLANs used by the EPGs the domain will be tied to. A domain is associated to a
single VLAN pool. VXLAN and multicast address pools are also configurable. VLANs are instantiated on
leaf switches based on AEP configuration. Allow/deny forwarding decisions are still based on contracts and
the policy model, not subnets and VLANs.

Attachable Access Entity Profiles


Attachable Access Entity Profiles (AEPs) can be considered the "where" of the fabric configuration, and are
used to group domains with similar requirements. AEPs are tied to interface policy groups. One or more
domains can be added to an AEP. By grouping domains into AEPs and associating them, the fabric knows
where the various devices in the domain live and the Application Policy Infrastructure Controller (APIC) can
push the VLANs and policy where it needs to be. AEPs are configured under the global policies section.

Policy Types
Most of the policies folders have subfolders. For example, under the interface policies folder there are folders
for configuration called policies, policy groups, and profiles.

Operating Cisco Application Centric Infrastructure


44
Fabric Connectivity
Policy Types

Switch Policies
There are also policies for switches - for example, configuring vPC domains, which are called explicit vPC
protection groups in the Application Policy Infrastructure Controller (APIC) GUI and vPC policies. Ideally,
policies should be created once and reused when connecting new devices to the fabric. Maximizing reusability
of policy and objects makes day-to-day operations exponentially faster and easier to make large-scale changes.

Switch Policy Groups


Switch policy groups allow leveraging of existing switch policies like Spanning Tree and monitoring policies

Switch Profiles
Switch profiles allow the selection of one or more leaf switches and associate interface profiles to configure
the ports on that specific node. This association pushes the configuration to the interface and creates a Port
Channel or vPC if one has been configured in the interface policy.
The following figure highlights the relationship between the various global, switch, and interface policies:
Figure 5: Relationships to allow a physical interface or interfaces to be attached to an EPG

Interface Policies
Interface policies dictate interface behavior, and are later tied to interface policy groups. For example, there
should be a policy that dictates if CDP is disabled and a policy that dictates if CDP is enabled; these can be
reused as new devices are connected to the leaf switches.

Operating Cisco Application Centric Infrastructure


45
Fabric Connectivity
Policy Types

Interface Policy Groups


Interface policy groups are templates to dictate port behavior and are associated to an AEP. Interface policy
groups use the policies described in the previous paragraph to specify how links should behave. These are
also reusable objects as many devices are likely to be connected to ports that will require the same port
configuration. There are three types of interface policy groups depending on link type: Access Port, Port
Channel, and vPC.
The ports on the leaf switches default to 10GE, and a 1GE link level policy must be created for devices
connected at that speed. Regarding Port Channels and vPC, each policy group designated a single logical
interface on the switches. If you want to create 10 PCs/vPCs, you must create 10 policy groups. Access port
policy groups can be reused between interfaces. Policy groups do not actually specify where the protocols
and port behavior should be implemented. The "where" happens by associating one or more interface profiles
to a switch profile, covered in the following paragraphs.

Interface Profiles
Interface profiles help tie the pieces together. Interface profiles contain blocks of ports - interface selectors -
and are also tied to the interface policy groups described in the previous paragraphs. Again, this is just an
arbitrary port, such as e1/1, the profile must be associated to a specific switch profile to configure the ports.

Layer 2 Interface Policy


In the Cisco APIC release 1.1, a configurable interface policy was added to allow a per port-VLAN significance.
To connect devices to the Cisco Application Centric Infrastructure (Cisco ACI) fabric we can use untagged
traffic, 802.1Q tagged traffic, or VXLAN encapsulation. A per-port VLAN allows the same VLAN to be used
for different endpoint groups, providing that traffic is coming in on a different port. Prior to release 1.1, a
VLAN could only be tied to one endpoint group per leaf.
In traditional networking one of the limitations related to VLAN encapsulation is scalability and reusability
due to the limit of 4096 VLANs in networking devices.
In Cisco ACI, with the default configuration (global), EPGs can use the same VLAN encapsulation as long
as EPGs are bound to separate switches. This allows tenants to re-use VLAN encapsulation IDs through the
fabric without allowing communication between tenants. However, global configuration assumes that tenants
do not share leaf switches and therefore there is no VLAN overlapping within the same leaf.
Per port-VLAN limitations and considerations
• When per port-VLAN is used, a port and VLAN pair (P,V) is registered internally instead of just a VLAN
encapsulation ID. This increases the consumption of hardware resources at a per switch level.
• Two EPGs belonging to a single bridge domain cannot share the same encapsulation ID on a given leaf
switch.
• It is expected that the port will flap when the Layer 2 interface policy changes between global and local.
That is, traffic will get affected.

DWDM-SFP10G-C Optic Interface Policy


The Cisco APIC release 3.1(1) added support for the DWDM-SFP10G-C optic, which includes an interface
policy for the optic. When a DWDM-SFP10G-C port is inserted, the port by default has channel number 32.
In the DWDM-SFP10G-C optic interface policy, you can change the channel number to any number between
1 to 96, which tunes the optic to the corresponding wavelength.

Operating Cisco Application Centric Infrastructure


46
Fabric Connectivity
Policy Types

Table 1: DWDM-SFP10G-C Port Wavelength by Channel

Channel Number Frequency (THz) Wavelength (nm)

1 191.35 1566.72
2 191.40 1566.31
3 191.45 1565.90
4 191.50 1565.50
5 191.55 1565.09
6 191.60 1564.68
7 191.65 1564.27
8 191.70 1563.86
9 191.75 1563.45
10 191.80 1563.05
11 191.85 1562.64
12 191.90 1562.23
13 191.95 1561.83
14 192.00 1561.42
15 192.05 1561.01
16 192.10 1560.61
17 192.15 1560.20
18 192.20 1559.79
19 192.25 1559.39
20 192.30 1558.98
21 192.35 1558.58
22 192.40 1558.17
23 192.45 1557.77
24 192.50 1557.36
25 192.55 1556.96
26 192.60 1556.55
27 192.65 1556.15
28 192.70 1555.75
29 192.75 1555.34
30 192.80 1554.94
31 192.85 1554.54

Operating Cisco Application Centric Infrastructure


47
Fabric Connectivity
Policy Types

Channel Number Frequency (THz) Wavelength (nm)

32 192.90 1554.13
33 192.95 1553.73
34 193.00 1553.33
35 193.05 1552.93
36 193.10 1552.52
37 193.15 1552.12
38 193.20 1551.72
39 193.25 1551.32
40 193.30 1550.92
41 193.35 1550.52
42 193.40 1550.12
43 193.45 1549.72
44 193.50 1549.32
45 193.55 1548.91
46 193.60 1548.51
47 193.65 1548.11
48 193.70 1547.72
49 193.75 1547.32
50 193.80 1546.92
51 193.85 1546.52
52 193.90 1546.12
53 193.95 1545.72
54 194.00 1545.32
55 194.05 1544.92
56 194.10 1544.53
57 194.15 1544.13
58 194.20 1543.73
59 194.25 1543.33
60 194.30 1542.94
61 194.35 1542.54
62 194.40 1542.14
63 194.45 1541.75

Operating Cisco Application Centric Infrastructure


48
Fabric Connectivity
Policy Types

Channel Number Frequency (THz) Wavelength (nm)

64 194.50 1541.35
65 194.55 1540.95
66 194.60 1540.56
67 194.65 1540.16
68 194.70 1539.77
69 194.75 1539.37
70 194.80 1538.98
71 194.85 1538.58
72 194.90 1538.19
73 194.95 1537.79
74 195.00 1537.40
75 195.05 1537.00
76 195.10 1536.61
77 195.15 1536.22
78 195.20 1535.82
79 195.25 1535.43
80 195.30 1535.04
81 195.35 1534.64
82 195.40 1534.25
83 195.45 1533.86
84 195.50 1533.47
85 195.55 1533.07
86 195.60 1532.68
87 195.65 1532.29
88 195.70 1531.90
89 195.75 1531.51
90 195.80 1531.12
91 195.85 1530.72
92 195.90 1530.33
93 195.95 1529.94
94 196.00 1529.55
95 196.05 1529.16

Operating Cisco Application Centric Infrastructure


49
Fabric Connectivity
Best Practices

Channel Number Frequency (THz) Wavelength (nm)

96 196.10 1528.77

Best Practices
Cisco has established several best practices for fabric configuration. These are not requirements and might
not work for all environments or applications, but might help simplify day-to-day operation of the Cisco
Application Centric Infrastructure (ACI) fabric.
• Policies
• Reuse policies whenever possible. For example, there should be policies for LACP active/passive/off,
1GE port speed, and 10GE port speed.
• When naming policies, use names that clearly describe the setting. For example, a policy that enables
LACP in mode active could be called "LACP-Active". There are many "default" policies out of the
box. However, it can be hard to remember what all the defaults are, which is why policies should
be clearly named to avoid making a mistake when adding new devices to the fabric.
• Create a switch profile for each leaf switch individually, and additionally, create a switch profile
for each vPC pair (if using vPC).
• Domains
• Build one physical domain per tenant for bare metal servers or servers without hypervisor integration
requiring similar treatment.
• Build one physical domain per tenant for external connectivity.
• If a VMM domain needs to be leveraged across multiple tenants, a single VMM domain can be
created and associated with all leaf ports where VMware ESXi servers are connected.
• AEPs
• Multiple domains can be associated to a single AEP for simplicity's sake. There are some cases
where multiple AEPs may need to be configured to enable the infrastructure VLAN, such as
overlapping VLAN pools, or to limit the scope of the presence of VLANs across the fabric.

Adding New Devices to the Fabric


This section will demonstrate how to configure ACI to re-use the fabric access policies, simplifying day-to-day
operation of the fabric. This section will walk through setting up profiles from scratch, with a focus on how
to re-use these profiles across the fabric. As outlined in the previous section, these various profiles are linked
together and have dependencies. The following diagram reiterates the object relationships:

Operating Cisco Application Centric Infrastructure


50
Fabric Connectivity
Adding New Devices to the Fabric

Figure 6: Object relationships

Whereas a traditional command line interface on a switch generally requires a port-by-port confuguration,
ACI allows definition of objects and policies that can be re-used. The re-usability of these policies makes it
possible to replicate the configuration of a switch very easily. The following diagram depicts how this
re-usability simplifies the operation of the fabric over time.
Figure 7: Policy Re-use

In any data center, the configuration of a couple of switches does not require many processes or automation.
As the data center size increases, automation becomes more and more critical as it has a direct impact on the
cost of business operations. In traditional networks, when changes that impact a large set of devices need to
be made, the operator is faced with the cost of designing processes to manage these devices. These can be
network management tools, scripts, or specialized applications. Leveraging the Cisco ACI policy model, an
operator can leverage profiles to streamline the operation of adding devices and managing those devices. This
is what is depicted as the policy re-use inflection point in the previous diagram.

Operating Cisco Application Centric Infrastructure


51
Fabric Connectivity
Sample Configuration

Sample Configuration
The following sections will walk through sample configuration of setting up individually connected devices,
Port Channel-connected devices, and vPC-connected devices from scratch, and will include a review of the
objects as they are configured. These are the steps to be taken in the APIC GUI when new devices are connected
to the leaf switches to ensure the access ports on the leaf switches have the right switchport configuration,
and the verification steps to ensure proper configuration. The following steps represent the use case of adding
a new bare metal server connected to a leaf switch.
Before getting into the configuration of vPC's, which are a popular server connectivity methodology, it is
important to understand what vPC's are and how they are different from traditional methods of server
connectivity. This section of the chapter attempts to clarify at a high level what vPC's are, the benefits they
provide and how vPC's in the ACI fabric differ from how they are deployed on Cisco Nexus switches running
NX-OS software.
At a high level, vPC extends link aggregation to two separate physical switches.
Figure 8: vPC Topology

In the figure above, a single server is dual homed to two different switches for redundancy. Without vPC's,
the server will likely use an active-standby configuration, or a special configuration on the NIC driver or the
kernel that allows it to intelligently load-balance traffic using an algorithm.
By configuring ports on two different switches as the same port-channel and using an inter-switch messaging
channel (such as the inter-switch port-channel in the green box on the left hand side) to cover redundancy
scenarios, we provide a logical topology that greatly simplifies server provisioning and management.
This allows for several key advantages from a server deployment perspective:
• You can create resilient Layer 2 topologies based on link aggregation
• You do not need STP
• You have increased bandwidth, as all links are actively forwarding
• Your server configurations are simplified since the configurations simply appears as port-channels without
the need for special software, from a driver or kernel-tuning standpoint
vPCs can also be used to connect other downstream devices, such as Cisco UCS fabric-interconnects, to
provide similar benefits.
The figure below shows a single traditional Layer 2 switch connected to a VPC enabled Cisco switch pair.

Operating Cisco Application Centric Infrastructure


52
Fabric Connectivity
Sample Configuration

Figure 9: Legacy connectivity compared to vPC

The components of a traditional vPC domain are illustrated below:


Figure 10: Traditional vPC topology

As illustrated above, in Cisco switching products running NX-OS software, vPC configurations need to be
done manually by the operator and require a pair of dedicated "inter-switch" links also called a peer-link.
There is also a peer-keepalive link, typically on the out-of-band management port, that is used to determine
peer liveliness to detect a vPC peer-switch failure. Making configuration changes in such scenarios without
the config-sync feature enabled may lead to scenarios where there are mismatched vPC parameters between
the vPC primary and the vPC secondary switches that may cause partial connectivity loss during the change
itself if a type-1 inconsistency is detected.
The ACI fabric greatly simplifies VPC configurations.

Operating Cisco Application Centric Infrastructure


53
Fabric Connectivity
Sample Configuration

Figure 11: vPC topology in ACI

The key differences to note here are that relative to traditional vPC design, there is no requirement for setting
up vPC peer-links. There are also no keepalives being sent on the management ports. The fabric itself serves
as the peer-link. The rich interconnectivity between fabric nodes makes it unlikely that peers will have an
active path between them.
Note that attempting to cable a leaf switch to another leaf switch will lead to a "wiring mismatch" fault in the
GUI and result in a blacklisted port that will have to be manually recovered.
The following are some other key behavioral changes to vPC as it applies to the ACI fabric relative to classic
vPC that are important for operators to understand:
• Configurations are automatically synchronized to avoid an error-free configuration by the APIC which
is the central point of control for all configurations in the ACI fabric.
• In traditional vPC solution, the slave switch brings down all its vPC links if the MCT goes down.
• In the ACI fabric, it is very unlikely that all the redundant paths between vPC peers fail at the same time.
Hence if the peer switch becomes unreachable, it is assumed to have crashed. The slave switch does not
bring down vPC links.
• Role election still happens, peers assume master-slave roles.
• Role is used in case of vpc type-1 consistency failure. Slave switch brings down all its vPC ports. A list
of type-1 parameters used for consistency checking for a given vPC domain specific to the ACI fabric
are listed below.
• Global type-1 parameters:
• STP
• Interface type-1 parameters:
• STP: Only BPDU Guard is configurable
• EthPM
• Port speed
• Duplex mode
• Port mode
• MTU
• Native VLAN
• PCM: Channel mode, static vs lacp

Operating Cisco Application Centric Infrastructure


54
Fabric Connectivity
Creating VLAN Pools

• LACP: Lag ID

The following diagrams illustrate how the ACI fabric forwards traffic from a vPC domain to a non-vPC
connected host in the fabric, and vice-versa.
Figure 12: vPC forwarding

Unicast packet flow H2 -> H1


1. H2 sends a pkt towards H1 on its link to S3.
2. S3 does a table lookup and routes with vPC Virtual IP (VIP).
3. Spine switch sees multiple routes for VIP and picks one of them (S2 in this case).
4. S2 delivers the pkt to locally attached host H1.
H1 -> H2
1. H1 sends a pkt towards H2 on one of its PC link (S1 in this case).
2. S1 does a table lookup and routes with IP of S3.
3. Spine switch routes to S3.
4. S3 delivers the pkt to locally attached host H2.

Creating VLAN Pools


In this example, configuring newly-connected bare metal servers first requires creation of a physical domain
and then association of the domain to a VLAN pool. As mentioned in the previous section, VLAN pools
define a range of VLAN IDs that will be used by the EPGs.
The servers are connected to two different leaf nodes in the fabric. Each server will be tagging using 802.1Q
or VXLAN encapsulation. The range of VLANs used in the configuration example is 100-199. As depicted
in the following figure, the ACI fabric can also act as a gateway between disparate encapsulation types such
as untagged traffic, 802.1Q VLAN tags, VXLAN VNIDs, and NVGRE tags. The leaf switches normalize the
traffic by stripping off tags and reapplying the required tags on fabric egress. In ACI, it is important to
understand that the definition of VLANs as they pertain to the leaf switch ports is utilized only for identification
purposes. When a packet arrives ingress to a leaf switch in the fabric, ACI has to know beforehand how to
classify packets into the different EPGs, using identifiers like VLANs, VXLAN, NVGRE, physical port IDs,
virtual port IDs.

Operating Cisco Application Centric Infrastructure


55
Fabric Connectivity
Creating a VLAN Pool Using the GUI

Figure 13: Encapsulation normalization

Creating a VLAN Pool Using the GUI


This procedure creates a VLAN pool using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Pools > VLAN.
Step 3 In the Work pane, choose Actions > Create VLAN Pool.
Step 4 In the Create VLAN Pool dialog box, perform the following actions:
a) Enter a name for the VLAN pool.
b) (Optional) Enter a description for the VLAN pool.
c) Choose an allocation mode:
• Dynamic Allocation—The Application Policy Infrastructure Controller (APIC) selects VLANs from
the pool dynamically. This is common in VMM integration mode where the actual VLAN ID is not
important since policies are applied to the EPG itself.
• Static Allocation—This is typically used when the pool will be referenced from a static source, such
as a static path binding for an EPG for use with bare metal servers.

d) Add one or more encapsulation blocks.


The encapsulation blocks define the range of VLANs in the VLAN pool. Multiple ranges can be added
to a single pool. Choose an allocation mode for each encapsulation block:
• Dynamic Allocation—The Application Policy Infrastructure Controller (APIC) selects VLANs from
the pool dynamically. This is common in VMM integration mode where the actual VLAN ID is not
important since policies are applied to the EPG itself.
• Inherit Allocation Mode from parent—The encapsulation block inherits its mode based on the
VLAN pool.
• Static Allocation—This is typically used when the pool will be referenced from a static source, such
as a static path binding for an EPG for use with bare metal servers.

Operating Cisco Application Centric Infrastructure


56
Fabric Connectivity
Creating a VLAN Pool Using the REST API

Step 5 Click Submit.

Creating a VLAN Pool Using the REST API


The following example REST request creates a VLAN pool:
<fvnsVlanInstP allocMode="static" childAction="" configIssues="" descr=""
dn="uni/infra/vlanns-[bsprint-vlan-pool]-static" lcOwn="local"
modTs="2015-02-23T15:58:33.538-08:00"
monPolDn="uni/fabric/monfab-default" name="bsprint-vlan-pool"
ownerKey="" ownerTag="" status="" uid="8131">
<fvnsRtVlanNs childAction="" lcOwn="local" modTs="2015-02-25T11:35:33.365-08:00"
rn="rtinfraVlanNs-[uni/l2dom-JC-L2-Domain]" status="" tCl="l2extDomP"
tDn="uni/l2dom-JC-L2-Domain"/>
<fvnsRtVlanNs childAction="" lcOwn="local" modTs="2015-02-23T16:13:22.007-08:00"
rn="rtinfraVlanNs-[uni/phys-bsprint-PHY]" status="" tCl="physDomP"
tDn="uni/physbsprint-PHY"/>
<fvnsEncapBlk childAction="" descr="" from="vlan-100" lcOwn="local"
modTs="2015-02-23T15:58:33.538-08:00"
name="" rn="from-[vlan-100]-to-[vlan-199]" status="" to="vlan-199" uid="8131"/>
</fvnsVlanInstP>

Creating a Physical Domain


A physical domain acts as the link between the VLAN pool and the Access Entity Profile (AEP). The domain
also ties the fabric configuration to the tenant configuration, as the tenant administrator is the one who associates
domains to EPGs, while the domains are created under the fabric tab. When configuring in this order, only
the profile name and the VLAN pool are configured. The creation of the AEP and its association will be
covered later in this section.
XML Object

<physDomP childAction="" configIssues="" dn="uni/phys-bsprint-PHY" lcOwn="local"


modTs="2015-02-23T16:13:21.906-08:00" monPolDn="uni/fabric/monfab-default"
name="bsprint-PHY" ownerKey="" ownerTag="" status="" uid="8131">
<infraRsVlanNs childAction="" forceResolve="no" lcOwn="local" modTs="2015-02-
23T16:13:22.065-08:00" monPolDn="uni/fabric/monfab-default" rType="mo" rn="rsvlanNs"
state="formed" stateQual="none" status="" tCl="fvnsVlanInstP" tDn="uni/infra/vlanns-
[bsprint-vlan-pool]-static" tType="mo" uid="8131"/>
<infraRsVlanNsDef childAction="" forceResolve="no" lcOwn="local" modTs="2015-02-
23T16:13:22.065-08:00" rType="mo" rn="rsvlanNsDef" state="formed" stateQual="none"
status="" tCl="fvnsAInstP" tDn="uni/infra/vlanns-[bsprint-vlan-pool]-static"
tType="mo"/>
<infraRtDomP childAction="" lcOwn="local" modTs="2015-02-23T16:13:52.945-08:00"
rn="rtdomP-[uni/infra/attentp-bsprint-AEP]" status="" tCl="infraAttEntityP"
tDn="uni/infra/attentp-bsprint-AEP"/>
</physDomP>

Creating an Attachable Access Entity Profile Using the GUI


This procedure creates an attachable access entity profile (AEP) using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Global Policies > Attached Acess Entity Profle.

Operating Cisco Application Centric Infrastructure


57
Fabric Connectivity
Creating an Attachable Access Entity Profile Using the REST API

Step 3 In the Work pane, choose Actions > Create Attached Entity Profile.
Step 4 In the Create Attached Entity Profile dialog box, perform the following actions:
a) Enter a name for the AEP.
b) (Optional) Enter a description for the AEP.
c) Put a check in the Enable Infrastructure VLAN box if you want to allow the infrastructure VLAN to
be passed over the links that are associated with this AEP.
d) Click + to associate the domain to the AEP.
e) Choose the physical domain that was previously configured.
Step 5 Click Next.
Step 6 Click Submit.

Creating an Attachable Access Entity Profile Using the REST API


The following example REST request creates an attachable access entity profile (AEP):
<infraAttEntityP childAction="" configIssues="" descr="" dn="uni/infra/attentpbsprint-AEP"
lcOwn="local" modTs="2015-02-23T16:13:52.874-08:00" monPolDn="uni/fabric/monfab-default"
name="bsprint-AEP" ownerKey="" ownerTag="" status="" uid="8131">
<infraContDomP childAction="" lcOwn="local" modTs="2015-02-23T16:13:52.874-08:00"
rn="dompcont" status="">
<infraAssocDomP childAction="" dompDn="uni/phys-bsprint-PHY" lcOwn="local"
modTs="2015-02-23T16:13:52.961-08:00" rn="assocdomp-[uni/phys-bsprint-PHY]"
status=""/>
<infraAssocDomP childAction="" dompDn="uni/l2dom-JC-L2-Domain" lcOwn="local"
modTs="2015-02-25T11:35:33.570-08:00" rn="assocdomp-[uni/l2dom-JC-L2-Domain]"
status=""/>
</infraContDomP>
<infraContNS childAction="" lcOwn="local" modTs="2015-02-23T16:13:52.874-08:00"
monPolDn="uni/fabric/monfab-default" rn="nscont" status="">
<infraRsToEncapInstDef childAction="" deplSt="" forceResolve="no" lcOwn="local"
modTs="2015-02-23T16:13:52.961-08:00" monPolDn="uni/fabric/monfabdefault"
rType="mo" rn="rstoEncapInstDef-[allocencap-[uni/infra]/encapnsdef-
[uni/infra/vlanns-[bsprint-vlan-pool]-static]]" state="formed" stateQual="none"
status="" tCl="stpEncapInstDef" tDn="allocencap-[uni/infra]/encapnsdef-
[uni/infra/vlanns-[bsprint-vlan-pool]-static]" tType="mo">
<fabricCreatedBy childAction="" creatorDn="uni/l2dom-JC-L2-Domain"
deplSt="" domainDn="uni/l2dom-JC-L2-Domain" lcOwn="local" modTs="2015-02-
25T11:35:33.570-08:00" monPolDn="uni/fabric/monfab-default" profileDn=""
rn="source-[uni/l2dom-JC-L2-Domain]" status=""/>
<fabricCreatedBy childAction="" creatorDn="uni/phys-bsprint-PHY" deplSt=""
domainDn="uni/phys-bsprint-PHY" lcOwn="local"
modTs="2015-02-23T16:13:52.961-08:00"
monPolDn="uni/fabric/monfab-default" profileDn=""
rn="source-[uni/phys-bsprint-PHY]"
status=""/>
</infraRsToEncapInstDef>
</infraContNS>
<infraRtAttEntP childAction="" lcOwn="local" modTs="2015-02-24T11:59:37.980-08:00"
rn="rtattEntP-[uni/infra/funcprof/accportgrp-bsprint-AccessPort]" status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-bsprint-AccessPort"/>
<infraRsDomP childAction="" forceResolve="no" lcOwn="local" modTs="2015-02-
25T11:35:33.570-08:00" monPolDn="uni/fabric/monfab-default" rType="mo"
rn="rsdomP-[uni/l2dom-JC-L2-Domain]" state="formed" stateQual="none" status=""
tCl="l2extDomP" tDn="uni/l2dom-JC-L2-Domain" tType="mo" uid="8754"/>
<infraRsDomP childAction="" forceResolve="no" lcOwn="local"
modTs="2015-02-23T16:13:52.961-08:00" monPolDn="uni/fabric/monfab-default" rType="mo"

Operating Cisco Application Centric Infrastructure


58
Fabric Connectivity
Create Interface Policies

rn="rsdomP-[uni/phys-bsprint-PHY]" state="formed" stateQual="none" status=""


tCl="physDomP"
tDn="uni/phys-bsprint-PHY" tType="mo" uid="8131"/>
</infraAttEntityP>

Create Interface Policies


Next, define the interface profiles and showcase the re-usability of the fabric policies. Interface policies can
be re-used as needed by different interface profile definition requirements. This section will illustrate creation
of new profiles, but ideally there are already policies in place that can simply be selected.

Creating a Link Level Policy


Link level policies dictate configuration like the speed of ports.
XML Object

<fabricHIfPol autoNeg="on" childAction="" descr="" dn="uni/infra/hintfpol-1G-Auto"


lcOwn="local" linkDebounce="100" modTs="2015-01-14T06:47:15.693-08:00" name="1G-Auto"
ownerKey="" ownerTag="" speed="1G" status="" uid="15374">
<fabricRtHIfPol childAction="" lcOwn="local" modTs="2015-01-14T06:48:48.081-
08:00" rn="rtinfraHIfPol-[uni/infra/funcprof/accportgrp-UCS-1G-PG]" status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-UCS-1G-PG"/>
<fabricRtHIfPol childAction="" lcOwn="local" modTs="2015-02-25T11:48:11.331-
08:00" rn="rtinfraHIfPol-[uni/infra/funcprof/accportgrp-L3-Example]" status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-L3-Example"/>
</fabricHIfPol>

Creating a CDP Interface Policy


XML Object

<cdpIfPol adminSt="enabled" childAction="" descr="" dn="uni/infra/cdpIfP-CDP-Enable"


lcOwn="local" modTs="2015-01-14T06:47:25.470-08:00" name="CDP-Enable" ownerKey=""
ownerTag="" status="" uid="15374">
<cdpRtCdpIfPol childAction="" lcOwn="local" modTs="2015-01-14T07:23:54.957-
08:00" rn="rtinfraCdpIfPol-[uni/infra/funcprof/accportgrp-UCS-10G-PG]" status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-UCS-10G-PG"/>
<cdpRtCdpIfPol childAction="" lcOwn="local" modTs="2015-02-24T14:59:11.154-
08:00" rn="rtinfraCdpIfPol-[uni/infra/funcprof/accbundle-ACI-VPC-IPG]" status=""
tCl="infraAccBndlGrp" tDn="uni/infra/funcprof/accbundle-ACI-VPC-IPG"/>
<cdpRtCdpIfPol childAction="" lcOwn="local" modTs="2015-01-14T06:48:48.081-
08:00" rn="rtinfraCdpIfPol-[uni/infra/funcprof/accportgrp-UCS-1G-PG]" status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-UCS-1G-PG"/>
<cdpRtCdpIfPol childAction="" lcOwn="local" modTs="2015-02-24T11:59:37.980-
08:00" rn="rtinfraCdpIfPol-[uni/infra/funcprof/accportgrp-bsprint-AccessPort]"
status="" tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-bsprint-
AccessPort"/>
<cdpRtCdpIfPol childAction="" lcOwn="local" modTs="2015-02-25T11:48:11.331-
08:00" rn="rtinfraCdpIfPol-[uni/infra/funcprof/accportgrp-L3-Example]" status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-L3-Example"/>
</cdpIfPol>

Creating an LLDP Interface Policy


XML Object

<lldpIfPol adminRxSt="enabled" adminTxSt="enabled" childAction=""


descr=""
dn="uni/infra/lldpIfP-LLDP-Enable" lcOwn="local" modTs="2015-02-11T07:40:35.664-08:00"

Operating Cisco Application Centric Infrastructure


59
Fabric Connectivity
Creating a Port Channel Policy Using the GUI

name="LLDP-Enable" ownerKey="" ownerTag="" status="" uid="15374">


<lldpRtLldpIfPol childAction="" lcOwn="local" modTs="2015-02-24T14:59:11.154-
08:00" rn="rtinfraLldpIfPol-[uni/infra/funcprof/accbundle-ACI-VPC-IPG]"
status=""
tCl="infraAccBndlGrp" tDn="uni/infra/funcprof/accbundle-ACI-VPC-IPG"
/>
<lldpRtLldpIfPol childAction="" lcOwn="local" modTs="2015-02-25T11:48:11.331-
08:00" rn="rtinfraLldpIfPol-[uni/infra/funcprof/accportgrp-L3-Example]"
status=""
tCl="infraAccPortGrp" tDn="uni/infra/funcprof/accportgrp-L3-Example"
/>
</lldpIfPol>

Creating a Port Channel Policy Using the GUI


This procedure creates a Port Channel policy using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Interface Policies > Policies > Port Channel Policies.
Step 3 In the Work pane, choose Actions > Create Port Channel Policy.
Step 4 In the Create Port Channel Policy dialog box, perform the following actions:
a) Enter a name for the Port Channel policy.
b) (Optional) Enter a description for the Port Channel policy.
c) Choose the LACP mode that is required for the server.
If LACP is enabled on the leaf switch, LACP must also be enabled on the server or other connected device.
d) (Optional) Choose a control state.
e) (Optional) Specify the minimum and maximum number of links in the Port Channel.
Note Click i icon in the top-right corner of the Create Port Channel Policy dialog box to access the
Cisco APIC Online Help file and view the full list of options.

Step 5 Click Submit.

Creating a Port Channel Policy Using the REST API


The following example REST request creates a Port Channel policy:
<lacpLagPol childAction="" ctrl="fast-sel-hot-stdby,graceful-conv,susp-individual"
descr="" dn="uni/infra/lacplagp-LACP-Active" lcOwn="local" maxLinks="16" minLinks="1"
modTs="2015-02-24T11:58:36.547-08:00" mode="active" name="LACP-Active" ownerKey=""
ownerTag="" status="" uid="8131">
<lacpRtLacpPol childAction="" lcOwn="local" modTs="2015-02-24T14:59:11.154-08:00"
rn="rtinfraLacpPol-[uni/infra/funcprof/accbundle-ACI-VPC-IPG]" status=""
tCl="infraAccBndlGrp" tDn="uni/infra/funcprof/accbundle-ACI-VPC-IPG"/>
</lacpLagPol>

Operating Cisco Application Centric Infrastructure


60
Fabric Connectivity
Creating a Port Channel Member Profile Using the GUI (Optional)

Note • To enable symmetric hashing, add ctrl="symmetric-hash" to the REST request.


• Symmetric hashing is not supported on the following switches:
• Cisco Nexus 93128TX
• Cisco Nexus 9372PX
• Cisco Nexus 9372PX-E
• Cisco Nexus 9372TX
• Cisco Nexus 9372TX-E
• Cisco Nexus 9396PX
• Cisco Nexus 9396TX

Creating a Port Channel Member Profile Using the GUI (Optional)


This procedure creates a Port Channel member profile using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Interface Policies > Policies > Port Channel Member Policies.
Step 3 In the Work pane, choose Actions > Create Port Channel Member Policy.
Step 4 In the Create Port Channel Member Policy dialog box, perform the following actions:
a) Enter a name for the policy.
b) (Optional) Enter a description for the policy.
c) If required, change the priority.
d) If required, change the transmit rate.
Step 5 Click Submit.

Creating a Spanning Tree Interface Policy Using the GUI (optional)


The Spanning Tree policy dictates the behavior of southbound leaf port Spanning Tree features. It is a common
best practice to enable BPDU guard on interfaces connected to servers.

Note ACI does not run Spanning Tree on the fabric between the leaves and spines. The Spanning Tree interface
policy simply defines the port behavior.

1. On the menu bar, choose Fabric > Access Policies.


2. In the Navigation pane, choose Interface Policies > Policies > Spanning Tree Interface.

Operating Cisco Application Centric Infrastructure


61
Fabric Connectivity
Creating a Storm Control Policy Using the GUI (optional)

3. In the Work pane, choose Actions > Create Spanning Tree Interface Policy.
4. In the Create Spanning Tree Interface Policy dialog box, perform the following actions:
1. Define a meaningful name for the policy.
2. Optionally, provide a description for the policy.
3. Enable BPDU filter and/or BPDU guard.

5. Click Submit.

Creating a Storm Control Policy Using the GUI (optional)


A traffic storm occurs when packets flood the LAN, creating excessive traffic and degrading network
performance. The traffic storm control feature can be used to prevent disruptions on ports by a broadcast,
multicast, or unicast traffic storm on physical interfaces.
1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Interface Policies > Policies > Storm Control.
3. In the Work pane, choose Actions > Create Storm Control Policy.
4. In the Create Storm Control Policy dialog box, perform the following actions:
1. Define a meaningful name for the policy.
2. Optionally, provide a description for the policy.
3. Specify how the control policy is to be applied, either through percentage of the total bandwidth or
as a packet per second definition that matches the requirement for the data center.

5. Click Submit.

Creating a Mis-cabling Protocol Interface Policy Using the GUI (Optional)


The mis-cabling protocol (MCP) was designed to handle misconfigurations that Link Layer Discovery Protocol
(LLDP) and Spanning Tree Protocol (STP) are unable to detect. MCP has a Layer 2 packet that it uses, and
MCP disables ports that form a loop within the Fabric. Cisco Application Centric Infrastructure (ACI) fabric
leafs do not participate in spanning tree protocol (STP) and act as hub with respect to STP. The untagged
MCP packet is sent, and if the fabric sees that the packet comes back in, then the fabric knows that there is a
loop and the fabric takes action based on that event. Faults and events are generated when this happens. MCP
can be enabled globally and per-interface. By default, MCP is disabled globally and is enabled on each port.
For MCP to work, it must be enabled globally, regardless of the per-interface configuration.
The following procedure creates an MPC interface policy using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Interface Policies > Policies > MCP Interface.
Step 3 In the Work pane, choose Actions > Create Mis-cabling Protocol Interface Policy.
Step 4 In the Create Mis-cabling Protocol Interface Policy dialog box, perform the following actions:

Operating Cisco Application Centric Infrastructure


62
Fabric Connectivity
Creating a Layer 2 Interface Policy to Enable Per Port-VLAN Using the GUI

a) Enter a name for the policy.


b) (Optional) Enter a description for the policy.
c) For the Admin State, choose Enable to enable the policy, or Disable to disable the policy.
Step 5 Click Submit.

Creating a Layer 2 Interface Policy to Enable Per Port-VLAN Using the GUI
1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Interface Policies > Policies > L2 Interface.
3. In the Work pane, choose Actions > Create L2 Interface Policy.
4. In the Create L2 Interface Policy dialog box, perform the following actions:
1. Give the L2 Interface name and an optional description.
2. Select VLAN scope to Port Local scope to enable per port-VLAN.

Create Interface Policy Groups


The interface policy groups comprise the interface policies as a functional group that is associated to an
interface. The following diagram shows how previously created items are grouped under the policy group.
Figure 14: Policies contained in a policy group

Once all the interface policies have been defined, the individual policies can be brought together to form a
policy group that will be linked to the interface profile. The policy group is defined from a master definition
that encompasses being one of the following:
• Access Policy Group
• Port Channel Policy Group
• VPC Policy Group

Creating an Access Port Policy Group Using the GUI


The access port policy is defined for an individual link (non-Port Channel or vPC).

Operating Cisco Application Centric Infrastructure


63
Fabric Connectivity
Creating a Port Channel Interface Policy Group Using the GUI

1. On the menu bar, choose Fabric > Access Policies.


2. In the Navigation pane, choose Interface Policies > Policy Groups.
3. In the Work pane, choose Actions > Create Access Policy Group.
4. In the Create Access Policy Group dialog box, perform the following actions:
1. Define a meaningful name for the policy group.
2. Optionally, provide a description for the policy group.
3. Use the profiles created previously that are relevant for this policy group.

5. Click Submit.

Creating a Port Channel Interface Policy Group Using the GUI


Port Channeling also load-balances traffic across the physical interfaces that are members of the channel
group. For every group of interfaces that needs to be configured into a port channel, a different policy group
has to be created. This policy group defines the behaviour. For example, if ports 1/1-4 are to be configured
into one port channel, and ports 1/5-8 into a separate port channel, each of those groups would require the
creation of a separate policy group.
1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Interface Policies > Policy Groups.
3. In the Work pane, choose Actions > Create PC Interface Policy Group.
4. In the Create PC Interface Policy Group dialog box, perform the following actions:
1. Define a meaningful name for the policy group.
2. Optionally, provide a description for the policy group.
3. Select the policies created previously that are relevant for this PC policy group.

5. Click Submit.

Create VPC Interface Policy Group

Note This object must be unique for each vPC created.

A virtual Port Channel (vPC) allows links that are physically connected to two different devices to appear as
a single Port Channel to a third device. In the world of ACI, pairs of leaf switches may be configured in a
vPC domain so that downstream devices can be active-active dual-homed.
For every group of interfaces that are to be configured into a vPC, a different interface policy group needs to
be created. The vPC policy group contains both the definition for the behaviour of the port channel, and the
identifier. For example, if ports 1/1-4 are to be configured into one vPC across two switches, and ports 1/5-8
into a separate vPC across two switches, each of those groups would require the definition of a separate policy
group.

Operating Cisco Application Centric Infrastructure


64
Fabric Connectivity
Interface Profile

Note For vPC you will also require a unique vPC domain definition between the two paired switches. More details
to follow.

1. On the menu bar, choose Fabric > Access Policies.


2. In the Navigation pane, choose Interface Policies > Policy Groups.
3. In the Work pane, choose Actions > Create VPC Interface Policy Group.
4. In the Create VPC Interface Policy Group dialog box, perform the following actions:
1. Define a meaningful name for the policy group.
2. Optionally, provide a description for the policy group.
3. Choose the policies created previously that are relevant for this vPC policy group.

5. Click Submit.

Interface Profile
The interface profile in ACI links the policy groups that define how the interface is going to behave, and
assigns them to specific ports via the concept of interface selector. In turn, the interface profile is eventually
tied to a switch profile to specify which leaf switch the referenced ports should be configured. As we continue
the process of defining the port profiles, you can observe how we have started at the bottom of this object tree
configuring the different profiles. The purposes for all these individual policies that tie together is to maximize
policy re-use.
Figure 15: Interface Profile links to Interface Selector and Interface Policy Group

The diagram in the previous section provides a visual description of what can be accomplished by grouping
the policies that have been defined under the interface profile, and then assigned to ports with interface selectors
and the access port policy groups.

Create Interface Profile


The interface profile is composed of two primary objects. The interface selector and the access port policy
group. The interface selector defines what interfaces will apply the access port policy. The ports that share
the same attributes can then be grouped under the same interface profile.
1. On the menu bar, choose Fabric > Access Policies.

Operating Cisco Application Centric Infrastructure


65
Fabric Connectivity
Creating an Interface Selector Using the GUI

2. In the Navigation pane, choose Interface Policies > Profiles.


3. In the Work pane, choose Actions > Create Interface Profile.
4. In the Create Interface Profile dialog box, perform the following actions:
1. Define a meaningful name for the profile.
2. Optionally, provide a description for the profile.

5. Click Submit.

Creating an Interface Selector Using the GUI


This procedure creates an interface selector using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Interface Policies > Profiles > Name_of_Interface_Profile.
Step 3 In the Work pane, choose Actions > Create Access Port Selector.
Step 4 In the Create Access Port Selector dialog box, perform the following actions:
a) Enter a name for the profile.
b) (Optional) Enter a description for the profile.
c) Enter the interface IDs.
d) If the port is connected to a FEX, put a check in the Connected to FEX box.
e) Choose the interface policy group that should be associated to these ports.
Step 5 Click Submit.

Creating an Interface Profile for a Port Channel Using the GUI


If a server has two or more uplinks to a leaf switch, the links can be bundled into a Port Channel for resiliency
and load distribution. To configure this in ACI, create an interface policy group of type Port Channel to
bundle the interfaces. Different Port Channels require different policy groups.

Operating Cisco Application Centric Infrastructure


66
Fabric Connectivity
Creating an Interface Profile for a Port Channel Using the GUI

Figure 16: Port Channel Policy Group

This procedure creates an interface profile for a Port Channel using the GUI.

Procedure

Step 1 On the menu bar, choose Fabric > Access Policies.


Step 2 In the Navigation pane, choose Interface Policies > Profiles.
Step 3 In the Work pane, choose Actions > Create Interface Profile.
Step 4 In the Create Interface Profile dialog box, perform the following actions:
a) Enter a name for the profile.
b) (Optional) Enter a description for the profile.
Step 5 Click Submit.
Next, create an interface port selector. Since you will be configuring a Port Channel, the operator will add all
of the interfaces required in the Port Channel interface. In this example, interfaces Ethernet 1/1-2 will be
configured in one Port Channel and interfaces Ethernet 1/3-4 will be configured in another Port Channel.

Step 6 On the menu bar, choose Fabric > Access Policies.


Step 7 In the Navigation pane, choose Interface Policies > Profiles > Name_of_Interface_Profile.

Operating Cisco Application Centric Infrastructure


67
Fabric Connectivity
Create an Interface Profile for Virtual Port Channel

Step 8 In the Work pane, choose Actions > Create Access Port Selector.
Step 9 In the Create Access Port Selector dialog box, perform the following actions:
a) Enter a name for the profile.
b) (Optional) Enter a description for the profile.
c) Enter interface IDs for the first port channel.
d) Choose the interface policy group.
Step 10 Click Submit.
Step 11 Repeat steps 8 through 10 if you have another Port Channel to add.

Create an Interface Profile for Virtual Port Channel


A vPC domain is always made up of two leaf switches, and a leaf switch can only be a member of one vPC
domain. In ACI, that means that the definition of the policies is significant between the two switches. The
same policy can be reused betweeen the two switches, and through the vPC domain the pair association can
be defined. vPC Switch domain members should be taken into consideration when configuring firmware
maintenance groups. By keeping this in mind, firmware upgrades should never impact both vPC switch peers
at the same time. More details on this can be found in the Upgrading and Downgrading Firmware section.
For this reason, a switch profile that would represent two separate switch IDs needs to be created. The
relationship of these switches to the two ports in the same policy group is defined through the interface profile.
Figure 17: vPC Policy Group

The same process would have to be repeated for every grouped interface on each side that will be a member
of the vPC.
1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Interface Policies > Profiles.
3. In the Work pane, choose Actions > Create Interface Profile.
4. In the Create Interface Profile dialog box, perform the following actions:
1. Define a meaningful name for the profile.
2. Optionally, provide a description for the profile.

5. Click Submit.
6. In the Navigation pane, choose Interface Policies > Profiles > Name_of_Interface_Profile_Created .

Operating Cisco Application Centric Infrastructure


68
Fabric Connectivity
Create a vPC Domain for Virtual Port Channel

7. In the Work pane, choose Actions > Create Access Port Selector.
8. In the Create Access Port Selector dialog box, perform the following actions:
1. Define a meaningful name for the profile.
2. Optionally, provide a description for the profile.
3. Enter interface IDs.
4. Select of the interface policy group to be used for the vPC port behavior.

9. Click Submit.

Create a vPC Domain for Virtual Port Channel


When configuring a vPC, there is one additional step to be configured once to put two leaf switches into the
same vPC domain.
Figure 18: Creating a vPC Domain

1. On the menu bar, choose Fabric > Access Policies.


2. In the Navigation pane, choose Switch Policies > VPC Domain > Virual Port Channel default.
3. In the Work pane, choose Actions > Create Explicit VPC Protection Group.
4. In the Create Explicit VPC Protection Group dialog box, perform the following actions:
1. Define a meaningful name for the vPC domain.
2. Provide a unique ID to represent the vPC domain.
3. Choose the first switch you want to be part of the vPC domain.
4. Choose the second switch you want to be part of the vPC domain.

5. Click Submit.

Switch Profiles
A switch profile groups all the interface profiles that define the behavior of its respective switch ports. A
switch profile could be the definition of a single switch or it could be the definition of multiple switches. As

Operating Cisco Application Centric Infrastructure


69
Fabric Connectivity
Reusability

a best practice, there should be a switch profile for each leaf switch, and an additional switch profile for each
vPC domain pair of leaf switches.
The interface profiles that you have created can be associated to the switch through a single switch profile or
they can be associated through different switch profiles. If you have various racks that are identical in the way
the interface ports are configured, it could be beneficial to utilize the same switch profile. This would make
it possible to modify the configuration of many switches during operations without having to configure each
switch individually.

Reusability
The capability of policy reusability is crucial to re-emphasize from an operational perspective. If a profile has
been defined to configure a port as 1GB speed for example, that profile can be reused for many interface
policy groups. When looking at whole switch configurations, the re-usability of the profile can be extended
to simplify data center operations and ensure compliance. The following figure illustrates the reusability of
profiles across racks of switches.
Figure 19: Policy re-use at scale

In the previous diagram, each of the top of rack switches is based on the same switch profile. If all these racks
are configured in the same fashion (meaning they are wired in the same way) the same policies could be reused
by simply assigning the switches to the same switch profile. It would then inherit the profile tree and be
configured the exact same way as the other racks.
It is also important to be aware of the implication of deleting profiles. If a profile has been reused across many
devices, make sure to check where it is being used before you delete the profile or policy.

Operating Cisco Application Centric Infrastructure


70
Fabric Connectivity
Sample vPC Creation

Sample vPC Creation


The following procedure demonstrates what a vPC bringup looks like and also API POST configuration
assessment of the vPC. The following topology will be configured:
Figure 20: Sample Topology

Creating VLAN Pools


REST :: /api/node/class/fvnsVlanInstP.xml

Creating a Physical Domain


REST :: /api/node/class/physDomP.xml

Creating Access Entity Profile


REST :: /api/node/class/infraAttEntityP.xml

Creating a Link Level Policy


REST :: /api/node/class/fabricHIfPol.xml

Creating a Port Channel Policy


REST :: /api/node/class/lacpLagPol.xml

Creating a vPC Interface Policy Group


REST :: /api/node/class/infraAccBndlGrp.xml

Creating an Interface Profile


REST :: /api/node/class/infraAccPortP.xml

Creating a Switch Profile


REST :: /api/node/class/infraNodeP.xml

Operating Cisco Application Centric Infrastructure


71
Fabric Connectivity
Sample vPC Creation

Creating a vPC Domain


REST :: /api/node/class/fabricExplicitGEp.xml

Validating the Operation of a Configured vPC Using the GUI


1. On the menu bar, choose Fabric > Inventory.
2. In the Navigation pane, choose POD 1 > Node_Name > Interfaces > vPC Interfaces.
3. In the Work pane, there will be a table that shows the status of the vPC interface. If configured correctly,
the status should be displayed and you should see successful establishment of the vPC domain.

Validating the Operation of a Configured vPC Using the CLI


You can validate the operation of the vPC directly from the CLI of the switch itself. If you connect to the
console or the out of band management interface of the leaf node you should be able to see the status with
the command show vpc.
Leaf-3# show vpc
Legend:
(*) - local vPC is down, forwarding via vPC peer-link
vPC domain id : 100
Peer status : peer adjacency formed ok
vPC keep-alive status : Disabled
Configuration consistency status : success
Per-vlan consistency status : success
Type-2 consistency status : success
vPC role : primary
Number of vPCs configured : 1
Peer Gateway : Disabled
Dual-active excluded VLANs : -
Graceful Consistency Check : Enabled
Auto-recovery status : Enabled (timeout = 240 seconds)
Operational Layer3 Peer : Disabled
vPC Peer-link status
---------------------------------------------------------------------
id Port Status Active vlans
-- ---- ------ --------------------------------------------------
1 up -
vPC status
----------------------------------------------------------------------
id Port Status Consistency Reason Active vlans
-- ---- ------ ----------- ------ ------------
1 Po1 up success success

The following REST API call can be used to build vPCs and attach vPCs to static port bindings.

URL: https://{{apic-ip}}/api/policymgr/mo/.xml
<polUni>
<infraInfra>
<!-- Switch Selector -->
<infraNodeP name="switchProfileforVPC_201">
<infraLeafS name="switchProfileforVPC_201" type="range">
<infraNodeBlk name="nodeBlk" from_="201" to_="201"/>
</infraLeafS>
<infraRsAccPortP tDn="uni/infra/accportprof-intProfileforVPC_201"/>
</infraNodeP>
<infraNodeP name="switchProfileforVPC_202">
<infraLeafS name="switchProfileforVPC_202" type="range">
<infraNodeBlk name="nodeBlk" from_="202" to_="202"/>
</infraLeafS>
<infraRsAccPortP tDn="uni/infra/accportprof-intProfileforVPC_202"/>

Operating Cisco Application Centric Infrastructure


72
Fabric Connectivity
Server Connectivity

</infraNodeP>
<!-- Interface Profile -->
<infraAccPortP name="intProfileforVPC_201">
<infraHPortS name="vpc201-202" type="range">
<infraPortBlk name="vpcPort1-15" fromCard="1" toCard="1" fromPort="15"
toPort="15"/>
<infraRsAccBaseGrp tDn="uni/infra/funcprof/accbundle-intPolicyGroupforVPC"/>
</infraHPortS>
</infraAccPortP>
<infraAccPortP name="intProfileforVPC_202">
<infraHPortS name="vpc201-202" type="range">
<infraPortBlk name="vpcPort1-1" fromCard="1" toCard="1" fromPort="1"
toPort="1"/>
<infraRsAccBaseGrp tDn="uni/infra/funcprof/accbundle-intPolicyGroupforVPC"/>
</infraHPortS>
</infraAccPortP>
<!-- Interface Policy Group -->
<infraFuncP>
<infraAccBndlGrp name="intPolicyGroupforVPC" lagT="node">
<infraRsAttEntP tDn="uni/infra/attentp-AttEntityProfileforCisco"/>
<infraRsCdpIfPol tnCdpIfPolName="CDP_ON" />
<infraRsLacpPol tnLacpLagPolName="LACP_ACTIVE" />
<infraRsHIfPol tnFabricHIfPolName="10GigAuto" />
</infraAccBndlGrp>
</infraFuncP>
</infraInfra>
</polUni>
https://{{hostName}}/api/node/mo/uni.xml
<polUni>
<fvTenant descr="" dn="uni/tn-Cisco" name="Cisco" ownerKey="" ownerTag="">
<fvAp descr="" name="CCO" ownerKey="" ownerTag="" prio="unspecified">
<fvAEPg descr="" matchT="AtleastOne" name="Web" prio="unspecified">
<fvRsPathAtt encap="vlan-1201" instrImedcy="immediate" mode="native"
tDn="topology/pod-1/protpaths-201-202/pathep-[vpc201-202]” />
</fvAEPg>
<fvAEPg descr="" matchT="AtleastOne" name="App" prio="unspecified">
<fvRsPathAtt encap="vlan-1202" instrImedcy="immediate" mode="native"
tDn="topology/pod-1/protpaths-201-202/pathep-[vpc201-202]” />
</fvAEPg>
</fvAp>
</fvTenant>
</polUni>

Server Connectivity
Server connectivity is necessary for all application workloads to function properly on the Cisco Application
Centric Infrastructure (ACI) fabric. The fabric connectivity requirements that are dictated by the server
infrastructure must be carefully considered. In the case of Cisco Unified Computing System (UCS), fabric
access policies must be provisioned to match these requirements. These policies are all governed by interface
policy groups. ACME Inc. has several different models of servers in their data centers, such as Cisco UCS B
and C series, as well as some third party servers that all need to be connected to the ACI fabric.

Cisco UCS B-Series Servers


When connecting UCS to the ACI fabric, the type of Layer 2 connection needed on the Fabric Interconnect
facing ports must be determined first. A best practice is to leverage a virtual port channel (vPC) to connect
the UCS environment so as to create a multi-chassis etherchannel. In this scenario, individual link and fabric
switch failures are mitigated to maintain a higher expected up time.

Operating Cisco Application Centric Infrastructure


73
Fabric Connectivity
Virtual Machine Networking

For more information on the process needed to configure links to UCS as either a vPC or a traditional port
channel, see the Adding New Devices to the Fabric section.

Standalone Rack Mount Servers or Non-Cisco Servers


Any non-UCS server architecture can also be connected directly to the ACI fabric or to a Cisco Nexus 2000
Fabric Extender (FEX). When being connected to the ACI fabric, the kind of traffic expected out of the server
links needs to be determined. If the workload is a bare metal server, traffic can be classified on a per port basis
and associated AEPs and EPGs can be mapped appropriately to match the tagged or untagged traffic. If a
supported hypervisor is to be used, a Virtual Machine Manager (VMM) domain must be properly configured,
and then associated with the corresponding ports on the fabric as a hypervisor that is facing through EPG and
AEP mapping. The key is to map the expected traffic classification to the ports that are connected to the server
infrastructure.
Utilizing a FEX is an alternative way to connect host devices into the ACI fabric. Restrictions that are present
in NX-OS mode such that non-host-facing ports are not supported, are still true. Ports must only be connected
to hosts, and connectivity to any other network device will not function properly. When utilizing a FEX, all
host-facing ports are treated the same way as if they were directly attached to the ACI fabric.

Virtual Machine Networking


Understanding VM Networking in ACI
One of the most common uses of the Cisco Application Centric Infrastructure (ACI) will be to help manage
and deploy applications in virtual environments. The ACI provides the ability to manage both virtual and
physical endpoints with the same set of policies. This chapter will look at various operational tasks that will
be performed throughout the daily operations.
The following list describes some virtual machine manager (VMM) system terms:
• A virtual machine controller is an external VMM entity, such as VMware vCenter, VMware vShield,
and Microsoft Systems Center Virtual Machine Manager (SCVMM). The Application Policy Infrastructure
Controller (APIC) communicates with the VMM to publish network policies that are applied to virtual
workloads. A virtual machine controller administrator provides an APIC administrator with a virtual
machine controller authentication credential; multiple controllers of the same type can use the same
credential.
• Credentials represent the authentication credentials to communicate with virtual machine controllers.
Multiple controllers can use the same credentials.
• A pool represents a range of traffic encapsulation identifiers, such as VLAN and VXLAN IDs, and
multicast addresses. A pool is a shared resource and can be consumed by multiple domains, such as
VMM and Layer 4 to Layer 7 services. A leaf switch does not support overlapping VLAN pools. Different
overlapping VLAN pools must not be associated with the same attachable entity profile (AEP).
• The two types of VLAN-based pools are as follows:
• Dynamic pools - Managed internally by the APIC to allocate VLANs for endpoint groups (EPGs).
A VMware vCenter domain can associate only to a dynamic pool. This is the pool type that is
required for VMM integration.
• Static pools - The EPG has a relation to the domain, and the domain has a relation to the pool. The
pool contains a range of encapsulated VLANs and VXLANs. For static EPG deployment, the user

Operating Cisco Application Centric Infrastructure


74
Fabric Connectivity
ACI VM Integration Workflow

defines the interface and the encapsulation. The encapsulation must be within the range of a pool
that is associated with a domain with which the EPG is associated.

When creating dynamic VLAN pools for VMM integration, the VLAN range must also be created on any
intermediate devices, such as traditional switches or blade switches. This includes creating the VLANs on
Unified Computing System (UCS).

ACI VM Integration Workflow


Figure 21: ACI VM Integration Workflow

For detailed information on how to deploy the VMware vSphere Distributed Switch with the Application
Policy Infrastructure Controller (APIC)Application Policy Infrastructure Controller (APIC), see the Cisco
APIC Getting Started Guide.
For detailed information and the workflow for how to enable integration of Microsoft SCVMM with Cisco
Application Centric Infrastructure (ACI), see the Cisco ACI with Microsoft SCVMM Workflow document.

Operating Cisco Application Centric Infrastructure


75
Fabric Connectivity
VMware Integration

VMware Integration
When integrating Cisco Application Centric Infrastructure (ACI) into your VMware infrastructure, you have
two options for deploying networking. VMware domains can be deployed, leveraging the VMware vSphere
Distributed Virtual Switch (DVS) or the Cisco Application Virtual Switch (AVS). Both provide similar basic
virtual networking functionality; however, the AVS provides additional capabilities, such as VXLAN and
microsegmentation support. ACME Inc. has chosen to leverage the additional features provided by AVS. For
organizations interested in using the standard DVS provided by VMware, see the following document:
http://www.cisco.com/c/en/us/td/docs/switches/datacenter/aci/apic/sw/1-x/getting-started/video/cisco_apic_
create_vcenter_domain_profile_using_gui.html
The ACI 1.2 release supports vCenter 6.0 and the following features for DVS only:
• vMotion across DVS with a data center
• vMotion across a data center within the same vCenter
• vMotion across vCenter
• Upgrading an ACI deployment using vSphere 5.1 and 5.5 to vSphere 6.0
• vShield 5.5 with vSphere 6.0
• NSX manager 6.1 with vSphere 6.0
The following feature is not supported:
• Long distance vMotion

VMM Policy Model Interaction


Shown below are some of the various ACI policies which are involved with setting up VM Integration. This
serves as a reference for the ways the various policies are related to each other.
Figure 22: VMM Policy Model Interaction

Operating Cisco Application Centric Infrastructure


76
Fabric Connectivity
Publishing EPGs to a VMM Domain

Publishing EPGs to a VMM Domain


This section will detail how to publish an existing endpoint group (EPG) to a Virtual Machine Manager
(VMM) domain. For details on how to create EPGs, see the Tenants section.
For an EPG to be pushed to a VMM domain, a domain binding within the tenant EPG must be created.
1. On the menu bar, choose Tenants > ALL TENANTS
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane, choose Tenant_Name > Application Profiles > Application_Profile_Name >
Application EPGs > Application_EPG_Name > Domains (VMs and Bare-Metals).
4. In the Work pane, choose Actions > Add VM Domain Association.
5. In the Add VM Domain Association dialog box, choose the VMM Domain Profile that you previously
created.
1. For the Deployment and Resolution Immediacy, Cisco recommends keeping the default option of
On Demand. This provides the best resource usage in the fabric by only deploying policies to Leaf
nodes when endpoints assigned to this EPG are connected. There is no communication delay or traffic
loss by keeping the default selections.

6. Click Submit. The EPG will now be available as a Port Group to your VMM.

Connecting Virtual Machines to the Endpoint Group Port Groups on vCenter


1. Connect to your vCenter using the VI Client.
2. From the Host and Clusters view, right click on your Virtual Machine and choose Edit Settings.
3. Click on the Network Adapter, and in the Network Connection drop-down box, choose the Port Group
which corresponds to your EPG. It should display in the format of [TENANT | APPLICATION_PROFILE
| EPG | VMM_DOMAIN_PROFILE]
If you do not see your Cisco Application Centric Infrastructure (ACI) EPG in the Network Connection list,
it means one of the following:
• The VM is running on a host which is not attached to the Distributed Switch managed by the Application
Policy Infrastructure Controller (APIC).
• There may be a communication between your APIC and vCenter either through the OOB or INB
management network.

Microsoft SCVMM Integration


The following figure shows a representative topology of a System Center Virtual Machine Manager (SCVMM)
deployment with Cisco Application Centric Infrastructure (ACI). Hyper-V clustering connectivity between
SCVMM virtual machines and the Application Policy Infrastructure Controller (APIC) can run over the
management network.

Operating Cisco Application Centric Infrastructure


77
Fabric Connectivity
ACI SCVMM Workflow

Figure 23: Topology of an SCVMM deployment with ACI

ACI SCVMM Workflow


The following figure illustrates the workflow for integrating Microsoft SCVMM with Cisco Application
Centric Infrastructure (ACI):

Operating Cisco Application Centric Infrastructure


78
Fabric Connectivity
Mapping of ACI and SCVMM Contructs

Figure 24: ACI SCVMM Workflow

For more information about the workflow for integrating Microsoft SCVMM with ACI, see the Cisco ACI
with Microsoft SCVMM Workflow document.

Mapping of ACI and SCVMM Contructs


The following figure shows the mapping of Cisco Application Centric Infrastructure (ACI) and SCVMM
constructs (SCVMM Controller, Cloud, and Logical Switches).

Operating Cisco Application Centric Infrastructure


79
Fabric Connectivity
Mapping Multiple SCVMMs to an APIC Controller

Figure 25: ACI and SCVMM Constructs

One VMM domain cannot map to the same SCVMM more than once. An Application Policy Infrastructure
Controller (APIC) controller can be associated up to 5 SCVMM controllers. For additional information on
other limitations, see the Verified Scalability Guide for Cisco ACI .

Mapping Multiple SCVMMs to an APIC Controller


When multiple SCVMMs are associated with an Application Policy Infrastructure Controller (APIC) controller,
the Opflex certificate from the first SCVMM controller must be copied to the secondary controller and other
controllers, as applicable. Use the certlm.msc command on the local SCVMM controller to import the
certificate to the following location:
Certificates - Local Computer > Personal > Certificates

The same Opflex certificate is deployed on the Hyper-V servers that are managed by this SCVMM controller.
Use the mmc command to install the certificate on the Hyper-V servers.

Verifying that the OpFlex Certificate is Deployed for a Connection from the SCVMM to the APIC
You can verify that the OpFlex certificate is deployed for a connection from the SCVMM to the Application
Policy Infrastructure Controller (APIC) by viewing the Cisco_APIC_SCVMM_Service log file, which
is located in the C:\Program Files (x86)\ApicVMMService\Logs\ directory. In the file, check
for the following things:
• The correct certificate is used
• There was a successful login to the APIC

The following example log file highlights these things:


2/22/2016 1:14:07 PM-1044-13||UpdateCredentials|| AdminSettingsController: UpdateCredentials.
2/22/2016 1:14:07 PM-1044-13||UpdateCredentials|| new: EndpointAddress: Called_from_SCVMMM_PS,

Operating Cisco Application Centric Infrastructure


80
Fabric Connectivity
Verifying VMM deployment from the APIC to the SCVMM

Username ApicAddresses 192.168.1.47;192.168.1.48;192.168.1.49 CertName: OpflexAgent


2/22/2016 1:14:07 PM-1044-13||UpdateCredentials|| ########
2/22/2016 1:14:07 PM-1044-13||UpdateCredentials|| oldreg_apicAddresses is
2/22/2016 1:14:07 PM-1044-13||UpdateCredentials|| Verifying APIC address 192.168.1.47
2/22/2016 1:14:07 PM-1044-13||GetInfoFromApic|| Querying URL
https://192.168.1.47/api/node/class/infraWiNode.xml
2/22/2016 1:14:07 PM-1044-13||GetInfoFromApic|| HostAddr 192.168.1.47
2/22/2016 1:14:07 PM-1044-13||PopulateCertsAndCookies|| URL:/api/node/class/infraWiNode.xml
2/22/2016 1:14:07 PM-1044-13||PopulateCertsAndCookies|| Searching Cached Store Name: My
2/22/2016 1:14:07 PM-1044-13||PopulateCertsAndCookies|| Using Certificate CN=OpflexAgent,
C=USA, S=CA, O=TS,
E=sj_aci_sol@lab.local in Cached Store Name:My
2/22/2016 1:14:07 PM-1044-13||PopulateCertsAndCookies|| Using the following CertDN:
uni/userext/user-admin/usercert-OpFlexAgent
2/22/2016 1:14:07 PM-1044-13||GetInfoFromApic|| IFC returned OK to deployment query
2/22/2016 1:14:07 PM-1044-13||GetInfoFromApic|| Successfully deserialize deployment query
response
2/22/2016 1:14:07 PM-1044-13||UpdateCredentials|| ApicClient.Login(addr 192.168.1.47)
Success.

Verifying VMM deployment from the APIC to the SCVMM


You can verify that the OpFlex certificate is deployed on the Hyper-V server by viewing log files in the
C:\Program Files (x86)\ApicHyperAgent\Logs directory. In the file, check for the following
things:
• The correct certificate is used.
• The connection with the Hyper-V servers on the fabric leafs is established.

In the SCVMM, check for the following things:


• Under Fabric > Logical Switches, verify that "apicVswitch_VMMdomainName" is deployed from the
Application Policy Infrastructure Controller (APIC) to the SCVMM.
• Under Fabric > Logical Networks, verify that "apicLogicalNetwork_VMMdomainName" is deploy
from APIC to the SCVMM.
• Under Fabric > Port Profiles, verify that "apicUplinkPortProfile_VMMdomainName" is deployed. If
not, go to the host under Servers; right click the host and choose Properties. Go to Virtual Switches
and ensure that the physical adapters are attached to the virtual switches.
• A VTEP Virtual Network Adapter is added to the virtual switch and an IP address is assigned to the
VTEP adapter.

Note In the APIC GUI, the Hyper-V servers and the virtual machines will not appear under the Microsoft SCVMM
inventory until the first 3 bullets items for the SCVMM are satisfied.

Other Troubleshooting Tips for Verifying VMM Deployment


• The logs for the APIC_SCVMM_Service agent and the APIC_Hyper-V agent are in the respective
C:\Program Files(x86)\ApicVMMService and C:\Program
Files(x86)\ApicHypervAgent directories.
• There are support scripts for these services. The support scripts can be run in debug mode to provide
more insight on the service status/configuration on the SCVMM controller or Hyper-V server respectively.
To use the support scripts:

Operating Cisco Application Centric Infrastructure


81
Fabric Connectivity
Verifying Virtual Endpoint Learning

1. Right click on a script.


2. Choose Edit. A Power Shell ISE window opens.
3. Click Debug on the top bar to execute the script.
4. Review the output of the script for the issue.

Verifying Virtual Endpoint Learning


Once the VMs are connected to the appropriate port group/EPG, you should verify the APIC has learned your
virtual end point.

Verifying VM Endpoint Learning on the APIC from the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name.
3. In the Navigation pane, choose Tenant_Name > Application Profiles > Application_Profile_Name >
Application EPGs > Application_EPG_Name.
4. In the Work pane, choose the Operational tab. Note: The current tab should display CLIENT
ENDPOINTS. All endpoints either virtual or physical will be displayed. From here you should be able
to find your Virtual Machine by filtering the "Learning Source" column for rows with values of "Learned
VMM".

Verifying VM Endpoint Learning on the APIC from the CLI


You can verify the same info as above from the CLI by using the 'moquery' (Managed Object Query) command
and adding two filters. One for the Distinguished Name (DN) name of your EPG, and one for the Class Name
of 'fvCEp' (Fabric Vector Client Endpoint)
moquery -c fvCEp --dn uni/tn-<TENANT_NAME>/ap-<APP_PROFILE_NAME>/epg-<EPG_NAME>

You can determine the DN of your EPG by right clicking on the EPG in the GUI, selecting "Save As" and
looking at the XML object. From this file you will see the DN entry for the particular EPG:
<imdata totalCount="1"><fvAEPg uid="15374" triggerSt="triggerable" status=""
scope="2588672" prio="unspecified" pcTag="49159" name="epg-od"
monPolDn="uni/tn-common/monepg-default" modTs="2015-02-06T06:46:24.729+11:00"
matchT="AtleastOne" lcOwn="local" dn="uni/tn-mb-tennant1/ap-mb-app-pro/epg-epg-od"
descr="" configSt="applied" configIssues="" childAction=""/></imdata>

Next, use this DN with the moquery to return the list of client Enpoints for this EPG:
admin@apic1:~> moquery -c fvCEp --dn uni/tn-mb-tennant1/ap-mb-app-pro/epg-epg-od
Total Objects shown: 1
# fv.CEp
name : 00:50:56:BB:8C:6A
childAction :
dn : uni/tn-mb-tennant1/ap-mb-app-pro/epg-epg-od/cep-00:50:56:BB:8C:6A
encap : vlan-211
id : 0
idepdn :
ip : 10.10.10.10
lcC : learned,vmm
lcOwn : local
mac : 00:50:56:BB:8C:6A

Operating Cisco Application Centric Infrastructure


82
Fabric Connectivity
VMware Integration Use Case

mcastAddr : not-applicable
modTs : 2015-02-06T06:48:52.229+11:00
rn : cep-00:50:56:BB:8C:6A
status :
uid : 0
uuid :

VMware Integration Use Case


A VMWare administrator in ACME requests the network team to trunk a set of VLANs down to the ESX
hosts to provide connectivity to their DVS switches. Rather than trunking VLANs on a per server basis, the
network team decides to leverage a new methodology to be more agile and leverage the on-demand provisioning
of resources where and when they are needed, as well as providing unlimited Layer 2 mobility for all the VM
hosts within the ACI fabric.
To do so, the network admins work with the VMware admins to decide on a range of VLANs that will be
provided dynamically by APIC to the ESX hosts that need them. They decide on an unused VLAN range of
(600 - 800). This is their dynamic VLAN pool. Once this is decided, the APIC administrator proceeds to
configure VMM integration in the APIC GUI by providing the vCenter credentials to APIC. APIC dynamically
provisions all EPGs and makes them available to the ESX hosts as a port-group.
Note: The APIC does not automatically move VMNICs into the port-group. This allows VMware admins to
maintain control and move virtual NICs into these port-groups on demand.
As the VMware admin provisions ESX hosts and selects the appropriate port-groups for VMs, the APIC
dynamically communicates with vCenter to make EPGs available through port groups. The APIC also
configures VLAN IDs on the leaf-switches as needed.
During a vMotion event, APIC is automatically informed of the VM move and then updates the endpoint
tracking table to allow seamless communication. VMs are allowed to move anywhere within the ACI fabric
with no restrictions other than those imposed by vCenter.
It is important to note that ACME can still choose to deploy traditional VLAN trunking down to VMware
DVS switches by statically provisioning EPGs on a per-port basis, and still reap the advantages of the Layer
2-anywhere ACI fabric. However, ACME chose VMM integration as the preferred deployment model as it
is the most effective method of breaking down organizational challenges, doing on-demand resource allocation,
and getting enhanced visibility and telemetry into both the virtual and physical environments.

Deploying the Application Virtual Switch


Prerequisites for Deploying the Application Virtual Switch
• All switch nodes have been discovered by the fabric
• INB or OOB management connectivity is configured.
• VMware vCenter is installed, configured, and available.
• One or more vSphere hosts are available for deployment to the AVS.
• (Optional) A DNS server policy has been configured to enable connection to a VMM using a hostname.
• A dynamic VLAN pool has been created with enough VLAN IDs to accommodate one VLAN per EPG
you plan on deploying to each VMM domain.

Operating Cisco Application Centric Infrastructure


83
Fabric Connectivity
Getting Started

Getting Started
The AVS software was designed to operate independently of the APIC software version. This allows either
device to be upgraded independently. Always refer to the AVS release notes to confirm if any special
considerations may exist.
Just like any software, new versions of the AVS will be released to include new features and improvements.
The initial AVS software released was version 4.2.1, followed by version 5.2.1. Refer to the ACI Ecosystem
Compatibility List document to ensure your desired version of AVS is compatible with the APIC and vSphere
versions being run.
The AVS package for either version will include vSphere Installation Bundles (VIBs). Each version of AVS
software includes the VIB files for all supported vSphere versions. As of this publication there are two VIBs
to support vSphere versions 5.1 and 5.5 (vSphere 5.0 is not supported). These can be downloaded from CCO
at the following location:
Downloads Home > Products > Switches > Virtual Networking > Application Virtual Switch
AVS 4.2.1 Bundle
cross_cisco-vem-v165-4.2.1.2.2.3.0-3.1.1.vib 5.1 VIB
cross_cisco-vem-v165-4.2.1.2.2.3.0-3.2.1.vib 5.5 VIB

AVS 5.2.1 Bundle


cross_cisco-vem-v172-5.2.1.3.1.3.0-3.1.1.vib
cross_cisco-vem-v172-5.2.1.3.1.3.0-3.2.1.vib

Install the AVS VIB


Before setting up the AVS configuration on the APIC, the AVS software must be installed in vSphere, referred
to as the Virtual Ethernet Module (VEM). This can be achieved in a variety of ways, all of which are discussed
in Cisco Application Virtual Switch Installation Guide. For a few hosts, this can easily be done manually, but
for 10+ hosts it may be easier to leverage the Virtual Switch Update Manager (VSUM) to help automate the
installation process.

Manual Installation
1. Place the host in Maintenance mode.
2. Copy the VIB file to a host. The easiest way to copy the VIB to the host is to leverage the VMware VI
Client, navigate to the Host > Configuration > Storage > Datastore_X. Right click on the desired datastore
and choose Browse Datastore. From here, the VIB can be uploaded directly to the host's datastore.
3. SSH into the vSphere host on which the AVS VIB is to be installed. If SSH is not enabled, it can be
enabled under the Host Configuration > Security Profile > SSH.
4. Install or upgrade the VIB using the esxcli command:
To install the AVS VIB:
esxcli software vib install -v /<path>/<vibname> --maintenance-mode --no-sig-check

To upgrade an existing AVS VIB:


esxcli software vib update -v /<path>/<vibname> --maintenance-mode --no-sig-check

A sample output is shown below:


# esxcli software vib install -v /vmfs/volumes/datastore1/cross_cisco-vem-v172-
5.2.1.3.1.3.0-3.2 .1.vib --maintenance-mode --no-sig-check

Operating Cisco Application Centric Infrastructure


84
Fabric Connectivity
Attachable Access Entity Profile (AEP) and AVS

Installation Result
Message: Operation finished successfully.
Reboot Required: false
VIBs Installed: Cisco_bootbank_cisco-vem-v172-5.2.1.3.1.3.0-3.2.1
VIBs Removed:
VIBs Skipped:
/vmfs/volumes/53cab6da-55209af3-0ef2-24e9b391de3e # vem version
Running esx version -1623387 x86_64
VEM Version: 5.2.1.3.1.3.0-3.2.1
VSM Version:
System Version: VMware ESXi 5.5.0 Releasebuild-1623387

5. Confirm the VEM is loaded and running.


# vem status
VEM modules are loaded
Switch Name Num Ports Used Ports Configured Ports MTU Uplinks
vSwitch0 3072 6 128 1500 VMNIC0
VEM Agent (vemdpa) is running

Attachable Access Entity Profile (AEP) and AVS


An important component used by the AVS is the Attachable Entity Profile (AEP). Regardless of using an
existing AEP or creating a new one, the Enable Infrastructure VLAN check box must be checked for the
AEP policy. This is to ensure that the traffic of interest, such as DHCP request/offer or data packets, can flow
through the infrastructure VLAN to the AVS. The AEP defines which VLANs will be permitted on a host
facing interface. When a domain is mapped to an endpoint group, the AEP validates that the VLAN can be
deployed on certain interfaces. Referring back to the "VMM Policy Model Interaction" diagram from the
"VM Networking Overview" chapter, the AEP is what ties the VMM domain to the physical interfaces where
the vSphere hosts are connected. The AEP can be created on-the-fly during the creation of the VMM domain
itself, but this guide will detail creating the AEP separately first.

Create a New AEP


1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Global Policies > Attachable Access Entity Profile.
3. In the Work pane, choose Actions > Create Attachable Access Entity Profile.
4. In the Create Attachable Access Entity Profile dialog box, perform the following actions:
1. Fill in the AEP wizard information then click Next.
1. Name: Provide any name to identify the AEP, such as "AVS-AEP".
2. Enable Infrastructure VLAN: Put a check in this box.
3. Domains (VMs or Baremetal): Leave blank. This will be covered later in the Publishing EPGs
to VMM Domains chapter.

2. From the next page of the wizard, select the Interface Policy Group your AEP will be associated to.
This procedure assumes your Interface Policy Group has already been created. Click the All Interfaces
radio button for the desired Interface Policy Group.

Operating Cisco Application Centric Infrastructure


85
Fabric Connectivity
Modify an Existing AEP

Note Interface Policy Group creation is covered elsewhere in this guide. Essentially the Interface Policy Group is
a collection of Interface policies which define Interfaces Selectors and properties, such as speed/negotiation,
LLDP, and CDP. See the "Adding New Devices to the Fabric" chapter for more detail on creating the interface
policy group and interface profiles.

Modify an Existing AEP


1. On the menu bar, choose Fabric > Access Policies.
2. In the Navigation pane, choose Global Policies > Attachable Access Entity Profile.
1. In the Navigation pane, choose the existing AEP.
2. In the Work pane, put a check in the Enable Infrastructure VLAN check box.

Note: As mentioned early in this chapter, the Infrastructure VLAN is required for AVS communication to
the fabric using the OpenFlex control channel.

VMM Domains for vCenter


A Virtual Machine Manager (VMM) domain defines a virtual infrastructure that will be integrated into ACI.
This allows the same policies applied to physical endpoints, to also be applied to virtual endpoints. vCenter
VMM Domains are created using either the VMware DVS or Cisco AVS. You cannot change from one to
the other. A new VMM Domain will be created from scratch to support AVS deployment.

AVS Switching Modes


The AVS can operate in the following switching modes:
• Local Switching: Supports VXLAN encapsulation or VLAN encapsulation.
• This switching mode allows Inter-EPG traffic to be switched locally on the AVS.
• No Local Switch only supports VLAN encapsulation.
• This switching mode sends all traffic (Inter-EPG included) to the Leaf switch.

Operating Cisco Application Centric Infrastructure


86
Fabric Connectivity
Create the VMM Domain for AVS

Figure 26: AVS Switching Modes: Non-Local and Local switching mode

The decision between using VLAN or VXLAN encapsulation will mandate different VLAN extension
requirements outside of the fabric. When using VXLAN encapsulation, only the infra VLAN is required to
be extended to the AVS hosts. All traffic between the AVS uplinks and ACI fabric will be encapsulated by
VXLAN and transferred using the infrastructure VLAN.
If VLAN encapsulation is preferred, you will need to ensure every VLAN in the VM Domain VLAN pool
has been extended between the fabric and AVS host. This includes creating the VLANs on intermediate
devices such as UCS and the vNICs for any AVS vSphere hosts.

Create the VMM Domain for AVS


Now that the DHCP server policy has been created and AEP created/modified, you can create the VMM
domain for the AVS.
1. On the menu bar, choose VM NETWORKING.
2. In the Navigation pane, choose the Policies tab.
3. In the Work pane, choose Actions > Create VCenter Domain.
4. In the Create vCenter Domain dialog box, perform the following actions:
1. Name: This value will be used as the AVS "Switchname" displayed in vCenter.
2. Virtual Switch: Cisco AVS

Operating Cisco Application Centric Infrastructure


87
Fabric Connectivity
Verify AVS Deployment on vCenter

3. Switching Preference: <Choose Local or No Local Switching>


• For No Local Switching mode:
• Multicast Address: <Assign a multicast address to represent your AVS>
• Multicast Address Pool: <Create a unique Multicast Address Pool large enough to include
each AVS vSphere host.>

• For Local Switching mode:


• Encapsulation: <Choose VLAN or VXLAN based on preference>
• For VLAN Encapsulation:
• VLAN Pool: <Choose/Create a VLAN pool>

• For VXLAN Encapsulation:


• Multicast Address: <Assign a multicast address to represent your AVS>
• Multicast Address Pool: <Create a unique Multicast Address Pool large enough
to include each AVS vSphere host.>

4. Attachable Access Entity Profile: <Choose the AEP previously created/modified>


5. vCenter Credentials: Create a credential set with administrator/root access to vCenter
6. vCenter: Add the vCenter details.
• Name: Friendly name for this vCenter
• Hostname/IP Address: <DNS or IP Address of vCenter>
• DVS Version: vCenter Default
• Datacenter: <Enter the exact Datacenter name displayed in vCenter>
• Management EPG: <Set to oob or inb Management EPG>
• Associated Credentials: <Choose the Credential set previously created>
• Click OK to complete the creation of the vCenter.

5. Click Submit.

Verify AVS Deployment on vCenter


1. In the vCenter client, navigate to HOME > INVENTORY > NETWORKING and confirm a new
Distributed Virtual Switch folder has been created.
2. Expand this folder to find your AVS, and a few default Port Groups including "uplink" and "vtep".

Operating Cisco Application Centric Infrastructure


88
Fabric Connectivity
Adding vSphere Hosts to the AVS

Adding vSphere Hosts to the AVS


After the AVS has been created in vCenter, you then need to attach hosts to it. To do this you will need at
least one unused physical interface (VMNIC) to act as the uplink on each host. AVS uplinks can not be shared
with any other existing vSwitch or vDS.
1. From the vCenter client, navigate to HOME > INVENTORY > NETWORKING.
2. Right click on the newly created AVS switch (not the folder) and choose Add Host....
3. In the Add Host dialog box, choose any vSphere hosts to add to the AVS, and select an unassigned
VMNIC uplink.
4. Click Next until the wizard completes, skipping the migration of any virtual adapters or virtual machine
networking at this time.
Note: For blade switch systems such as UCS, the VMNIC interface used must have all necessary VLANs
allowed on the interface. In UCS terms, this requires the vNIC within the service profile to have all relevant
VLANs active on the vNICs.
5. You should see a new vmk interface created on your distributed switch within vCenter and assigned to
the 'vtep' port group. This VMK is your Virtual Tunnel Endpoint (VTEP) interface. The VTEP should
have pulled a DHCP address from the APIC from the TEP subnet. As can be seen from the screenshot
below, we see that the VMkernel port has received the IP address from the APIC. The APIC uses the
same 10.0.0.0/16 pool that is created during the APIC setup to provision the IP address. This implies that
we are ready for Opflex communication in between the AVS and the APIC.
~ # esxcfg-VMKNIC -l
Interface Port Group/DVPort IP Family IP Address Netmask Broadcast
vmk0 Management Network IPv4 172.16.176.54 255.255.255.0 172.16.176.255

vmk1 vmotion IPv4 192.168.99.54 255.255.255.0 192.168.99.255

vmk2 9 IPv4 10.0.16.95 255.255.0.0 10.0.255.255

MAC Address MTU TSO MSS Enabled Type


00:25:b5:00:00:29 1500 65535 true STATIC
00:50:56:61:1c:92 1500 65535 true STATIC
00:50:56:65:3d:b3 1500 65535 true DHCP

Verify AVS on ESX


On the ESX command line, issue the vemcmd show openflex command.
Verify that the status: 12 (Active) is seen as well as the switching mode. Also verify that the GIPO
address is the same as the multicast address that was used while creating the VMM domain.

~ # vemcmd show openflex


Status: 12 (Active)
Dvs name: comp/prov-VMware/ctrlr-[AVS-TEST]-VC/sw-dvs-87
Remote IP: 10.0.0.30 Port: 8000
Infra vlan: 4093
FTEP IP: 10.0.0.32
Switching Mode: LS
NS GIPO: 225.127.1.1

Verify on the AVS host - there should be one multicast group per deployed EPG on the host. In the output
below, there are three different Virtual Machines connected to different EPGs.

Operating Cisco Application Centric Infrastructure


89
Fabric Connectivity
VXLAN Load Balancing

~ # vemcmd show epp multicast


Number of Group Additions 3
Number of Group Deletions 0
Multicast Address EPP Ref Count
225.0.0.58 1
225.0.0.76 1
225.0.0.92 1

VXLAN Load Balancing


VXLAN load balancing is automatically enabled as soon as more than one VMKNIC is connected to the
Cisco AVS. Each VMKNIC can use only one uplink port; you should have an equal number of VMKNICs
and uplinks. A maximum of eight VMKNICs can be attached to a Cisco AVS switch. Each of the VMKNICs
that you create has its own software-based MAC address. In VXLAN load balancing, the VMKNICs provide
a unique MAC address to packets of data that can then be directed to use certain physical NICs (VMNICs).
You need to have as many VMKNICs as the host has VMNICs, up to a maximum of eight. For example, if
the host has five VMNICs, you need to add four VMKNICs to enable VXLAN load-balancing; the Cisco
Application Policy Infrastructure Controller (APIC) already created one VMKNIC when the host was added
to the distributed virtual switch (DVS).
In VMware vSphere Client, you will need to create an additional virtual adapter (VMK) for each AVS uplink.
Each vmk interface created for the AVS should be attached to the vtep port group and configured for DHCP.
Each VMK interface added is assigned a unique DHCP address from the fabric TEP pool.

IGMP Snooping Policy for AVS


Cisco UCS-B Series Considerations with AVS Deployments
This section of the article will focus the necessary steps to enable AVS through the Cisco UCS-B series.
By default, USC-B FI has IGMP snooping enabled. Due to this, we have to configure an IGMP querier policy
on the APIC. The IGMP snooping policy needs to be enabled on the infra tenant.
If we disable IGMP snooping on UCS or other intermediate blade switches, then IGMP policy is not needed
since the blade switch will flood the multicast traffic on all the relevant ports.

Create an IGMP Snooping Policy for AVS


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose infra.
3. In the Navigation pane, choose infr > Networking > Bridge Domain > default.
1. In the IGMP Snoop Policy drop-down list, choose Create IGMP Snooping Policy.
2. Provide a name for the policy, such as "IGMP_Infra".
3. Click the Fast Leave check box.
4. Click the Enable Querier check box.

4. Click Submit.

Operating Cisco Application Centric Infrastructure


90
Fabric Connectivity
Microsegmentation with the Cisco Application Virtual Switch

Note Verify if the IGMP snooping querier is being seen on the UCS Fabric interconnects. In this example, VLAN
4093 is the infra VLAN, and 192.168.0.30 is the bridge domain subnet for the infra bridge domain:
ucsb-A(nxos)# show ip igmp snooping querier vlan 4093
Vlan IP Address Version Expires Port
4093 192.168.0.30 v3 00:03:46 port-channel1

You can verify if IGMP snooping is working properly on the vSphere host CLI by using the vemcmd show
epp multicast command. The alternate method would be to create an IGMP policy on UCS to disable IGMP
snooping, which will cause flooding of the multicast traffic to all endpoints.

Microsegmentation with the Cisco Application Virtual Switch


Microsegmentation (uSeg) with the Cisco Application Virtual Switch (AVS) provides the ability to assign
endpoints to endpoint groups automatically based on various attributes. Microsegmentation with Cisco AVS
was introduced in Cisco AVS Release 5.2(1)SV3(1.5). This feature is available in the Cisco Application
Centric Infrastructure (ACI) for Cisco AVS only; it is not available with VMware Distributed Virtual Switch
(DVS). Endpoint groups are now divided into two categories: application endpoint groups and uSeg endpoint
groups. Application endpoint groups are what will appear in your VMM, such as vCenter, to be assigned to
virtual machines as network port groups. uSeg endpoint groups are implicitly applied to any virtual machine
within the same tenant and VMM domain, pending an attribute match.
Microsegmentation policies used by the Cisco AVS are centrally managed by the Application Policy
Infrastructure Controller (APIC) and enforced by the fabric. uSeg endpoint groups will not appear to vCenter.
When changing a virtual machine's network binding, "uSeg EPG" will not appear as a port group binding
option. However, virtual machines are still assigned to their regular application endpoint group in the fabric.

Table 2: Attributes Available for uSeg Endpoint Group Auto Assignment

Attribute Attribute Type

VM Name VM

VM ID VM

VNIC ID VM

Hypervisor VM

DVS Port-Group VM

DVS Name VM

MAC Sets Network

IP Sets Network

Operating Cisco Application Centric Infrastructure


91
Fabric Connectivity
External Connectivity

External Connectivity
Extending ACI to External Layer 2
As mentioned in the introduction of this book, ACME Inc. is a multinational company with multiple data
centers. Therefore, ACME Inc. must configure some Layer 2 connectivity. This is necessary for extending
Layer 2 connectivity to a Data Center Interconnect (DCI) platform, to further extend connectivity to a remote
data center, or simply to extend a Layer 2 domain outside of the fabric to connect in an existing Layer 2
network in a non-ACI fabric.

Extending Endpoint Groups Outside the ACI Fabric


The simplest way to extend an endpoint group (EPG) outside of the ACI fabric is to statically assign a leaf
port and VLAN ID to an existing endpoint group. After doing so, all of the traffic received on this leaf port
with the configured VLAN ID will be mapped to the EPG, and as such, the configured policy for this EPG
will be enforced. The endpoints do not need to be directly connected to the ACI leaf, as the traffic classification
will be based on the encapsulation received on a port.
To assign a Layer 2 connection statically on an ACI leaf port to an EPG:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane, choose Tenant_Name > Application Profiles > App_Profile_Name >
Application EPGs > EPG_Name > Static Bindings (Paths).
4. In the Work pane, choose Action > Deploy Static EPG on PC, vPC or Interface.
1. In the Path field, specify a port as well as a VLAN ID.
2. Click one of the Deployment Immediacy radio buttons. Deployment immediacy determines when
the actual configuration will be applied on the leaf switch hardware. The immediacy also determines
when the hardware resource, such as a VLAN resource and policy content-addressable memory (CAM)
to support the related contract for this EPG, will be consumed on the leaf switch. The option Immediate
means that the EPG configuration and its related policy configuration will be programmed in the
hardware right away. The option On Demand instructs the leaf switch to program the EPG and its
related policy in the hardware only when traffic matching this policy is received for this EPG.
3. Click one of the Mode radio buttons. The mode option specifies whether the ACI leaf expects incoming
traffic to be tagged with a VLAN ID or not.
1. Tagged - The tagged option means that the leaf node expects incoming traffic to be tagged with
the specified VLAN ID previously established. This is the default deployment mode. Choose this
mode if the traffic from the host is tagged with a VLAN ID. Multiple EPGs can be statically bound
to the same interface as long as the encap VLAN/VXLAN ID is unique.
2. Untagged - The untagged option means that the leaf expects untagged traffic without a VLAN
ID. Similar to the switchport access vlan vlan_ID command, with this option you can only
assign the interface to one EPG. This option can be used to connect a leaf port to a bare metal
server whose network interface cards (NICs) typically generate untagged traffic. A port can have
only one EPG statically bound to a port as untagged.

Operating Cisco Application Centric Infrastructure


92
Fabric Connectivity
Extending an ACI Bridge Domain Outside of the Fabric

3. 802.1P - The 802.1P option refers to traffic tagged with 802.1P headers. 802.1P mode is useful
when its necessary to handle the traffic on one EPG as untagged to the interface (similar to the
switchport trunk native vlan vlan_ID command), but (unlike the untagged mode) 802.1P will
allow other 'tagged' EPGs to be statically bound to the same interface. Any traffic received on
links with this mode classification will have the following conditions applied to them.

4. Create a physical domain and VLAN pool that are associated to this physical domain.
5. Associate the physical domain to the EPG in question.
6. Create an attachable access entity profile (AEP) to map the interfaces and policies together.

See the Adding New Devices to the Fabric section for more information on how to configure an AEP and a
physical domain.

Extending an ACI Bridge Domain Outside of the Fabric


A Layer 2 outside connection is associated with a bridge domain and is designed to extend the whole bridge
domain, not just an individual EPG under the bridge domain, to the outside network.
To accomplish an extension of the bridge domain to the outside, a Layer 2 outside connection must be created
for the bridge domain. During this process, create a new external EPG to classify this external traffic. This
new EPG will be part of the existing bridge domain. Classify any outside connections or endpoints into this
new external EPG. With two separate EPGs, you will also need to select which traffic you would like to
traverse between the two EPGs. Similar to the previous example of adding an endpoint to a pre-existing EPG,
this method will also allow the endpoints to share the same subnet and default gateway.
To create an external Layer 2 domain:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane, choose Tenant_Name > Networking > External Bridged Network.
4. In the Work pane, choose Action > Create Bridged Outside.
5. In the Create Bridged Outside dialog box, perform the following actions:
1. Associate the Layer 2 outside connection with the bridge domain and a VLAN ID. This VLAN must
be configured on the external Layer 2 network. This Layer 2 outside connection will put this VLAN
and the bridge domain of the ACI fabric under the same Layer 2 domain. This VLAN ID must be in
the range of the VLAN pool that is used for the Layer 2 outside connection.
1. For the External Bridged Domain drop-down list, create a Layer 2 domain if one does not already
exist.
2. While creating the Layer 2 domain, if it does not already exist, create a VLAN pool to associate
to the VLAN on the Layer 2 outside connection. This is a means to specify the range of the VLAN
IDs that will be used for creating a Layer 2 outside connection. This helps avoid any overlapping
in the VLAN range between VLANs used for an EPG and those in use for a Layer 2 outside
connection.

2. Add a Layer 2 border leaf node and Layer 2 interface for a Layer 2 outside connection.

Operating Cisco Application Centric Infrastructure


93
Fabric Connectivity
Extending ACI to External Layer 3

3. After adding a Layer 2 border leaf and Layer 2 interface, click Next to start creating a Layer 2 EPG.
Simply provide a name for the Layer 2 EPG. All of the traffic entering the ACI fabric with the
designated VLAN (the VLAN ID provided in step 1) will be classified into this Layer 2 EPG.
4. Configure a contract to allow communication between your existing endpoints in the existing EPG
and your new external Layer 2 EPG. In the Navigation pane, choose External Bridged Networks >
Networks and specify a contract to govern this policy as the consumed contract. After specifying this
contract as the provided contract for your internal EPG, the communication between this external
Layer 2 EPG and your existing internal EPG will be allowed.
5. Create an AEP. This is a policy object that tells the APIC to allow certain encap (VLANs) on selected
ports. For more information on how to create n Access Attachable Entity Profile, see the Adding New
Devices to the Fabric section.

You should now have the desired reachability between the inside and outside Layer 2 segments.

Extending ACI to External Layer 3


The most important component of any application is the user or customer, which generally does not directly
attach to the fabric, and therefore there must be connected to the external network. ACME must be able to
connect to both their internal corporate backbone, as well as to the Internet to provide access to the mobile
application. This integration is possible with Cisco Application Centric Infrastructure (ACI) at the tenant
policy level. Layer 3 connectivity to a device like a router is known as an External Routed Network, and
provides IP connectivity between a tenant private network and an external IP network. Each Layer 3 external
connection is associated with one tenant private network. The requirement of the Layer 3 external network is
only needed when a group of devices in the application profile require Layer 3 connectivity to a network
outside of the ACI fabric.
An application profile enables an operator to group the different components, or tiers, of an application into
endpoint groups (EPGs). These application components might have requirements for external connectivity
into them. The following figure shows part of a simplified fabric:
Figure 27: A sample application profile for a three-tiered application with contracts between the tiers

For example, web servers need a connection to the outside world for users to reach them. With ACI, the
connectivity is defined by a contract to a defined external Layer 3 endpoint group. As the operator of the
fabric, you can provide the tenant administrator with the ability to interface to an external Layer 3 connection
in various ways by using a uniquely-defined Layer 3 construct for the tenant application profile or a shared
common infrastructure.
External Layer 3 connections are usually established on the border leaf construct of the ACI. Any ACI leaf
can become a border leaf. In large scale ACI designs it might be productive to have dedicated ACI leafs as
border leafs. It is important to note that the spine nodes cannot have connections to external routers. A border
leaf is simply terminology to refer to a leaf that happens to be connected to a Layer 3 device. Other devices,
like servers, can still connect to the border leaves. In the ACI fabric, the external Layer 3 connection can be
one of the following types:
1. Physical Layer 3 interface

Operating Cisco Application Centric Infrastructure


94
Fabric Connectivity
Supported Routing Protocols

2. Subinterface with 8021.Q tagging


3. Switched Virtual Interface (SVI)
The following figure depicts the logic of public and private networks:
Figure 28: Application profile with external consumers, public and private networks annotated

With devices connecting through the external Layer 3 connection, the external network has learned of the
internal ACI network 10.1.1.0/24, as it is advertised to the adjacent router through the Layer 3 external
connection. For the private networks, ACI does not advertise the networks through the routing protocol to the
adjacent Layer 3 router, and the networks are not reachable to devices external to the fabric.
In releases prior to version 1.1 of Cisco Application Policy Infrastructure Controller (APIC), the fabric only
advertises subnets that are marked public in the associated bridge domain. Routes that are learned externally
from the fabric are not advertised through other ports. This behavior is known as a non-transit fabric. In release
version 1.1 and later, ACI is capable of acting as a transit network, and routes learned from one external Layer
3 connection can be advertised out to a different external Layer 3 connection, not just fabric routes.
The network team will provide the external Layer 3 connectivity for their tenants. One common mechanism
is to use sub-interfaces on a router to create different Layer 3 domains since each tenant will likely not have
their own external router.

Supported Routing Protocols


The following routing protocols are supported at time of writing:
• Static routes - You can define static routes to the outside world. Using static routes reduces the sizing
and complexity of the routing tables in the leaf nodes, but increases administrator overhead. With static
routes, you must also configure the static path back to the interanal network that you wish to be reachable
from the outside world.
• OSPF NSSA - Using not-so-stubby area (NSSA) reduces the size of the Open Shortest Path First (OSPF)
database and the need to maintain the overhead of the routing protocols with large tables of routes. With
OSPF NSSA, the router learns only a summarization of routes, including a default path out of the fabric.
OSPF NSSA advertises to the adjacent router the internal public subnets part of the Layer 3 external.
• iBGP peering leaf and external router - With internal Border Gateway Protocol (iBGP), ACI supports
only one autonomous system (AS) number that has to match the one that is used for the internal
Multiprotocol Border Gateway Protocol (MP-BGP) route reflector. Without MP-BGP, the external routes
(static, OSPF, or BGP) for the Layer 3 outside connections are not propagated within the ACI fabric,
and the ACI leaves that are not part of the border leaf does not have IP connectivity to any outside
networks. Given that the same AS number is used for both cases, the user must find out the AS number
on the router to which the ACI border leaf will connect, and use that AS number as the BGP AS number
for the ACI fabric.

Configure MP-BGP Spine Route Reflectors


The ACI fabric route reflectors use multiprotocol border gateway protocol (MP-BGP) to distribute external
routes within the fabric so a full mesh BGP topology is not required. To enable route reflectors in the ACI

Operating Cisco Application Centric Infrastructure


95
Fabric Connectivity
Configure MP-BGP Spine Route Reflectors

fabric, the fabric administrator must select at least one spine switch that will be a route reflector, and provide
the autonomous system (AS) number for the fabric. Once route reflectors are configured, administrators can
setup connectivity to external networks.
To connect external Layer 3 devices to the ACI fabric, the fabric infrastructure operator must configure a
Route Reflector policy to designate which spines act as the route reflector(s). For redundancy purposes,
configure more than one spine as a router reflector node.
When a tenant requires a Layer 3 connection, the infrastructure operator configures the leaf node to which
the WAN router is being connected as border leaf node, which pairs the border leaf node with one of the route
reflector nodes as a BGP peer. After the route reflectors are configured, they can advertise routes in the fabric.
Each leaf node can store up to 4000 routes at time of writing. If a WAN router must advertise more than 4000
routes, the router should peer with multiple leaf nodes. The infrastructure operator configures each of the
paired leaf nodes with the routes (or route prefixes) that the nodes can advertise.
To configure the Route Reflector policy:
1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Pod Policies > Policies > BGP Route Deflector default.
3. In the Work pane, perform the following actions:
1. Change the Autonomous System Number to match the required number for your network.
2. Add the two spine nodes that will be members of this reflector policy.
3. Click Submit.

4. In the Navigation pane, choose Pod Policies.


5. In the Work pane, choose Actions > Create Pod Policy Group.
6. In the Create Pod Policy Group dialog box, perform the following actions:
1. In the BGP Route Reflector Policy drop-down list, choose default.
2. In the Navigation pane, choose Pod Policies > Profiles > default.
3. In the Work pane, in the Fabric Policy Group drop-down list, choose Create Pod Policy Group.
4. In the Create Pod Policy Group dialog box, in the Date Time Policy drop-down list, choose default.
5. In the BGP Route Reflector Policy drop-down list, choose default.
6. Complete the remainder of the dialog box as appropriate to your setup.

7. Click Submit.

The following figure illustrates the objects and their relationships for external Layer 3 connections:

Operating Cisco Application Centric Infrastructure


96
Fabric Connectivity
Layer 3 Integration Through Tenant Network with OSPF NSSA

Figure 29: Object relationships for Layer 3 outside objects

Layer 3 Integration Through Tenant Network with OSPF NSSA


The following figure shows a simple integration of a Layer 3 external into ACI using OSPF:
Figure 30: Logical topology for an external OSPF router communicating with two border leafs

The setup includes a single router with two interfaces connected to leaf switches.
Note: See the "Adding New Devices to The Fabric" section to setup the access policies for the interfaces of
the leaves that are connected to the router.
To integrate Layer 3 through a tenant network with OSPF/NSSA:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Networking > External Routed Networks.
4. In the Work pane, choose Action > Create Routed Outside.
5. In the Create Routed Outside dialog box, perform the following actions:
1. In the Name field, enter a name for the profile.

Operating Cisco Application Centric Infrastructure


97
Fabric Connectivity
Layer 3 Integration Through Tenant Network with OSPF NSSA

2. In the Private Network drop-down list, choose the private network for this tenant.
3. Click the OSPF check box.
4. In the OSPF Area ID field, enter the OSPF area ID, such as "1".
5. In the OSPF Area Control section, click the Send redistributed LSAs into NSSA area check
box.
6. In the OSPF Area Type section, click the NSSA Area radio button.
7. In the Nodes and Interfaces Protocol Profiles section, click + to add a profile.
8. In the Create Node Profile dialog box, perform the following actions:
1. In the Name field, enter a name for the profile.
2. In the Nodes section, click + to add a node.
3. In the Select Node dialog box, perform the following actions:
1. In the Node ID drop-down list, choose a node, such as Leaf-1.
2. In the Router ID field, enter the router's IP address as the ID, such as "10.0.1.1".
3. Uncheck the Router ID as Loopback Address check box.
4. In the Loopback Addresses section, click + to add a loopback address.
5. Enter the loopback address, such as "10.254.254.1", and click Update.
6. Click OK.

4. In the OSPF Interface Profiles section, click + to create an OSPF interface profile.
5. In the Create Interface Profile dialog box, perform the following actions:
1. In the Name field, enter a name for the profile.
2. In the OSPF Policy drop-down list, choose Create OSPF Interface Policy. When defining
the interaction with another OSPF router, you must specify the policy interaction. This
document does not explain the different OSPF parameters.
3. In the Create OSPF Interface Policy dialog box, perform the following actions:
Ordered List Number 5 In the Name field, enter a name for the OSPF
policy, such as "OSPF-Point2Point".
Ordered List Number 5 In the Network Type section, click the radio
button that matches the adjacent router, such as
Point to Point.
Ordered List Number 5 Complete the remainder of the dialog box as
appropriate to your setup.
Ordered List Number 5 Click Submit.

4. In the Interfaces section, click on the Routed Intefaces tab.


5. Click the + sign to select a routed interface.

Operating Cisco Application Centric Infrastructure


98
Fabric Connectivity
External Layer 3 for Multiple Tenants

6. In the Select Routed Interface dialog box, perform the following actions:
Ordered List Number 5 In the Path drop-down list, choose the interface
on the leaf, such as e1/9 on Leaf-1.
Ordered List Number 5 In the IP Address field, enter the IP address of
the path that is attached to the layer 3 outside
profile, such as "10.0.1.1/24".
Ordered List Number 5 In the MTU (bytes) field, enter the maximum
MTU of the external network, such as "1500" to
match the example peering router.
Ordered List Number 5 Complete the remainder of the dialog box as
appropriate to your setup and click OK.

7. Click OK.

6. Click OK.

9. Click Next.
10. In the External EPG Networks section, click + create an external network.
11. In the Create External Network dialog box, perform the following actions:
1. In the IP Address field, enter 0.0.0.0/0 to permit the learning of any subnet and click OK.

12. Click Finish. Next, you must configure the external network EPG.

External Layer 3 for Multiple Tenants


In ACI, you can use various mechanisms to reuse the same external Layer 3 router for multiple tenants. If the
adjacent router is a Cisco Nexus Series Switch with a Layer 2 trunk interface, the external Layer 3 connection
can be configured to route via SVI. For routers capable of using sub-interfaces, those can be used to provide
multiple external Layer 3 connection for multiple VRFs and/or tenants. The fabric operator can configure
multiple external Layer 3 connections using either sub-interface or SVI and provide that to each tenant.

Application Migration Use Case


When operating the ACI fabric, there can be occasions when you will have to migrate workloads, servers or
virtualization hosts from outside the ACI fabric, onto the fabric. One common example is when migrating
from a traditional data center configuration over to a policy-driven data center using ACI. As ACME starts
to use ACI in more of their data centers, it will be come necessary to perform these migrations. In this example,
ACME must manage the migration of switched virtual interfaces (SVI) as well as the policy allowing traffic
to traverse a Layer 2 outside network and then on to the ACI fabric.
At a high level, you must start by configuring the Layer 2 outside network to allow traffic from the source
VLAN to communicate with the same VLAN residing on the ACI fabric. You will also need to configure
Layer 3 connectivity from the fabric out to the existing Layer 3 networks in preparation for full connectivity
after SVI migration.

Operating Cisco Application Centric Infrastructure


99
Fabric Connectivity
Extending the Network to ACI

Further information and steps on how to create this Layer 2 and Layer 3 connectivity including the policy,
can be found in the Fabric Connectivity chapter of this book.
Once they have successfully established connectivity between the outside Layer 2 network (where the workload
or host is coming from) and the existing internal fabric EPG, you can then start the migration process of
moving application workloads onto the fabric. One key consideration should be when to switch over the SVI
interfaces from the existing environment into the ACI fabric and when to start advertising routes to this SVI
network. Assuming that the SVIs reside on the external Layer 2 network, Cisco recommends that you move
the SVIs over to the ACI fabric once a majority of the hosts have been migrated over.

Extending the Network to ACI


One of the ACME sites would like to migrate from the legacy data center architecture to the next generation
Cisco Application Centric Infrastructure (ACI) Fabric. They would like to migrate with minimal service
interruption while taking advantage of ACI innovations where applicable. ACME would like to perform the
migration in multiple stages.
The Legacy data center prior to migration:
Figure 31: Traditional pre-migration data center

The ACI data center following migration:

Operating Cisco Application Centric Infrastructure


100
Fabric Connectivity
Extending the Network to ACI

Figure 32: Post-migration ACI based data center topology

The first stage will provide connectivity from the legacy data center to the ACI fabric. In this state, you
logically map a VLAN=EPG. The interconnect from the legacy network to the ACI fabric will be accomplished
through standard Layer 2 extensions (VLAN/VXLAN).
Provide physical connectivity from the existing aggregation layer to the ACI border leafs. This connectivity
can be accomplished in either the form of a Virtual Port Channel, Port Channel, or a single interface.
1. Provide a physical connection from aggregation switch #1 to the ACI border leaf #1.
2. Provide a physical connection from aggregation switch #2 to the ACI border leaf #1.
Note: Before connecting external physical connections into the fabric, the Fabric Access Policies for the
access ports that you will be used for the DCI must be configured. For details on configuring the access policies
please reference the Fabric Connectivty section of this book.
Configure the aggregation links as a Layer 2 trunk.
1. Trunk the VLAN representing the host connectivity. This allows for the host VLAN to be extended into
the fabric.
In the Application Policy Infrastructure Controller (APIC) you will now configure a single tenant. The created
tenant will represent the legacy data center into the ACI fabric.

Operating Cisco Application Centric Infrastructure


101
Fabric Connectivity
Extending the Network to ACI

Operating Cisco Application Centric Infrastructure


102
CHAPTER 5
Tenants
• ACI Tenancy Models, on page 103
• Application Profile, on page 105

ACI Tenancy Models


ACME Inc. will be using tenancy for a couple of use cases. They will be using tenant constructs for the
application lifecycle of their current deployment, maintaining a separate tenant for the resources that developers
will be using to build the application, a tenant that will be used for the automated testing, and finally a
production tenant. Additionally, as mentioned in the introduction, they are also looking to build an infrastructure
which can be leveraged for similar initiatives in the future. Tenants will be used to draw virtual boundaries
for different lines of business. The information security team will be able to integrate this into the corporate
LDAP system, and prevent changes which would impact other groups.
Cisco Application Centric Infrastructure (ACI) has been designed from the beginning to be "multi-tenant".
This means different things to different people (much like the term Cloud) based on their perspective. In the
case of a classic service provider, a tenant is a unique customer, while in a typical end-customer environment
a tenant could be an operating group, business unit, application owner, and so on.
The decision on how to leverage tenancy models is driven by a number of factors:
1. Overall IT operations and support models in your organization to manage application, networking, servers,
security, and so on.
2. Separation of environments from a software development lifecycle perspective: development, quality
assurance, and production.
3. Separation of duties by domain owner, such as web, app, and database owners.
4. Fault domain size and scope to limit the impact of failures, such as different business units.
In traditional networking environments, making a routing protocol change on a router or Layer 3 switch could
potentially affect hundreds of unique VLANs/subnets. This introduces a warranted level of caution around
change control and application impact. Leveraging the ACI policy model, the physical hardware is abstracted
from the logical constructs. The tenant object gives us the ability to draw a box around the logical and concrete
objects that we use to provide a unified view of the configuration dependencies for underlay and overlay
networks.
A tenant in the ACI object model represents the highest-level object. Inside, you can differentiate between
the objects that define the tenant networking, such as private networks (VRFs), bridge domains and subnets;
and the objects that define the tenant policies such as application profiles and endpoint groups.

Operating Cisco Application Centric Infrastructure


103
Tenants
ACI Tenancy Models

In ACI, the tenant policies are where you define applications. An application could consist of a combination
of physical servers or virtual machines that we will call servers from now on. For example, a website could
use a 3-tier application model, comprised of web servers, application servers and database servers. When a
user browses the web site, they might actually be communicating with a virtual IP address on a load balancer
that in turn can distribute the web request to a number of different web servers. The web servers in turn
communicate with core applications that can be divided amongst several application servers for load balancing
or high availability purposes. Finally, the application servers communicate with the database which could
also be a cluster of servers.
Each server is referred to as an endpoint in ACI. Endpoints are classified in ACI to apply policies. You create
endpoint groups with endpoints that share the same type of policies, such as with whom are they going to
communicate and what type of communication or restrictions are required. Therefore, an application can be
formed by several endpoint groups and they are grouped in an application profile.
The tenant networking is used to define networking policies and will be applied to the underlying hardware
in a transparent way thanks to the layer of abstraction provided by ACI using private networks, bridge domains
and subnets. In the next sections of this chapter, these concepts will be covered in detail. Below you can find
an illustration with the different objects that compound a tenant and how they are related.
Although the tenant networking and the tenant policies are defined separately, the networking policies used
by an application are defined with a relationship between the endpoint groups and the bridge domain.
The following image shows all of the components that can be configured within a tenant. In the following
sections each diagram shows the progress of how ACME Inc. adds each component.
Figure 33: Tenant Logical Model

There are 3 tenants that are preconfigured in the system by default:


1. Common—A special tenant with the purpose of providing "common" services to other tenants in the ACI
fabric. Global reuse is a core principle in the common tenant. Some examples of common services are:
1. Shared L3 out
2. Shared private networks
3. Shared bridge domains
4. DNS
5. DHCP
6. Active directory

Operating Cisco Application Centric Infrastructure


104
Tenants
Application Profile

2. Infra—The Infrastructure tenant that is used for all internal fabric communications, such as tunnels and
policy deployment. This includes switch to switch (leaf, spine, Application Virtual Switch (AVS)) and
switch to Application Policy Infrastructure Controller (APIC). The Infra tenant does not get exposed to
the user space (tenants) and it has its own private network space and bridge domains. Fabric discovery,
image management, and DHCP for fabric functions are all handled within this tenant.
3. Mgmt—The management tenant provides convenient means to configure access policies for fabric nodes.
While fabric nodes are accessible and configurable through the APIC, they can also be accessed directly
using in-band and out-of band connections. In-band and out-of-band policies are configured under the
mgmt tenant:
• In-Band Management Access
• Out-of-Band Management Access

Application Profile
An application profile is a convenient logical container for multiple hosts (physical or virtual). You can create
application profile containers based on a variety of criteria, such as what function the application provides,
how the application looks from the end-user perspective, where they are located within the context of the data
center, or any other logical grouping relative to the implementation. Application profile servers are grouped
in endpoint groups depending on the use of common policies.
Application profiles provide a mechanism to understand groups of servers as a single application. This approach
makes an Cisco Application Centric Infrastructure (ACI) application aware and allows us to check the
operational state for an application while monitoring all the servers that are part of an application as a whole.
Furthermore, an administrator can become informed about relevant faults and health status for that particular
application. Each application profile created can have a unique monitoring policy and QOS policy applied.
An application profile is a child object of the Tenant and a single Tenant can contain multiple application
profiles.
Figure 34: Adding components to a Tenant - 1. Application Profile

Operating Cisco Application Centric Infrastructure


105
Tenants
Application Profile Configuration

Application Profile Configuration


Name - The name of the application profile.
Tags - A tag or metadata is a non-hierarchical keyword or term assigned to the fabric module.
Monitoring Policy - The monitoring policy name for the EPG semantic scope (optional).

Creating a New Application Profile Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles.
4. In the Work pane, choose Actions > Create Application Profile.
5. In the Create Application Profile dialog box, perform the following actions:
1. Enter an application profile Name.
2. Enter a description (optional).
3. Enter a TAG (optional).
4. Choose a monitoring policy (optional).

6. Click Submit.

Modifying an Application Profile Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile.
4. In the Work pane, choose Policy.
5. In the Work pane, you can perform the following actions:
1. Enter a description (optional).
2. Enter an appropriate TAG (optional).
3. Enter a label (optional).
4. Choose a QoS class (optional).
5. Choose the monitoring policy (optional).

6. Click Submit.

Removing Application Profile Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.

Operating Cisco Application Centric Infrastructure


106
Tenants
Verify Application Profile

2. In the Work pane, choose the Tenant_Name .


3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile.
4. In the Work pane, choose Policy.
5. In the Work pane, choose Actions > Delete.

Verify Application Profile


REST :: /api/node/class/fvAp.xml
CLI :: moquery -c fvAp

Endpoint Group
Endpoint groups (EPGs) are used to create logical groupings of hosts or servers that perform similar functions
within the fabric and that will share similar policies. Each endpoint group created can have a unique monitoring
policy or QoS policy and are associated with a bridge domain.
An endpoint group is a child object of the application profile and an application profile can contain multiple
endpoint groups. Each endpoint within an endpoint group is susceptible to the same policy in the Fabric.
Figure 35: Adding components to a tenant - 2. End Point Group in the Application Profile

All of the endpoints inside an EPG can communicate with each other. Communications between EPGs is
governed by contracts and not traditional Layer 2/Layer 3 forwarding constructs. For example, Host-A in
EPG-A can have the IP address/mask of 10.1.1.10/24 and Host B in EPG B can have the IP address/mask
10.1.1.20/24 (note that both hosts believe they are "in the same subnet"). In this case they would not be allowed
to communicate unless a contract that permitted connectivity existed between EPG-A and EPG-B. Contracts
will be explained in greater detail in a following section.
There are some types of endpoint groups within the fabric that are not contained under application profiles
such as, Application endpoint group, External Bridge Networks (aka Layer2 External), External Routed
Networks (aka as Layer3 External) and Management endpoint groups. These endpoint groups might have
special requirements, for example, in External Bridge Networks, MAC addresses of the endpoints are not
learnt by the leaf switches.

Operating Cisco Application Centric Infrastructure


107
Tenants
Endpoint Group Subtypes

Endpoint groups are linked to bridge domains but they will receive a VLAN ID different from the bridge
domain, unless Bridge Domain legacy mode is used.
It is important to understand that a single subnet can be extended across several EPGs. Each EPG is identified
by an encapsulation VLAN or VXLAN so that the same subnet will be using different encapsulation IDs
across the fabric. This concept is different from traditional networking.

Endpoint Group Subtypes


In Application Policy Infrastructure Controller (APIC) software version 1.1, legacy endpoint group became
split into two types:

Application Endpoint Group


This is the traditional endpoint group, which can be applied to Virtual or Physical endpoints using static path
bindings, VMM integration, or Layer 2/Layer 3 domain binding.

Microsegment (uSeg) endpoint group


This classification of endpoint group allows various "attributes" to be matched against endpoints to assign
them automatically into a uSeg endpoint group. This type of endpoint group is also referred to as attribute-based
endpoint groups. Some of the attributes that you can match against include VM properties (such as VM Name,
VM ID, and Hypervisor), MAC addresses, and IP sets.
Once a uSeg endpoint group has been created and eventually assigned to a VMM domain, it will auto-match
on any endpoint within the VMM domain that exists within the tenant and move any endpoints from their
assigned application endpoint group to the uSeg endpoint group. Once this occurs, any policies applied to the
uSeg EPG (Contracts, QoS, Monitoring Policies, and so on) are now applied. Policies from their original
application EPG are no longer applied to the endpoint.

Note VM endpoints are assigned to their application endpoint group, but the fabric will automatically move them
to their uSeg endpoint group if an attribute match exists. This means that within their Virtual Machine Manager
(vCenter), the endpoint will still show as assigned to the application EPG/port group. However, if you examine
the uSeg EPG > Operational > Client End Points, you should see the endpoint learned under its new uSeg
EPG.

When adding attributes to a uSeg endpoint group, it must not be currently assigned to any VMM domains.
This ensures the endpoint group is not currently assigned to any VM endpoints and therefore prevents
accidentally moving of functional endpoints by mistakenly assigning an attribute to an always bound VM
domain. For this reason, during the create uSeg endpoint group procedure, you must create the endpoint group
first, then add the VMM domain afterwards. This ensures that a uSeg endpoint group's attributes are assigned
before the VMM domain is added.

Creating a New Endpoint Group


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile > Application
EPGs.

Operating Cisco Application Centric Infrastructure


108
Tenants
Modify Endpoint Group

4. In the Work pane, choose Actions > Create Application EPG.


5. In the Create Application EPG dialog box, perform the following.
1. Enter an Application EPG Name.
2. Enter an Tag (optional).
3. Enter an Qos Class (optional).
4. Enter an Custom Qos (optional).
5. Choose or create a Bridge Domain Name.
6. Choose a Monitoring Policy (optional).
7. Choose to associate to VM domain profile (optional).
8. Choose to statically link with leaves/paths (optional)

6. Click Finish.

Modify Endpoint Group


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile > Application
EPGs > Application_EPG .
4. In the Work pane, select policy.
1. Enter an Application EPG Name.
2. Enter an Tag (optional).
3. Enter an Qos Class (optional).
4. Enter an Custom Qos (optional).
5. Enter a Bridge Domain Name.
6. Choose the appropriate Monitoring Policy if applicable (optional).
7. Enter an Associated Domain Profile Name.

5. Click Finish.

Remove Endpoint Group


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile > Application
EPGs > Application_EPG ..
4. In the Work pane, choose Actions > Delete.

Operating Cisco Application Centric Infrastructure


109
Tenants
Verify Endpoint Group

Verify Endpoint Group


REST :: /api/node/class/fvAEPg.xml
CLI :: moquery -c fvAEPg

Endpoint
Endpoints are devices that are connected to the network either directly or indirectly. Endpoints have an address
(identity), a location, and attributes, and can be either virtual or physical. Each endpoint has a path, an
encapsulation, and a deployment Immediacy mode associated with it.
An Endpoint is a child object of the Endpoint Group and an Endpoint Group construct can contain multiple
Endpoints. The Endpoints referenced within the fabric can be either static (defined within the APIC) or dynamic
(automated by vCenter/Openstack).
You can add Static Endpoints by creating Static Bindings within the Endpoint Group. Below is an example
of a static binding. See the VVM section for an example of a dynamic binding.
In order to show the endpoints that are connected to the fabric under certain EPGs:

Verify Endpoint
REST :: /api/node/class/fvCEp.xml
CLI :: moquery -c fvCEp

Private Networks
A private network is also referred to as a Virtual Routing and Forwarding (VRF) , private Layer 3 network,
or context. It is a unique Layer 3 forwarding and application policy domain. Private networks are a child of
the Tenant object. All of the endpoints within the private network must have unique IP addresses because it
is possible to forward packets directly between these devices if the policy allows it. One or more bridge
domains are associated with a private network.
Figure 36: Adding components to a Tenant - 3. Private Network as part of the Tenant Logical Model

The most common method to share private networks between tenants is through the common tenant. For more
information about common tenants, see the overview section of this chapter. Private networks created in the

Operating Cisco Application Centric Infrastructure


110
Tenants
Private Network Configuration Parameters

common tenant are shared globally within the fabric. However, a private network that is intended to be used
by multiple tenants and is not created in the common tenant requires explicit configuration to be shared.
When there is a requirement to route traffic between separate private network instances, special consideration
for subnet configuration is needed. This will be discussed in detail in the bridge domain and endpoint group
configuration sections.

Private Network Configuration Parameters


The following list describes the private network configuration parameters:
• Name—The name of the private network.
• Policy Control Enforcement Preference—The preferred policy control. The values can be enforced or
unenforced. When enforced is chosen, contracts between endpoint groups are required to allow traffic.
Unenforced allows all traffic within the Private Network. The default is enforced.
• Policy Control Enforcement Direction—The preferred policy control in relation to where the policy will
be applied, that is to say in which direction. The default is ingress.
• End Point Retention Policy—The end point retention policy name (optional).
• Monitoring Policy—The monitoring policy name for the Tenant semantic scope (optional).
• DNS Label—The network domain name label. Labels enable classifying which objects can and cannot
communicate with one another (optional).
• BGP Timers—Name of the BGP timers policy associated with this object.
• OSPF Timers—Name of the OSPF timers policy associated with this object.
• OSPF Address Family Context—The OSPF Address Family Context policy name.
• EIGRP Address Family Context—The EIGRP Address Family Context policy name.

Creating a New Private Network


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > VRFs.
4. In the Work pane, choose Actions > Create VRF.
5. In the Create VRF dialog box, perform the following actions:
1. Enter a private network or VRF name.
2. Choose a policy control enforcement preference (optional).
3. Choose a policy control enforcement direction (optional)
4. Choose an endpoint retention policy name (optional).
5. Choose the appropriate monitoring policy, if applicable (optional).
6. Choose the appropriate DNS label, if applicable (optional).
7. Choose the route tag policy, if applicable (optional).

Operating Cisco Application Centric Infrastructure


111
Tenants
Modifying a Private Network Using the GUI

8. Create a bridge domain (optional).


9. Configure BGP policies (optional).
10. Choose EIGRP policies (optional).

6. Click Finish. If you have performed any of the option creation or configuration steps, such as creating a
bridge domain, or configuring BGP, OSPF, or EIGRP policies, click Next
7. If you clicked Next, follow the on-screen prompts to configure your relevant additional policies.

Modifying a Private Network Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > VRFs > Private_Network.
4. In the Work pane, choose Policy.
1. Choose a policy control enforcement preference (optional).
2. Choose a policy control enforcement direction (optional).
3. Choose a BGP timers policy (optional).
4. Modify a BGP context per address family, using the add/delete icons (optional).
5. Choose an OSPF timers policy (optional).
6. Modify a OSPF context per address family, using the add/delete icons (optional).
7. Choose an endpoint retention policy name (optional).
8. Choose the appropriate monitoring policy, if applicable (optional).
9. Modify a EIGRP context per address family, using the add/delete icons (optional).
10. Choose the appropriate DNS label, if applicable (optional).
11. Choose the route tag policy, if applicable (optional)

5. Click Submit.

Removing Private Network Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > VRFs > Private_Network.
4. In the Work pane, choose Actions > Delete.

Verify Private Network


REST :: /api/node/class/fvCtx.xml

Operating Cisco Application Centric Infrastructure


112
Tenants
Bridge Domain

CLI :: moquery -c fvCtx

Bridge Domain
A bridge domain is the logical representation of a Layer 2 forwarding domain within the fabric. A bridge
domain is a child of the tenant object and must be linked to a private network.
The bridge domain defines the unique Layer 2 MAC address space and a Layer 2 flood domain if flooding is
enabled. While a private network defines a unique IP address space, that address space can consist of multiple
subnets. Those subnets will be spread across one or more bridge domains contained in the private network.
Bridge domains will span all switches in which associated endpoint groups are configured. A bridge domain
can have multiple subnets. However, a subnet is contained within a single bridge domain.
Figure 37: Adding components to a Tenant - 4. Bridge Domain as part of the Tenant Application Profile

The following image provides an example of a tenant to show how bridge domains are contained inside of
private networks and how they are linked to endpoint groups and the other elements.

Operating Cisco Application Centric Infrastructure


113
Tenants
Bridge Domain

Figure 38: End Point Group as part of the Tenant Application Profile

A bridge domain is not a VLAN, although it can act similar to a VLAN. Think of a bridge domain as a
distributed switch, which, on a leaf, can be translated locally as a VLAN with local significance.
From a practical perspective, each bridge domain will exist in a particular leaf if there is a connected endpoint
that belongs to that endpoint group. Each bridge domain receives a VLAN ID in the leaf switches.
The VLAN ID used is also called the platform independent VLAN or PI VLAN. This VLAN concept is
different from traditional networking and is not used to forward traffic, but as an identifier. Each PI VLAN
is then linked to a VXLAN ID that will be used for forwarding purposes inside of the fabric.
In the following example, under the Tenant Acme, the bridge domain Acme-Applications-BD was assigned
the PI VLAN ID 42 in the Leaf-1.
Endpoint groups are also assigned with a PI VLAN ID that is locally significant in each leaf. This VLAN ID
is different from the bridge domain. Therefore in Cisco Application Centric Infrastructure (ACI), several
VLANs will be used for endpoints inside on one bridge domain. For more details refer to the endpoint section
in this chapter.
When a Subnet is defined in a bridge domain, the leaf switches will be the default gateway for the endpoint
groups using that subnet. If the endpoint groups have endpoints on multiple leaves, each leaf will configure
the default gateway. In that way, the default gateway for the endpoints will always be the first switch of the
fabric that is reached, also know as a pervasive gateway. This means that an SVI will be configured under the

Operating Cisco Application Centric Infrastructure


114
Tenants
Bridge Domain Configuration Parameters

VRF that represents the private network that the bridge domain is linked to. If a bridge domain has several
subnets, there will be only one SVI per bridge domain but it will use secondary IP addresses.

Bridge Domain Configuration Parameters


• Name—The name of the bridge domain.
• Network—The associated Layer 3 context.
• Forwarding—Optimize/Custom.
• L2 Unknown Unicast—The forwarding method for unknown Layer 2 destinations. Default method is
Proxy, which means that the leaf will forward to the spine for a lookup using a global database. If the
destination is not found, it is dropped. The second method is Flood, which utilizes a multicast tree rooted
in the spine for a specific bridge domain.
• L3 Unknown Multicast Flooding—The node forwarding parameter for unknown multicast destinations.
You can choose Flood or Optimized Flood.
• Multidestination Flood—This parameter configures the flooding behavior for Layer 2 multidestination
flood, such as multicast, broadcast, and link local-specific traffic. You can choose to flood in the bridge
domain (default), drop all of the traffic, or flood in an encapsulation or VLAN.
• ARP Flooding—A property to specify whether ARP flooding is enabled. If flooding is disabled, unicast
routing will be performed on the target IP address. ARP flooding is disabled by default.
• Unicast Routing—The forwarding method based on predefined forwarding criteria (IP or MAC address).
Unicast routing is enabled by default. Unicast routing uses a destination IP address to forward traffic by
creating specific /32 routes in hardware.
• Config BD MAC Address—The MAC address of the bridge domain or switched virtual interface (SVI).
Every bridge domain by default takes the fabric-wide default MAC address.
• IGMP Snoop Policy—The IGMP Snooping policy name. By examining (snooping) IGMP membership
report messages from interested hosts, multicast traffic is limited to the subset of VLAN interfaces on
which the hosts reside.
• Associated L3 Outs—The name of the Layer 3 outside interface associated with this object.
• L3 Out for Route Profile—The Layer 3 outside interface identifier controlling connectivity to outside
networks.
• Route Profile—The associated route profile name.
• Monitoring Policy—The monitoring policy name for the tenant semantic scope (optional).
• Subnets—The network visibility of the subnet. The subnet is a portion of a network sharing a particular
subnet address. The scope can be:
• Shared Between VRFs—Defines subnets under an endpoint group, with the Shared option
configured, to route leak to other tenants within the Fabric.
• Advertise Externally—Defines subnets under a bridge domain, with the Public option configured,
to share with Layer 3 outbound.
• Private to VRF—Defines subnets under a bridge domain, with the Private option configured, to
only be used in that tenant (will not be leaked). The default is Private.

Operating Cisco Application Centric Infrastructure


115
Tenants
Creating a New Bridge Domain Using the GUI

• Subnet Control—The control can be specific protocols applied to the subnet such as IGMP Snooping.
The control can be:
• Querier IP—Enables IGMP snooping on the subnet.
• DHCP Labels—The network domain name label.

Creating a New Bridge Domain Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > Bridge Domains.
4. In the Work pane, choose Actions > Create Bridge Domain.
5. In the Create Bridge Domain dialog box, perform the following actions:
1. Enter an Bridge Domain Name.
2. Choose the Network.
3. Choose the Forwarding Semantics (optional).
4. Choose the IGMP Snoop Policy (optional).
5. Choose the Associated L3 Outs (optional).
6. Choose the L3 Out for Route Profile (optional).
7. Choose the Route Profile (optional).
8. Choose the Monitoring Policy if applicable (optional).
9. Choose the Subnets (optional).
10. Choose the DNS Label if applicable (optional).

6. Click Submit.

Creating a New Bridge Domain Using the NX-OS-Style CLI


You can use the NX-OS-Style CLI to create a bridge domain.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure

Step 3 Enter the configure mode for a tenant:


apic1(config)# tenant tenant1

Operating Cisco Application Centric Infrastructure


116
Tenants
Modifying a Bridge Domain Using the GUI

Step 4 Enter the configure mode for a bridge domain:


apic1(config-tenant)# bridge-domain bd1

Step 5 Enter the configure mode for a VRF:


apic1(config-bd)# vrf vrf1

Step 6 Enter ? for a list of commands.

Modifying a Bridge Domain Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > Bridge Domains >
Bridge_Domain_Name.
4. In the Work pane, choose the Policy tab and perform the following actions:
1. Choose the Network.
2. Choose the Forwarding Semantics (optional).
3. Choose the IGMP Snoop Policy (optional).
4. Choose the Associated L3 Outs (optional).
5. Choose the L3 Out for Route Profile (optional).
6. Choose the Route Profile (optional).
7. Choose the Monitoring Policy if applicable (optional).
8. Choose the Subnets (optional).
9. Choose the DNS Label if applicable (optional).

5. Click Finish.

Modifying a Bridge Domain Using NX-OS-Style CLI


You can use the NX-OS-style CLI to modify a bridge domain.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure

Step 3 Enter the configure mode for a tenant:

Operating Cisco Application Centric Infrastructure


117
Tenants
Removing a Bridge Domain Using the GUI

apic1(config)# tenant tenant1

Step 4 Enter the configure mode for a bridge domain:


apic1(config-tenant)# bridge-domain bd1

Step 5 Enter ? for a list of commands.

Removing a Bridge Domain Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation Pane choose Tenant_Name > Networking > Bridge Domain > Bridge Domain_Name.
4. In the Work pane, choose Actions > Delete.

Removing a Bridge Domain Using NX-OS-Style CLI


You can use the NX-OS-style CLI to remove a bridge domain.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure

Step 3 Enter the configure mode for a tenant:


apic1(config)# tenant tenant1

Step 4 Remove the bridge domain:


apic1(config-tenant)# no bridge-domain bd1

Verifying a Bridge Domain Using the Object Model CLI


You can use the object model CLI to verify the bridge domains.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Switch to the object model CLI:

Operating Cisco Application Centric Infrastructure


118
Tenants
Tenant Networking Use Cases

apic1# bash
admin@apic1:~>

Step 3 Verify a concrete bridge domain:


admin@apic1:~> moquery -c l2BD

Step 4 Verify a resolved bridge domain:


admin@apic1:~> moquery -c fvBDDef

Step 5 Verify a local bridge domain:


admin@apic1:~> moquery -c fvBD

Tenant Networking Use Cases


Common Private Network for All Tenants
This use case may be typical for environments where an ACI administrator wishes to create multiple tenants,
but place all within a single private network in the fabric.
This method has the following advantages and disadvantages:
Advantages:
• Ability to use a single private network for all internal and external fabric connectivity
• No route leaking needed between EPGs in different VRFs
• Single Layer 3 Outside can be used by all tenants
Disadvantages:
• Changes to routing will impact all tenants
From a containment and relationship perspective, this topology looks as follows:
Figure 39: Common Private Network for all Tenants

To Configure the common Tenant private network:


The Tenant has been created. Now the network administrator will have to associate the common private
network to the Tenant by first creating a bridge domain.
The configuration for this use case can be applied via the following CLI configuration:
CLI : Tenant Cisco

# tenant

Operating Cisco Application Centric Infrastructure


119
Tenants
Common Private Network for All Tenants

cd '/aci/tenants'
mocreate 'Cisco'
moconfig commit
# bridge-domain
cd '/aci/tenants/Cisco/networking/bridge-domains'
mocreate 'Cisco'
cd 'Cisco'
moset network 'default'
moconfig commit
# subnet
cd '/aci/tenants/Cisco/networking/bridge-domains/Cisco/subnets'
mocreate '172.16.0.1/24'
moconfig commit
# application-profile
cd '/aci/tenants/Cisco/application-profiles'
mocreate 'App1'
moconfig commit
# application-epg
cd '/aci/tenants/Cisco/application-profiles/App1/application-epgs'
mocreate 'EPG1'
cd 'EPG1'
moset bridge-domain 'Cisco'
moconfig commit
# criterion
cd '/aci/tenants/Cisco/application-profiles/App1/application-epgs/EPG1/vm-attributescriteria'
mocreate 'default'
moconfig commit

This configuration can also be applied using the following XML posted to the APIC REST API
XML : Tenant Cisco

<fvTenant name="Cisco">
<fvBD arpFlood="no" multiDstPktAct="bd-flood" name="Cisco" unicastRoute="yes"
unkMacUcastAct="proxy" unkMcastAct="flood">
<fvRsCtx tnFvCtxName="default"/>
<fvSubnet ctrl="nd" descr="" ip="172.16.0.1/24" preferred="no"
scope="private"/>
</fvBD>
<fvAp name="App1">
<fvAEPg matchT="AtleastOne" name="EPG1">
<fvRsBd tnFvBDName="Cisco"/>
</fvAEPg>
</fvAp>
<fvRsTenantMonPol tnMonEPGPolName=""/>
</fvTenant>

For many multi-tenant environments it is desirable to allow each tenant to manage and own their own address
space and not be concerned with overlaps between other tenants. This particular use case demonstrates how
a private network can be associated with each tenant. One Private Network per Tenant with Intra-EPG
communications
Advantages:
• Allow for maximum isolation between tenants
• Ability to address hosts in tenants with overlapping IP addresses
Disadvantages:
• Increased complexity when needing to allow EPG communication between different tenants with dedicated
VRF
The object containment for this particular setup can be depicted as shown below:

Operating Cisco Application Centric Infrastructure


120
Tenants
Common Private Network for All Tenants

Figure 40: Private Network per Tenant

To create the tenant:


The configuration for this use case can be applied via the following CLI configuration:
CLI : Tenant Cisco

# tenant
cd '/aci/tenants'
mocreate 'Cisco'
moconfig commit
# bridge-domain
cd '/aci/tenants/Cisco/networking/bridge-domains'
mocreate 'Cisco'
cd 'Cisco'
moset network 'Cisco'
moconfig commit
# subnet
cd '/aci/tenants/Cisco/networking/bridge-domains/Cisco/subnets'
mocreate '172.16.0.1/24'
moconfig commit
# private-network
cd '/aci/tenants/Cisco/networking/private-networks'
mocreate 'Cisco'
moconfig commit
# application-profile
cd '/aci/tenants/Cisco/application-profiles'
mocreate 'App1'
moconfig commit
# application-epg
cd '/aci/tenants/Cisco/application-profiles/App1/application-epgs'
mocreate 'EPG1'
cd 'EPG1'
moset bridge-domain 'Cisco'
moconfig commit

This configuration can also be applied using the following XML posted to the APIC REST API:
XML : Tenant Cisco

<fvTenant name="Cisco">
<fvBD arpFlood="no" multiDstPktAct="bd-flood" name="Cisco" unicastRoute="yes"
unkMacUcastAct="proxy" unkMcastAct="flood">
<fvRsCtx tnFvCtxName="Cisco"/>

Operating Cisco Application Centric Infrastructure


121
Tenants
Multiple Private Networks with Intra-Tenant Communication

<fvSubnet ctrl="nd" ip="172.16.0.1/24" name="" preferred="no" scope="private"/>


</fvBD>
<fvCtx knwMcastAct="permit" name="Cisco" pcEnfPref="enforced"/>
<fvAp name="App1" prio="unspecified">
<fvAEPg name="EPG1">
<fvRsBd tnFvBDName="Cisco"/>
</fvAEPg>
</fvAp>
</fvTenant>

Multiple Private Networks with Intra-Tenant Communication


Another use case that may be desirable to support is the option to have a single tenant with multiple private
networks. This may be a result of needing to provide multi-tenancy at a network level, but not at a management
level. It may also be caused by needing to support overlapping subnets within a single tenant, due to mergers
and acquisitions or other business changes.
This method has the following advantages and disadvantages:
Advantages:
• Ability to have overlapping subnets within a single tenant
Disadvantages:
• EPGs residing in overlapping subnets cannot have policy applied between one another
The object containment for this particular setup can be depicted as shown below:
Figure 41: Multiple Private Networks with Intra-Tenant Communication

To create the tenant:


The configuration for this use case can be applied via the following CLI configuration:
CLI : Tenant Cisco

# tenant
cd '/aci/tenants'

Operating Cisco Application Centric Infrastructure


122
Tenants
Multiple Private Networks with Intra-Tenant Communication

mocreate 'Cisco'
moconfig commit
# bridge-domain
cd '/aci/tenants/Cisco/networking/bridge-domains'
mocreate 'Cisco'
cd 'Cisco'
moset network 'Cisco'
moconfig commit
# bridge-domain
cd '/aci/tenants/Cisco/networking/bridge-domains'
mocreate 'Cisco1'
cd 'Cisco1'
moset network 'Cisco1'
moconfig commit
# private-network
cd '/aci/tenants/Cisco/networking/private-networks'
mocreate 'Cisco'
moconfig commit
# private-network
cd '/aci/tenants/Cisco/networking/private-networks'
mocreate 'Cisco1'
moconfig commit
# application-profile
cd '/aci/tenants/Cisco/application-profiles'
mocreate 'App1'
moconfig commit
# application-epg
cd '/aci/tenants/Cisco/application-profiles/App1/application-epgs'
mocreate 'EPG1'
cd 'EPG1'
moset bridge-domain 'Cisco'
moconfig commit
# fv-rscon
cd '/aci/tenants/Cisco/application-profiles/App1/applicationepgs/
EPG1/contracts/consumed-contracts'
mocreate 'ICMP'
moconfig commit
# fv-subnet
cd '/aci/tenants/Cisco/application-profiles/App1/application-epgs/EPG1/subnets'
mocreate '172.16.1.1/24'
cd '172.16.1.1:24'
moset scope 'private,shared'
moconfig commit
# application-epg
cd '/aci/tenants/Cisco/application-profiles/App1/application-epgs'
mocreate 'EPG2'
cd 'EPG2'
moset bridge-domain 'Cisco1'
moconfig commit
# fv-rsprov
cd '/aci/tenants/Cisco/application-profiles/App/applicationepgs/
EPG2/contracts/provided-contracts'
mocreate 'ICMP'
moconfig commit
# fv-subnet
cd '/aci/tenants/Cisco/application-profiles/CCO/application-epgs/EPG2/subnets'
mocreate '172.16.2.1/24'
cd '172.16.2.1:24'
moset scope 'private,shared'
moconfig commit

This configuration can also be applied using the following XML posted to the APIC REST API:
XML : Tenant Cisco

Operating Cisco Application Centric Infrastructure


123
Tenants
Multiple Private Networks with Inter-Tenant Communication

<fvTenant dn="uni/tn-Cisco" name="Cisco">


<vzBrCP name="ICMP" scope="tenant">
<vzSubj consMatchT="AtleastOne" name="icmp" provMatchT="AtleastOne"
revFltPorts="yes">
<vzRsSubjFiltAtt tnVzFilterName="icmp"/>
</vzSubj>
</vzBrCP>
<fvCtx knwMcastAct="permit" name="CiscoCtx" pcEnfPref="enforced"/>
<fvCtx knwMcastAct="permit" name="CiscoCtx2" pcEnfPref="enforced"/>
<fvBD arpFlood="yes" mac="00:22:BD:F8:19:FF" name="CiscoBD2" unicastRoute="yes"
unkMacUcastAct="flood" unkMcastAct="flood">
<fvRsCtx tnFvCtxName="CiscoCtx2"/>
</fvBD>
<fvBD arpFlood="yes" mac="00:22:BD:F8:19:FF" name="CiscoBD" unicastRoute="yes"
unkMacUcastAct="flood" unkMcastAct="flood">
<fvRsCtx tnFvCtxName="CiscoCtx"/>
</fvBD>
<fvAp name="CCO">
<fvAEPg matchT="AtleastOne" name="Web">
<fvRsCons tnVzBrCPName="ICMP"/>
<fvRsPathAtt encap="vlan-1201" instrImedcy="immediate" mode="native"
tDn="topology/pod-1/paths-201/pathep-[eth1/16]"/>
<fvSubnet ip="172.16.2.1/24" scope="private,shared"/>
<fvRsDomAtt instrImedcy="lazy" resImedcy="lazy" tDn="uni/phys-
PhysDomainforCisco"/>
<fvRsBd tnFvBDName="CiscoBD2"/>
</fvAEPg>
<fvAEPg matchT="AtleastOne" name="App">
<fvRsPathAtt encap="vlan-1202" instrImedcy="immediate" mode="native"
tDn="topology/pod-1/paths-202/pathep-[eth1/2]"/>
<fvSubnet ip="172.16.1.1/24" scope="private,shared"/>
<fvRsDomAtt instrImedcy="lazy" resImedcy="lazy" tDn="uni/phys-
PhysDomainforCisco"/>
<fvRsBd tnFvBDName="CiscoBD"/>
<fvRsProv matchT="AtleastOne" tnVzBrCPName="ICMP"/>
</fvAEPg>
</fvAp>
</fvTenant>

Multiple Private Networks with Inter-Tenant Communication


This use case may be typical for environments where an ACI administrator wishes to create multiple tenants
with the ability to support inter-tenant communications.
This method has the following advantages and disadvantages:
Advantages
• Each tenant container can be managed separately
• Allows for maximum isolation between tenants
Disadvantages
• Tenant address space must be unique
From a containment and relationship perspective, this topology looks as follows:

Operating Cisco Application Centric Infrastructure


124
Tenants
Multiple Private Networks with Inter-Tenant Communication

Figure 42: Multiple Private Networks with Inter-Tenant Communication

To create the tenant:


The configuration for this use case can be applied via the following CLI configuration:
CLI : TENANT Cisco1

# tenant
cd '/aci/tenants'
mocreate 'Cisco1'
moconfig commit
# bridge-domain
cd '/aci/tenants/Cisco1/networking/bridge-domains'
mocreate 'Cisco1'
cd 'Cisco1'
moset network 'Cisco1'
moconfig commit
# private-network
cd '/aci/tenants/Cisco1/networking/private-networks'
mocreate 'Cisco1'
moconfig commit
# application-profile
cd '/aci/tenants/Cisco1/application-profiles'
mocreate 'App1'
moconfig commit
# application-epg
cd '/aci/tenants/Cisco1/application-profiles/App1/application-epgs'
mocreate 'EPG1'
cd 'EPG1'
moset bridge-domain 'Cisco1'
moconfig commit
# fv-rsprov
cd '/aci/tenants/Cisco/application-profiles/CCO/applicationepgs/
App/contracts/provided-contracts'
mocreate 'ICMP'
moconfig commit
# fv-subnet
cd '/aci/tenants/Cisco/application-profiles/CCO/application-epgs/App/subnets'
mocreate '172.16.1.1/24'

Operating Cisco Application Centric Infrastructure


125
Tenants
Multiple Private Networks with Inter-Tenant Communication

cd '172.16.1.1:24'
moset scope 'private,shared'
moconfig commit
# contract
cd '/aci/tenants/Cisco/security-policies/contracts'
mocreate 'ICMP'
cd 'ICMP'
moset scope 'global'
moconfig commit
# contract-subject
cd '/aci/tenants/Cisco/security-policies/contracts/ICMP/subjects'
mocreate 'icmp'
moconfig commit
# vz-rssubjfiltatt
cd '/aci/tenants/Cisco/security-policies/contracts/ICMP/subjects/icmp/common-filters'
mocreate 'icmp'
moconfig commit

CLI : TENANT Cisco2

# tenant
cd '/aci/tenants'
mocreate 'Cisco'
moconfig commit
# bridge-domain
cd '/aci/tenants/Cisco/networking/bridge-domains'
mocreate 'Cisco'
cd 'Cisco'
moset network 'Cisco'
moconfig commit
# private-network
cd '/aci/tenants/Cisco/networking/private-networks'
mocreate 'Cisco'
moconfig commit
# application-profile
cd '/aci/tenants/Cisco/application-profiles'
mocreate 'App1'
moconfig commit
# application-epg
cd '/aci/tenants/Cisco2/application-profiles/App1/application-epgs'
mocreate 'EPG1'
cd 'EPG1'
moset bridge-domain 'Cisco'
moconfig commit
# fv-rsconsif
cd '/aci/tenants/Cisco1/application-profiles/CCO/applicationepgs/
Web/contracts/consumed-contract-interfaces'
mocreate 'CiscoInterTenantICMP'
moconfig commit
# fv-subnet
cd '/aci/tenants/Cisco1/application-profiles/CCO/application-epgs/Web/subnets'
mocreate '172.16.2.1/24'
cd '172.16.2.1:24'
moset scope 'shared-subnet'
moconfig commit
# imported-contract
cd '/aci/tenants/Cisco1/security-policies/imported-contracts'
mocreate 'CiscoInterTenantICMP'
cd 'CiscoInterTenantICMP'
moset contract 'tenants/Cisco/security-policies/contracts/ICMP'
moconfig commit

This configuration can also be applied using the following XML posted to the APIC REST API:

Operating Cisco Application Centric Infrastructure


126
Tenants
Multiple Private Networks with Inter-Tenant Communication

XML : TENANT Cisco1

<fvTenant dn="uni/tn-Cisco1" name="Cisco1">

<vzBrCP name="ICMP" scope="global">


<vzSubj consMatchT="AtleastOne" name="icmp" provMatchT="AtleastOne"
revFltPorts="yes">
<vzRsSubjFiltAtt tnVzFilterName="icmp"/>
</vzSubj>
</vzBrCP>

<vzCPIf dn="uni/tn-Cisco1/cif-ICMP" name="ICMP">

<vzRsIf consMatchT="AtleastOne" name="icmp" provMatchT="AtleastOne"


revFltPorts="yes">
<vzRsSubjFiltAtt tDn="uni/tn-Cisco2/brc-default"/>
</vzRsIf>
</vzCPIf>
<fvCtx knwMcastAct="permit" name="CiscoCtx" pcEnfPref="enforced"/>

<fvBD arpFlood="yes" mac="00:22:BD:F8:19:FF" name="CiscoBD2" unicastRoute="yes"


unkMacUcastAct="flood" unkMcastAct="flood">
<fvRsCtx tnFvCtxName="CiscoCtx2"/>
</fvBD>
<fvBD arpFlood="yes" name="CiscoBD" unicastRoute="yes" unkMacUcastAct="flood"
unkMcastAct="flood">
<fvRsCtx tnFvCtxName="CiscoCtx"/>
</fvBD>
<fvAp name="CCO">
<fvAEPg matchT="AtleastOne" name="EPG1">
<fvRsPathAtt encap="vlan-1202" instrImedcy="immediate" mode="native"
tDn="topology/pod-1/paths-202/pathep-[eth1/2]"/>
<fvSubnet ip="172.16.1.1/24" scope="private,shared"/>

<fvRsDomAtt instrImedcy="lazy" resImedcy="lazy" tDn="uni/phys-


PhysDomainforCisco"/>

<fvRsBd tnFvBDName="CiscoBD"/>
<fvRsProv matchT="AtleastOne" tnVzBrCPName="ICMP"/>
</fvAEPg>
</fvAp>
</fvTenant>

XML : TENANT Cisco2

<fvTenant dn="uni/tn-Cisco2" name="Cisco2">


<fvCtx knwMcastAct="permit" name="CiscoCtx" pcEnfPref="enforced"/>
<fvBD arpFlood="yes" mac="00:22:BD:F8:19:FF" name="CiscoBD2" unicastRoute="yes"
unkMacUcastAct="flood" unkMcastAct="flood">
<fvRsCtx tnFvCtxName="CiscoCtx"/>
</fvBD>
<fvBD arpFlood="yes" name="CiscoBD" unicastRoute="yes" unkMacUcastAct="flood"
unkMcastAct="flood">
<fvRsCtx tnFvCtxName="CiscoCtx"/>
</fvBD>
<fvAp name="CCO">
<fvAEPg matchT="AtleastOne" name="EPG2">
<fvRsPathAtt encap="vlan-1202" instrImedcy="immediate" mode="native"

Operating Cisco Application Centric Infrastructure


127
Tenants
Dual Fabrics with a Common Pervasive Gateway

tDn="topology/pod-1/paths-201/pathep-[eth1/2]"/>
<fvSubnet ip="172.16.1.1/24" scope="private,shared"/>

<fvRsDomAtt instrImedcy="lazy" resImedcy="lazy" tDn="uni/phys-


PhysDomainforCisco"/>

<fvRsBd tnFvBDName="CiscoBD"/>
<fvRsConsIf matchT="AtleastOne" tnVzBrCPIfName="ICMP"/>
</fvAEPg>
</fvAp>
</fvTenant>

Dual Fabrics with a Common Pervasive Gateway


This use case might be typical for environments where an Cisco Application Centric Infrastructure (ACI)
administrator wishes to manage dual fabrics and be able to seamlessly move workload between the fabrics.
Advantages
• Virtual machines can be migrated between hypervisor hosts that are connected to different fabrics
• Allows for seamless workload migration
Disadvantages
• Coordination between the configuration of the dual fabrics is required
The objective of the "Routing over Layer 2 out/Common pervasive gateway" feature is to allow an endpoint
to seamlessly move from one fabric to another.
The following information applies to dual fabrics with a common pervasive gateway:
• Assumes dual fabrics are in use.
• "Routed" in this case means traffic between endpoints in different bridge domains (subnets).
• Bridge domains are mirrored between fabrics (with some exceptions).
• You may hear the term 'stretched bridge domain', when in fact it means a bridge domain that is mirrored
between fabrics. It is still 2 separate bridge domains, one in each of the independent fabrics.
• There are no endpoints on the Layer 2 network using the bridge domain IP address as their gateway.
• The user can manually configure each fabric with regards to the bridge domains, or use some orchestration
tool to distribute the synced configuration to each fabric.
• The ACI tool kit has an application that can help with this.

Using traffic between VM16 and VM17, we will explain why you need this feature.

Operating Cisco Application Centric Infrastructure


128
Tenants
Dual Fabrics with a Common Pervasive Gateway

If you look at the figure above, you see that VM17, when sending packets to VM16, will send to its default
gateway. The packet is then 'routed' from BD17 to BD16. BD16 then forwards the packet from the BD16
SMAC (source MAC), onto VM16 as a Layer 2 packet. When VM16 responds, the same occurs in reverse
order. The result is that the Layer 2 network, here depicted as a Nexus 5K, will continually learn the BD16/BD17
SMAC from a different port.
You must maintain the same bridge domain IP address and MAC address between the fabrics so that when
the VM migrates across the fabrics, it will not have to ARP for a new MAC for it's default gateway. As you
can see, using the same SMAC from both fabrics poses a problem.
The solution introduces some additional configuration on the bridge domain. In the new release (1.2), you
can now configure the bridge domain subnet IP address as 'virtual'. This is the address that will function as
the VMs default gateway. You also can configure a VMAC (virtual MAC). This is the MAC that the VMs
will resolve to when they issue ARP for their default gateway. These must match between fabrics for the
bridge domain.
You also now must configure a CMAC (configured MAC) for the bridge domain, and second IP address in
the same subnet as the virtual IP. These must be unique between the fabrics for the bridge domain.
You use the CMAC as the SMAC for routed packets, and you use the second IP for ARP gleaning and endpoint
tracking. You will see this explained later.

Operating Cisco Application Centric Infrastructure


129
Tenants
Dual Fabrics with a Common Pervasive Gateway

In the above diagram, you see that BD16 and BD17 are replicated on both the top and bottom fabrics. You
see the addition of the PIP and CMAC in the bridge domain configurations, and note that they are different
between fabrics, while the VIP and VMAC are the same between fabrics.
For the packet flow, VM17 sends a packet to VM16. BD17 in the bottom fabric routes the packet to BD16 in
the bottom fabric. BD16 in the bottom fabric uses the configured CMAC as the SMAC when forwarding the
frame to VM16. The N5K learns MAC 0022.1616.0002 from the bottom fabric. When VM16 in the top fabric
responds, the same occurs in the top fabric. BD17 in the top fabric will use its configured CMAC as the SMAC
for the packet as it exits the Layer 2 out. The N5K now learns that MAC 0022.1717.0001 from the top fabric.
The Nexus 5K will no longer see a MAC flap when packets routed between bridge domains pass though it.
Key to note here is that even if VM17 moves to the top fabric, and VM16 remains on the top fabric, the bridge
domains will still use their configured CMAC as the SMAC when they forward routed packets to endpoints.

Operating Cisco Application Centric Infrastructure


130
Tenants
Dual Fabrics with a Common Pervasive Gateway

Using VM17 as a LINUX host, you can use TCPDUMP to confirm that the MAC address for packets to VM16
go to the VMAC, and that return traffic is received from the CMAC.
[root@localhost ~]# ping 16.1.1.2
PING 16.1.1.2 (16.1.1.2) 56(84) bytes of data.
64 bytes from 16.1.1.2: icmp_seq=1 ttl=64 time=0.332 ms
64 bytes from 16.1.1.2: icmp_seq=2 ttl=64 time=0.376 ms
64 bytes from 16.1.1.2: icmp_seq=3 ttl=64 time=0.383 ms

--- 16.1.1.2 ping statistics ---


3 packets transmitted, 3 received, 0% packet loss, time 2001ms
rtt min/avg/max/mdev = 0.332/0.363/0.383/0.031 ms
[root@localhost ~]#

[root@localhost ~]# tcpdump -e -i eth1 -n


tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth1, link-type EN10MB (Ethernet), capture size 96 bytes
04:06:59.130801 00:50:56:bb:a1:03 > 00:22:bd:f8:19:ff, ethertype IPv4
(0x0800), length 98: 17.1.1.2 > 16.1.1.2: ICMP echo request, id 9583,
seq 8796, length 64
04:06:59.131095 00:22:17:17:00:01 > 00:50:56:bb:a1:03, ethertype IPv4
(0x0800), length 98: 16.1.1.2 > 17.1.1.2: ICMP echo reply, id 9583,
seq 8796, length 64
04:07:00.131368 00:50:56:bb:a1:03 > 00:22:bd:f8:19:ff, ethertype IPv4
(0x0800), length 98: 17.1.1.2 > 16.1.1.2: ICMP echo request, id 9583,
seq 8797, length 64
04:07:00.131669 00:22:17:17:00:01 > 00:50:56:bb:a1:03, ethertype IPv4
(0x0800), length 98: 16.1.1.2 > 17.1.1.2: ICMP echo reply, id 9583,
seq 8797, length 64
04:07:01.131915 00:50:56:bb:a1:03 > 00:22:bd:f8:19:ff, ethertype IPv4
(0x0800), length 98: 17.1.1.2 > 16.1.1.2: ICMP echo request, id 9583,

Operating Cisco Application Centric Infrastructure


131
Tenants
Dual Fabrics with a Common Pervasive Gateway

seq 8798, length 64


04:07:01.132237 00:22:17:17:00:01 > 00:50:56:bb:a1:03, ethertype IPv4
(0x0800), length 98: 16.1.1.2 > 17.1.1.2: ICMP echo reply, id 9583,
seq 8798, length 64

6 packets captured
6 packets received by filter
0 packets dropped by kernel
[root@localhost ~]#

Using the tcpdump command with the –e switch, we can see that a PING from 17.1.1.2 to 16.1.1.2 does use
the VMAC as a the SMAC for the PING request, and that the PING response is seen from the CMAC configured
on the BD that the endpoint is in.
The first set of highlighted text shows the ICMP echo request (PING), which is sent to the configured VMAC
for BD17. The second set of highlighted text shows the ICMP echo response, which is received from the
BD17 configured CMAC, and not the VMAC.
The each fabric will send a GARP sourced from the VIP and the VMAC every 30 seconds (by default). This
should not cause any problems for the Layer 2 network, as these GARPs are at a low rate. Using the Nexus
5000 debug ip arp packet command, you can see the frequency.
2015 Oct 28 12:05:31.711090arp: (context 1) Receiving packet from Vlan2330,
logical interface Vlan2330 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:05:31.711940 arp: Src 0022.bdf8.19ff/17.1.1.1 Dst
ffff.ffff.ffff/17.1.1.1
2015 Oct 28 12:05:31.713557 arp: (context 1) Receiving packet from Vlan2331,
logical interface Vlan2331 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:05:31.714382 arp: Src 0022.bdf8.19ff/16.1.1.1 Dst
ffff.ffff.ffff/16.1.1.1
2015 Oct 28 12:06:01.717761 arp: (context 1) Receiving packet from Vlan2330,
logical interface Vlan2330 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:06:01.718607 arp: Src 0022.bdf8.19ff/17.1.1.1 Dst
ffff.ffff.ffff/17.1.1.1
2015 Oct 28 12:06:01.720627 arp: (context 1) Receiving packet from Vlan2331,
logical interface Vlan2331 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:06:01.721457 arp: Src 0022.bdf8.19ff/16.1.1.1 Dst
ffff.ffff.ffff/16.1.1.1

We use the second IP configured on the bridge domain in use. In our example above, BD17 learned EP
17.1.1.230 via the L2 out.
The following example output is from the debug ip arp packet command on the Nexus 5000 in the topology.
You can see the BD17 PIP and CMAC as they perform endpoint tracking. The frames originated from the
ACI leaf using the configured BD17 PIP and CMAC to confirm that endpoint 17.1.1.1 is still alive on the
Layer 2 endpoint group.
2015 Oct 28 12:05:31.711090arp: (context 1) Receiving packet from Vlan2330,
logical interface Vlan2330 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:05:31.711940 arp: Src 0022.bdf8.19ff/17.1.1.1 Dst
ffff.ffff.ffff/17.1.1.1
2015 Oct 28 12:05:31.713557 arp: (context 1) Receiving packet from Vlan2331,
logical interface Vlan2331 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:05:31.714382 arp: Src 0022.bdf8.19ff/16.1.1.1 Dst
ffff.ffff.ffff/16.1.1.1
2015 Oct 28 12:06:01.717761 arp: (context 1) Receiving packet from Vlan2330,
logical interface Vlan2330 physical interface Ethernet1/23, (prty 1) Hrd

Operating Cisco Application Centric Infrastructure


132
Tenants
Configuring Dual Fabrics with a Common Pervasive Gateway Using the GUI

type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:06:01.718607 arp: Src 0022.bdf8.19ff/17.1.1.1 Dst
ffff.ffff.ffff/17.1.1.1
2015 Oct 28 12:06:01.720627 arp: (context 1) Receiving packet from Vlan2331,
logical interface Vlan2331 physical interface Ethernet1/23, (prty 1) Hrd
type 1 Prot type 800 Hrd len 6 Prot len 4 OP 1, Pkt size 46
2015 Oct 28 12:06:01.721457 arp: Src 0022.bdf8.19ff/16.1.1.1 Dst
ffff.ffff.ffff/16.1.1.1

Configuring Dual Fabrics with a Common Pervasive Gateway Using the GUI
The following procedure describes how to configure dual fabrics with a common pervasive gateway using
the GUI for this use case.

Procedure

Step 1 On the menu bar, choose Tenant > All TENANTS.


Step 2 In the Work pane, double click the Tenant_Name.
Step 3 In the Navigation Pane, choose Tenant_Name > Networking > Bridge Domains > BD_name.
Step 4 In the Work pane, set the following values for the properties:
a) For the L2 Unknown Unicast buttons, click Flood.
b) For the L3 Unknown Multicast Flooding buttons, click Flood.
c) For the Multi Destination Flooding buttons, click Flood in BD.
Step 5 Choose the L3 Configurations tab.
Step 6 In the Work pane, set the following values for the properties:
a) For the Custom MAC Address field, enter the custom MAC address for the bridge domain.
The custom MAC address must differ between fabrics.
b) For the Virtual MAC Address field, enter the virtual MAC address for the bridge domain.
The virtual MAC address must match between fabrics.

Step 7 Click Submit.


Step 8 In the Navigation Pane, choose Tenant_Name > Networking > Bridge Domains > BD_name > Subnets >
Subnet_IP.
Step 9 In the Work pane, put a check in the Treat as virtual IP address box.
This configures the bridge domain gateway IP address is as a VIP (virtual IP address).
Also under the Subnets folder is an 16.1.1.103 address that is used for ARP gleaning and endpoint tracking.
This address must be unique for the bridge domain across the fabrics.

Step 10 Repeat steps 3 to 9 for each bridge domain that is mirrored between the fabrics.

Operating Cisco Application Centric Infrastructure


133
Tenants
Configuring Dual Fabrics with a Common Pervasive Gateway Using the GUI

Operating Cisco Application Centric Infrastructure


134
CHAPTER 6
Working with Contracts
• Contracts, on page 135
• Filters, on page 143
• Taboo Contracts, on page 147
• Inter-Tenant Contracts, on page 150

Contracts
Contracts provide a way for the Cisco Application Centric Infrastructure (ACI) administrator to control traffic
flow within the ACI fabric between endpoint groups. These contracts are built using a provider-consumer
model where one endpoint group provides the services it wants to offer and another endpoint group consumes
them. Contracts are assigned a scope of Global, Tenant, VRF, or Application Profile, which limit the
accessibility of the contract.
In brief, contracts consist of 1 or more subjects. Each subject contains 1 or more filters. Each filter contains
1 or more entries. Each Entry is equivalent to a line in an Access Control List (ACL) that is applied on the
leaf switch to which the endpoint within the endpoint group is attached.
In detail, contracts are comprised of the following items:
• Subjects—A group of filters for a specific application or service.
• Filters—Used to classify traffic based upon layer 2 to layer 4 attributes (such as Ethernet type, protocol
type, TCP flags and ports).
• Actions—Action to be taken on the filtered traffic. The following actions are supported:
• Permit the traffic (regular contracts, only)
• Mark the traffic (DSCP/CoS) (regular contracts, only)
• Redirect the traffic (regular contracts, only, through a service graph)
• Copy the traffic (regular contracts, only, through a service graph or SPAN)
• Block the traffic (taboo contracts, only)
• Log the traffic (taboo contracts, only)

• Labels—(Optional) Used to group objects such as subjects and endpoint groups for the purpose of
increasing granularity in policy enforcement.

Operating Cisco Application Centric Infrastructure


135
Working with Contracts
Contracts

While different endpoint groups can only communicate with other endpoint groups based upon the contract
rules defined, there is no contract required for intra-endpoint group communication. Intra-endpoint group
communication from endpoint to endpoint in the same endpoint group is allowed by default.
If a filter allows traffic from any consumer port to a provider port (e.g. 8888), if reverse port filtering is enabled
and the contract is applied both directions (say for TCP traffic), either the consumer or the provider can initiate
communication. The provider could open up a TCP socket to the consumer using port 8888, whether the
provider or consumer sent traffic first.
If you do not configure a contract, traffic is permitted only for the following types of packets as well as the
types that are permitted by default for multicast traffic and class equal traffic:
• DHCP v4 (prot 0x11, sport 0x44, dport 0x43)
• DHCP v4 (prot 0x11, sport 0x43, dport 0x44)
• DHCP v6 (prot 0x11, sport 0x222, dport 0x223)
• OSPF (prot 0x59)
• EIGRP (prot 0x58)
• PIM (prot 0x67)
• IGMP (prot 0x2)
• ND-Sol ICMPv6 (prot 0x3a dport 0x0087)
• ND-Advt ICMPv6 (prot 0x3a dport 0x0088)

The following example shows how different contracts would control traffic flow between endpoint groups in
a 3-tiered application containing a group of web servers in one endpoint group, a group of application servers
in a second endpoint group, and a group of database servers in a third endpoint group. The Web endpoint
group (provider) provides a contract (contract1) which is consumed by the L3Out endpoint group (traffic
external to the ACI fabric). This allows for web traffic to reach the web servers from outside the ACI fabric.
The Application endpoint group (provider) provides a contract (contract2) for communications which the
Web endpoint group (consumer) consumes. This allows the web server to call applications on the application
servers. Finally, the Application endpoint group (consumer) consumes a contract (contract3), which the
Database endpoint group (provider) provides. This allows the application servers to access the database for
the applications. For un-acked UDP traffic, reverse port filtering is not necessary. But, for TCP traffic, the
responder cannot set up a TCP session without reverse port filtering enabled or a different contract that allows
any established traffic from the responder.

Operating Cisco Application Centric Infrastructure


136
Working with Contracts
Contract Configuration Parameters

Figure 43: Contract Policies Between End Point Groups

The following types of Contracts that can be applied in ACI:


• Regular contracts
• Taboo contracts
• Out-Of-Band (OOB) contracts

Contracts govern the following types of endpoint group communications:


• Between application endpoint groups
• Between application endpoint groups and external networks
• Between application endpoint groups and in-band management endpoint group, for example if in-band
management is configured for the ACI fabric and certain endpoint groups are to be allowed to access it

Out-of-band contracts apply only to out-of-band traffic from the management tenant. Taboo contracts are
used to deny and log traffic related to regular contracts and are configured into the hardware before the regular
contract. For example, if the objective was to allow traffic with source ports 50 through 500 with the exception
of port 305, then the regular contract would allow all ports in the range of 50 through 500 while the taboo
contract would have a single entry denying port 305. The taboo contract denying port 305 would be programmed
into the hardware before the regular contract allowing ports 50 through 500.

Contract Configuration Parameters


When configuring contracts you can define the following options:
• Application-profile—This contract can be applied to any endpoint groups in the same application profile.

Operating Cisco Application Centric Infrastructure


137
Working with Contracts
Create/Modify/Remove Regular Contracts

• Contract Scope—The scope of a service contract between two or more participating peer entities or
endpoint groups. The contract will not be applied to any consumer endpoint group outside the scope of
the provider endpoint group.
The states are:
• Private Network—This contract can be applied to any endpoint groups within the same VRF.
• Tenant —This contract can be applied to any endpoint groups within the same tenant.
• Global —This contract can be applied to any endpoint groups throughout the fabric.
The default state is Private Network.
• QoS Class—The priority level of the service contract.
The priority level can be:
• Unspecified
• Level1—Class 1 Differentiated Services Code Point (DSCP) value.
• Level2—Class 2 DSCP value.
• Level3—Class 3 DSCP value.
The default is Unspecified.
• Tags (labels)—(Optional) The search keyword or term that is assigned to the application profile. A tag
allows you to group multiple objects by a descriptive name. You can assign the same tag name to multiple
objects and you can assign one or more tag names to an object. When contracts are assigned to an endpoint
group as either a consumer or provider, by default all subjects within a contract apply to the endpoint
group. With tags, only endpoint groups in application profiles with matching criteria will implement the
subject of the contract.
• Match—-The subject match criteria across consumer endpoint groups. Labels can be applied to a variety
of provider and consumer managed objects, including endpoint groups, contracts, bridge domains, DHCP
relay policies, and DNS policies. When checking for a match of provider labels and consumer labels,
the match setting is determined by the provider endpoint group. The different options are:
• AtleastOne—At least 1 label matches on Provider and Consumer endpoint groups. Blank labels
are considered a match.
• AtmostOne—Matches only when all labels on the endpoint groups are exactly the same. Blank
labels are considered a match.
• None—None of the subject labels match.
• All—Only matches when both endpoint groups have all labels, excluding blank labels.
The default is AtleastOne.

Create/Modify/Remove Regular Contracts


Create Contracts
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name.
3. In the Navigation pane choose Tenant_Name > Security Policies > Contracts.
4. In the Work pane, choose Actions > Create Contract.

Operating Cisco Application Centric Infrastructure


138
Working with Contracts
Modify Contracts

5. In the Create Contract dialog box, perform the following actions:


1. Enter a contract name.
2. Choose a contract scope (optional).
3. Choose a QoS class (optional).
4. Click + next to the Subject to add a contract subject.
1. In the Create Contract Subject dialog box, perform the following actions:
1. Enter a contract subject name.
2. Click + in the Filter Chain field.
For information regarding filter creation, see the "Filters" section.

6. Click Update
7. Click OK.
8. Click Submit.

Modify Contracts
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name.
3. In the Navigation pane choose Tenant_Name > Security Policies > Contracts > Contract_Name.
4. In the Work pane, choose the Policy tab.
1. Choose a Contract Scope (optional).
2. Choose a Qos Class (optional).
3. Click + next to the Subject field. to add a Contract Subject.
1. In the Create Contract Subject dialog box, perform the following actions:
1. Enter a Contract Subject Name.
2. Click + next to Filter Chain.

Note For information regarding filter creation, see the "Filters" section.

5. Click Update.
6. Click OK.
7. Click Submit.

Operating Cisco Application Centric Infrastructure


139
Working with Contracts
Remove Contracts

Remove Contracts
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Contracts > Contract_Name.
4. In the Work pane, choose Actions > Delete.

Verify Contracts
REST :: /api/node/class/vzBrCP.xml

CLI :: moquery -c vzBrCP

Apply/Remove EPG Contracts


Apply a Contract to an EPG
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name.
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile_Name >
Application EPGs > EPG_Name > Contracts .
4. In the Work pane, choose Actions > Add Provided Contract or Actions > Add Consumed Contract.
Note: Choose the action depending on how the contract is to be deployed.
5. In the Add Contract dialog box, perform the following actions:
1. Enter a Contract_Name.
2. Choose a QOS policy (optional).
3. Choose a Label (optional).

6. Click Submit.

Remove a Contract from an EPG


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile_Name >
Application EPGs > EPG_Name > Contracts > Contract_Name .
4. In the Work pane, choose Actions > Delete.

Operating Cisco Application Centric Infrastructure


140
Working with Contracts
Verify Contract on an EPG

Verify Contract on an EPG


Provider

REST :: /api/node/class/fvRsProv.xml

CLI :: moquery -c fvRsProv

Consumer

REST :: /api/node/class/fvRsCons.xml

CLI :: moquery -c fvRsCons

Apply/Remove External Network Contracts


Apply a Contract to an External Network
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > External Routed Networks > Routed
Outside_Name > Networks > External_Network_Instance_Profile .
4. In the Work pane, click + next to either Add Provided Contract or Add Consumed Contract.
Note: Make a selection depending on how the contract is to be deployed.
1. Choose a Contract_Name .
2. Choose a QOS Type.
3. Choose a Match Criteria.

5. Click Update.

Remove a Contract from an External Network


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > External Routed Networks > Routed
Outside_Name > Networks > External_Network_Instance_Profile .
4. In the Work pane, choose the Contract_Name and click x.

Verify External Network Contracts


Provider

REST :: /api/node/class/fvRsProv.xml

Operating Cisco Application Centric Infrastructure


141
Working with Contracts
Applying or Removing VRF Contracts

CLI :: moquery -c fvRsProv

Consumer

REST :: /api/node/class/fvRsCons.xml

CLI :: moquery -c fvRsCons

Applying or Removing VRF Contracts


To apply contracts to all endpoint groups within a VRF instance, contracts can be applied directly to the VRF
instance. This concept is also referred as "vzAny" endpoint group. It eases contract management by allowing
the contract configuration for all endpoint groups within a VRF instance from a single location as well as
optimizing hardware resource consumption.
For example, if an Cisco Application Centric Infrastructure (ACI) administration has 100 endpoint groups
that are all part of the same VRF instance, they can apply the contracts to this one vzAny group under the
VRF instance, rather than to each endpoint group.
VRF instance-wide contracts are traditionally contracts that allow established traffic allowing endpoint group
contracts to only define traffic in one direction, from consumer to provider, without the need to have reverse
port forwarding enabled for TCP traffic. Since all endpoint groups within the VRF instance allow established
traffic, reverse port forwarding is unnecessary in the contract applied to the endpoint group directly.
A quick trick to see if contracts, or the lack thereof, are blocking traffic within the VRF instance in an ACI
fabric is to unenforce the VRF instance. This allows communication between all endpoint groups within the
VRF instance without the need for contracts. This is equivalent to applying the common tenant contract vzAny
to the VRF instance endpoint group.

Note If there is a very large number of contracts within the VRF, it can take up to an hour or more to re-implement
the contracts in the leaf switches when the VRF is moved back to enforced.

In the case of shared services, you must define the provider EPG shared subnet under the EPG in order to
properly derive the pcTag (classification) of the destination from the consumer (vzAny) side. If you are
migrating from a bridge domain-to-bridge domain shared services configuration, where both the consumer
and provider subnets are defined under bridge domains, to vzAny acting as a shared service consumer, you
must take an extra configuration step where you add the provider subnet to the EPG with the shared flags at
minimum.

Note If you add the EPG subnet as a duplicate of the defined bridge domain subnet, ensure that both definitions of
the subnet always have the same flags defined. Failure to do so can result in unexpected fabric forwarding
behavior.

Applying a Contract to a VRF (vzAny) Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.

Operating Cisco Application Centric Infrastructure


142
Working with Contracts
Removing a Contract from a VRF (vzAny) Using the GUI

2. In the Work pane, choose the Tenant_Name .


3. In the Navigation pane choose Tenant_Name > Networking > Private Networks >
Private_Network_Name > EPG Collection for Context.
4. In the Work pane, click + next to either Add Provided Contract or Add Consumed Contract.
Make a selection depending on how the contract is to be deployed.
1. Enter a Contract_Name .
2. Choose a QOS Type.
3. Choose a Match Criteria.

5. Click Update.

Removing a Contract from a VRF (vzAny) Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Networking > Private Networks >
Private_Network_Name > EPG Collection for Context.
4. In the Work pane, choose the Contract_Name and click x.

Verifying VRF Contracts


The following API verifies a VRF's contracts:
/api/node/class/vzBrCP.xml

The following iShell command verifies a VRF's contracts:


admin@apic1:~> moquery -c vzBrCP

Filters
A filter is a group of filter entries that are aimed to filter traffic. Each filter entry is a rule that allows or denies
traffic that is classified based on TCP/IP header fields, such as Layer 3 protocol type or Layer 4 ports. The
filter is defined on the contract that is associated with an endpoint group. This can be either incoming toward
an endpoint group, outgoing away from an endpoint group, or both. A subject is an entity that connects the
filter to the contract, thereby affecting the traffic between endpoint groups that are provided and consumed
by this contract.

Filter Entry Configuration Parameters


When configuring a filter, the following options can be defined:
• Name—The name of a filter entry.
• EtherType—The EtherType of the filter entry. The EtherTypes are:

Operating Cisco Application Centric Infrastructure


143
Working with Contracts
Creating Filters Using the GUI

• ARP
• FCOE
• IP
• MAC Security
• MPLS Unicast
• Trill
• Unspecified

• ARP Flag—The Address Resolution Protocol flag for a filter entry. The filter entry is a combination of
network traffic classification properties.
• IP Protocol—The IP protocol for a filter entry. The filter entry is a combination of network traffic
classification properties.
• Match Only Fragments—Match only packet fragments. When enabled, the rule applies to any IP
fragment with an offset that is greater than 0 (all IP fragments except the first). When disabled, the rule
will not apply to IP fragments with an offset greater than 0 because TCP/UDP port information can only
be checked in initial fragments.
• Port Ranges (Source, Destination)—The port fields for the source and destination. You can define a
single port by specifying the same value in the From and To fields, or you can define a range of ports
from 0 to 65535 by specifying different values in the From and To fields. Instead of specifying a number,
you can instead choose one of the following server types to use the pre-defined port of that type:
• HTTPS
• SMTP
• HTTP
• FTP-Data
• Unspecified
• DNS
• POP3
• RTSP

The default is Unspecified.


• TCP Session Rules—The TCP session rules for a filter entry. The filter entry is a combination of network
traffic classification properties.

Creating Filters Using the GUI


The following procedure creates a filter using the GUI:

Operating Cisco Application Centric Infrastructure


144
Working with Contracts
Modifying Filters Using the GUI

Procedure

Step 1 On the menu bar, choose Tenants > All Tenants.


Step 2 In the Work pane, double click the tenant's name.
Step 3 In the Navigation pane, choose Tenant tenant_name > Security Policies > Filters.
Step 4 In the Work pane, choose Actions > Create Filter.
Step 5 In the Create Filter dialog box, fill in the fields as required, except as specified below:
a) In the Name field, enter a name for the filter.
b) On the Entries table, click +.
Step 6 In the Entries table, fill in the fields as specified below:
a) In the Name field, enter a name for the filter entry.
b) In the Ethertype drop-down list, choose an ethertype.
c) (Optional) In the ARP Flag drop-down list, choose an ARP flag.
d) (Optional) In the IP Protocol drop-down list, choose an IP protocol.
e) (Optional) If required, put a check in the Match Only Fragments check box.
f) (Optional) In the Source Port From drop-down list, choose a source port.
g) (Optional) In the Source Port To drop-down list, choose a source port.
h) (Optional) In the Destination Port From drop-down list, choose a destination port.
i) (Optional) In the Destination Port To drop-down list, choose a destination port.
j) (Optional) In the TCP Session Rules drop-down list, choose a TCP session rule.
k) Click Update.
Step 7 Click Submit.

Modifying Filters Using the GUI


The following procedure modifies a filter using the GUI:

Procedure

Step 1 On the menu bar, choose Tenants > All Tenants.


Step 2 In the Work pane, double click the tenant's name.
Step 3 In the Navigation pane, choose Tenant tenant_name > Security Policies > Filters > filter_name.
Step 4 In the Navigation pane, in the Entries table, double click on the filter entry that you want to modify.
Step 5 Modify the values.
Step 6 Click Update.

Removing Filters Using the GUI


1. On the menu bar, choose Tenants > ALL TENANTS.

Operating Cisco Application Centric Infrastructure


145
Working with Contracts
Configuring Filters Using the NX-OS-Style CLI

2. In the Work pane, choose the Tenant_Name .


3. In the Navigation pane choose Tenant_Name > Security Policies > Filters > Filter_Name .
4. In the Work pane, choose Actions > Delete.

Configuring Filters Using the NX-OS-Style CLI


The filters can be created and accessed in the NX-OS-style CLI through the tenant shell.

Procedure

Step 1 SSH to an APIC in the fabric.


# ssh admin@node_name

Step 2 Enter the configure mode:


apic1# configure

Step 3 Go to the desired tenant:


apic1(config)# tenant tenant1

Step 4 Create a filter called "FilterHTTPS" with the entries of "match tcp dest 80" and "match ip":
apic1(config-tenant)# access-list FilterHTTPS
apic1(config-tenant-acl)# match tcp dest 80
apic1(config-tenant-acl)# match ip
apic1(config-tenant-acl)# exit

Step 5 Access the contract to which you want to apply the "FilterHTTPS" filter:
apic1(config-tenant)# contract WebHTTPS

Step 6 Create a subject "SubjectHTTPS", which will connect the filter to the contract. This way we can impose the
same filter on several contracts without having to create multiple filters with identical entries.
apic1(config-tenant-contract)# subject SubjectHTTPS

Step 7 Tie the filter to the contract. You can use the filter to match traffic that is incoming to the endpoint group that
is tied to the contract "WebHTTPs", to match traffic that is outgoing from the endpoint group that is tied to
the contract, or for both.
apic1(config-tenant-contract-subj)# access-group FilterHTTPS
both match traffic in both direction
in match traffic from provider to consumer
out match traffic from consumer to provider
apic1(config-tenant-contract-subj)# access-group FilterHTTPS both

Operating Cisco Application Centric Infrastructure


146
Working with Contracts
Removing and Deleting Filters Using the NX-OS-Style CLI

Removing and Deleting Filters Using the NX-OS-Style CLI


Procedure

Step 1 The following command removes the filter association:


apic1(config-tenant-contract-subj)# no access-group FilterHTTPS both

Step 2 The following command deletes the entire filter:


apic1(config-tenant)# no access-list FilterHTTPS

Verifying Filters
You can use any of the following methods to verify the filters:
• In the GUI, navigate to the following location:
Tenant_Name > Security Policies > Filters > Filter_Name
• Use the following API:
/api/node/class/vzFilter.xml
• Enter the following NX-OS-style CLI command:
apic1# show run

• Enter the following object model CLI command:


admin@apic1:~> moquery -c vzFilter

Taboo Contracts
There may be times when the ACI administrator might need to deny traffic that is allowed by another contract.
Taboos are a special type of contract that an ACI administrator can use to deny specific traffic that would
otherwise be allowed by another contract. Taboos can be used to drop traffic matching a pattern (any EPG, a
specific EPG, matching a filter, and so forth). Taboo rules are applied in the hardware before the rules of
regular contracts are applied.
To imitate the traditional networking concepts, an "allow-all-traffic" contract can be applied, with taboo
contracts configured to restrict certain types of traffic.

Taboo Contract Configuration Parameters


When configuring Taboo Contracts you can define the following options:
• Name - The name of the contract or contract object.
• Subjects - The network domain name label. Labels enable classification of the objects which can and
cannot communicate with one another (optional).

Operating Cisco Application Centric Infrastructure


147
Working with Contracts
Create/Modify/Delete Taboo Contracts

• Directive - The filter directives assigned to the taboo contract.

Create/Modify/Delete Taboo Contracts


Create Taboo Contracts
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Taboo Contracts .
4. In the Work pane, choose Action > Create Taboo Contract.
5. In the Create Taboo Contract dialog box, perform the following actions:
1. Enter a Taboo Contract Name.
2. Click + to next to the Subject field to add a Taboo Subject.
1. Enter a Filter Name.
2. Choose Directives.

6. Click Update.
7. Click OK.
8. Click Submit.

Modify Taboo Contracts


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Taboo Contracts >
Taboo_Contract_Name .
4. In the Work pane, choose policy.
1. Click + to next to the Subject field.
2. In the Create Taboo Contract Subject dialog box, perform the following actions:
1. Enter a Taboo Contract Subject Name.
2. Click + in the Filter Chain field.
1. Enter a Filter Name.
2. Choose Directives.

5. Click Submit.

Operating Cisco Application Centric Infrastructure


148
Working with Contracts
Delete Taboo Contracts

Delete Taboo Contracts


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Taboo Contracts >
Taboo_Contract_Name .
4. In the Work pane, choose Action > Delete.

Verify Taboo Contracts


REST :: /api/node/class/vzTaboo.xml

CLI :: moquery -c vzTaboo

Apply/Remove Taboo Contracts


Apply a Taboo Contract to an EPG
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile_Name >
Application EPGs > EPG_Name > Contracts.
4. In the Work pane, choose Actions > Add Taboo Contract.
5. In the Add Taboo Contract dialog box,
1. Choose the Taboo Contract.

6. Click Submit.

Remove a Taboo Contract from an EPG


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Application Profiles > Application_Profile_Name >
Application EPGs > EPG_Name > Contracts.
4. In the Work pane, choose the Taboo Contract_Name > Actions > Delete.

Verify Taboo Contracts Applied to an EPG


Provider

REST :: /api/node/class/fvRsProv.xml

Operating Cisco Application Centric Infrastructure


149
Working with Contracts
Inter-Tenant Contracts

CLI :: moquery -c fvRsProv

Consumer

REST :: /api/node/class/fvRsCons.xml

CLI :: moquery -c fvRsCons

Inter-Tenant Contracts
There may be times when the ACI administrator might need to allow traffic between two tenants. Interface
contracts are a special type of contract that an ACI administrator can use to allow specific traffic through the
use of a contract export. The contract in essence is exported in the source tenant and imported into the target
tenant. Similar to traditional contracts, the source EPG will be of type provider. However, in the target tenant,
the contract is imported as type contract interface. Some use case examples show the complete process in the
next chapter.

Configuration Parameters
When importing a contract, the following options can be defined:
• Name - The name of the contract interface.
• Global Contract - Name of a service contract to be shared between two or more participating peer
entities.
• Tenant - The Tenant name of the targeted Export contract.

Create/Modify/Remove Export Contracts


Export Contract
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Contracts.
4. In the Work pane, choose Actions > Export Contract.
5. In the Export Contract dialog box, perform the following actions:
1. Enter an Export Contract Name.
2. Choose the Global Contract.
3. Enter the Tenant Name.

6. Click Finish.

Operating Cisco Application Centric Infrastructure


150
Working with Contracts
Modify Exported Contracts

Modify Exported Contracts


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Contracts > Contract_Name.
4. In the Work pane, choose policy.
1. Enter an Export Contract Name.
2. Choose the Global Contract.
3. Enter the Tenant Name.

5. Click Finish.

Remove Exported Contracts


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Security Policies > Contracts > Imported Contracts
> Contact_Name.
4. In the Work pane, choose Actions > Delete.

Verify Exported Contracts


REST :: /api/node/class/vzCPif.xml

CLI :: moquery -c vzCPif

Ingress-Based ACLs
The main purpose of the ingress-based ACL feature is to save resources on the border leaf. In this policy
enforcement model, the policy will be only applied on non-border leafs, thereby reducing zone-rule consumption
on border leafs. This enforcement direction policy is applied at the VRF level and allows for backward
compatibility with the previous policy enforcement model. The policy enforcement direction for this new
model is as follows:
1. Host to WAN—The policy is applied on the non-border leaf
2. WAN to Host—The policy is applied on non-border leaf regardless of whether or not the endpoint group
is learned on the border leaf
3. WAN to WAN—The policy is applied on ingress border leaf
This feature is not compatible with the transit routing, vzAny, and taboo contract use cases. Transit routing
rules are already applied at ingress.

Operating Cisco Application Centric Infrastructure


151
Working with Contracts
Configuring Ingress-Based ACLs Using the GUI

Configuring Ingress-Based ACLs Using the GUI


Policy control enforcement direction is applied on the VRF.

Procedure

Step 1 On the menu bar, choose Tenant > All TENANTS.


Step 2 In the Work pane, double click the tenant's name.
Step 3 In the Navigation Pane, choose Networking > VRFs > VRF Name.
Step 4 In the Work pane, set Policy Control Enforcement Direction to Ingress.
Step 5 Click Submit.
Step 6 Verify the policy usage, then click Submit Changes.

Verifying Ingress-Based ACLs


The following iShell command verifies the ingress-based ACLs:
admin@apic1:~> moquery -c fv.Ctx -f ‘fv.Ctx.name==”vrf-name”’

The following hardware CLI commands verify the ingress-based ACLs:


# vsh_lc
module-1# show system internal eltmc info vrf name

Contracts Use Cases


These use cases all assume the objective is for a host in EPG-1 to talk to a host in EPG-2, achieving bidirectional
traffic. How these scenarios are implemented will depend on the operational model chosen, and whether the
system is more focused on object re-use or tenant autonomy. Review the Contracts section on Contract Scoping
for a more detailed discussion.
These are some common scenarios:
1. Inter-Tenant Contracts
2. Inter-Private Network Contracts
3. Single Contract Bidirectional forwarding with reverse filter
4. Single Contract Unidirectional with multiple Filters
5. Multiple Contracts Unidirectional with single Filter

Inter-Tenant Contracts
ACME Inc., as with most companies, makes use of shared services such as DNS for name resolution and
Active Directory for user management. These services will be used across most of their tenants and so ACME
Inc. must allow this traffic across the whole fabric. Communication between EPGs that belong to different
tenants is only allowed when they share the same contract. To use the same contract, it will need to be exported
from the source tenant to the appropriate destination tenant. That contract will appear under the Imported
Contract section in the Security Policies of the destination tenant.
A Consumed Contract Interface will be used to associate an EPG from the destination tenant with the imported
contract.

Operating Cisco Application Centric Infrastructure


152
Working with Contracts
Inter-Private Network Contracts Communication

Note: A contract consumption interface represents one or more subjects defined under the contract. By
associating to an interface, an endpoint group starts consuming all the subjects represented by the interface.
In the use case below, EPG-1 in tenant Cisco-1 requires communication with EPG-2 in tenant Cisco-2. This
is accomplished by utilizing contact interfaces. In tenant Cisco-1 the user will export the intended contract
interfaces. In tenant Cisco-1 the user will export the intended contract and select provider to provide the
contrast to EPG-2. The user will then confirm the imported contract in tenant Cisco-2 and select the contract
as consumed. To advertise the routes from the source VRF to the intended VRF, the user must create the
subnet within the EPG.
Figure 44: Exporting Contracts Between Tenants

Tenant Cisco-1/EPG-1
1. Create an Export Contract under security policies.
2. Create the host subnet (default Gateway IP) under EPG1 - subnet scope shared.
3. Add the Contract under EPG1 - contract type provider.
4. Create the host subnet under the bridge domain - subnet scope private/public.

Tenant Cisco-2/EPG-2
1. Confirm the exported contract is listed under Imported Contracts.
2. Create the host subnet (default Gateway IP) under EPG2 - subnet scope shared.
3. Add the Interface Contract under EPG2 - contract type consumed.
4. Create the host subnet (default Gateway IP) under the bridge domain - subnet scope private/public.

Inter-Private Network Contracts Communication


In the use case below, EPG-1 in VRF Cisco-1 requires communication with EPG-2 in VRF Cisco-2. This is
accomplished by utilizing the subnet field within the EPG. By creating the subnet under the EPG and selecting
shared, the route will be leaked to the VRF noted within the Tenant scoped contract.

Operating Cisco Application Centric Infrastructure


153
Working with Contracts
Single Contract Bidirectional Reverse Filter

Figure 45: Exporting Contracts Between Private Networks

1. Create the contract under Security Policies - contract scope Tenant.


2. (Tenant Cisco-1/EPG-1) Create the host subnet (default Gateway IP) under EPG1 - subnet scope shared.
3. Add the Contract under EPG1 - contract type provider.
4. (Tenant Cisco-1/EPG-2) Create the host subnet (default Gateway IP) under EPG2 - subnet scope shared.
5. Add the Contract under EPG2 - contract type provider.

Single Contract Bidirectional Reverse Filter


This use case is useful when implementing a contract with the option to apply the contract subject in both
directions and with the option to apply the reverse filter. This is the most common of the use cases and allows
for a single subject/filter to be implemented with a single provider/consumer relationship.
In the use case below, EPG-1 is providing a contract with a subject of www and EPG-2 is consuming the
contract. This allows the Web client in EPG-2 to access the Web server in EPG-1. That is, EPG-1 is providing
a service to EPG-2. The Web server in EPG-1 will not have access to port 80 of the Web client in EPG-2.
Figure 46: Default Bi-directional Contract with Reverse Filter

Result:
A single contract with (1) subject and (1) filter with a single provider and a single consumer. In this example,
www.

Operating Cisco Application Centric Infrastructure


154
Working with Contracts
Single Contract Unidirectional with Multiple Filters

Single Contract Unidirectional with Multiple Filters


This use case involves implementing a contract without the option to apply the contract subject in both
directions. When selecting this option the user no longer has the option to select the reverse filter option.
In the use case below, EPG-1 is providing a contract with a subject of icmp and EPG-2 is consuming the
contract. This allows the Host in EPG-1 to access the Host in EPG-2 via icmp. When utilizing a single subject
without the use of "Apply Both Directions," the user must then configure two filters, one in each direction.
Figure 47: Single Contract, Single Unidirectional Subject, Multiple Filters

Result:
A single contract with (1) Subject (2) Filters and a single provider and a single consumer. In this example,
icmp.

Multiple Contracts Uni-Directional Single Filter


This use case is useful when implementing a contract with the option to apply the contract subject in both
directions, and without the option to apply the reverse filter. This allows the end-user the most granularity
when deploying contracts, but is also the most comprehensive.
In the use case below, EPG-1 is providing a contract with a subject of www and EPG-2 is consuming the
contract. This allows the Web Client in EPG-2 to access the Web Server in EPG-1. That is, EPG-1 is providing
a service to EPG-2.

Operating Cisco Application Centric Infrastructure


155
Working with Contracts
Multiple Contracts Uni-Directional Single Filter

Figure 48: Multiple Contracts, Unidirectional Subjects, Single Filters

Result:
Two contracts with (1) Subject (1) Filters. Each contract will have a single provider and a single consumer
referencing the same contract. The difference here is that the contract is explicitly applied in BOTH directions.

Operating Cisco Application Centric Infrastructure


156
CHAPTER 7
Layer 4 to Layer 7 Service Insertion
• Understanding Layer 4 to Layer 7 Integration, on page 157
• Services Deployment Guide Reference, on page 159
• Service Graph Monitoring, on page 161
• ASAv Sample Configuration, on page 163

Understanding Layer 4 to Layer 7 Integration


When ACME Inc. designed their new application, they knew they would need to incorporate some services,
such as firewalls, load balancers, IDS/IPS, or other types of higher-layer service devices.
In traditional infrastructure, service insertion would require inline device placement or redirection in order to
get traffic to the service devices. As an example, you might place firewalls directly inline as a "bump in the
wire" or as an adjunct service device near a gateway router or switch. Firewalls are typically configured on
a device-by-device basis by building up blocks of static configuration. These static configuration blocks build
up over time to create a situation where the configuration works, but becomes inflexible and fragile, which
causes change management to become challenging.
One of the key technology innovations in Cisco's Application Centric Infrastructure (ACI) is policy-based
management of service insertion through application of a Service Graph. Through the rest of this chapter, we
will discuss the high level overview of how the process works and how ACME will utilize Service Graphs
for efficient management of Layer 4 to Layer 7 services.
The main purpose of data center fabric equipment is fast and efficient forwarding of traffic from ingress to
the fabric, between physical and virtual hosts within the fabric and egress back out of the fabric. Useful
infrastructure implementations also utilize this fast fabric in a smart way to also integrate Layer 4 to Layer 7
services. Some possible Layer 4 to Layer 7 services include:
• Firewalls
• Load balancers
• Traffic inspection appliances
• SSL offload functions
• Application flow acceleration functions
Integrating services with Cisco ACI Service Graphs will provide ACME with the following benefits:
• Policy based configuration management
• Flexible configuration state abstraction through the ACI object model

Operating Cisco Application Centric Infrastructure


157
Layer 4 to Layer 7 Service Insertion
Service Insertion Design Principles

• Integrated configuration management using the APIC GUI, REST API or Python scripts, all based on a
consistent ACI object model
• Complex topology modeling with logical flow stitching allowing abstracted links between multiple
service devices
• Policy-based provisioning allowing rapid complex topology deployment
• Configuration synchronization allowing dynamic workload provisioning and de-provisioning without
manual intervention
• Application centric template-based configuration management and object reuse to shorten infrastructure
implementation timelines
• Infrastructure multi-tenancy within the fabric and the service devices

Service Insertion Design Principles


With the spine-leaf architecture and holistic fabric management aspects of ACI, traffic flow to/from service
devices is managed very efficiently, and thus the devices do not need to be placed at any specific location
within the network fabric. Services appliances can be physical or virtual and can be connected to any leaf
under management of the ACI fabric. Where applicable, physical appliances can also be run in multiple context
mode, allowing multi-tenant mapping of fabric forwarding and tenant-specific service configurations.

Applying service graphs to EPG Communications


To allow communication between endpoint groups within an ACI fabric, a contract must be put into place.
This contract takes the form of a specific consumer/provider relationship defined by specified protocols and
ports. There could also be an "allow all" contract that allows completely open communications. This contract
essentially controls communications flow between endpoint groups, and can be extended to include service
insertion via attachment of a service graph to a contract. The service graph then ties the contract to the resolved
service device with the policy-based configuration in place.

Rendering Service Graphs


Cisco Application Centric Infrastructure (ACI) allows users to define a policy using the following methods:
• Application Policy Infrastructure Controller (APIC) GUI
• Python SDK (Cobra)
• RESTful API
These policy objects can be created, manipulated, and reused. As it relates to the Layer 4 to Layer 7 services,
these objects express the intent of use for that object in relation to the application.
When an application profile is deployed and endpoints are attached to the leaf switches, the service graph
objects are translated into specific device configurations that are pushed to the service devices through a
process called rendering. The APIC also sets up the network forwarding path to make sure the correct forwarding
action is taken to get traffic flow to the service devices for treatment.
This abstracted process of configuration management works like a policy template where you can define the
expected behavior, then link two endpoint groups and subject their relationship to that policy. This policy can
be copied, reused and repackaged as necessary. The rendering involves the allocation and configuration of
all required settings on both the ACI fabric and the Layer 4 to Layer 7 devices.

Operating Cisco Application Centric Infrastructure


158
Layer 4 to Layer 7 Service Insertion
Integration Support Function

As is the case with many customers, ACME has a few cookie cutter templates for firewall and load-balancing
services. Though the initial definition of these templates can be potentially cumbersome, subsequently reusing
the templates is very straightforward simply by replacing IP addresses, ports, object-groups, and other values.

Integration Support Function


In the Cisco Application Centric Infrastructure (ACI) model, communications with the service devices is
supported by importing device packages. These device packages carry the device description, exposed functions,
and have configuration script content. When the device package is imported, the ACI fabric has full
understanding of what a device can do, how it connects to the fabric, how to build path forwarding to bring
traffic into and get traffic back from the device, and how to translate policy intent to a device-specific
configuration. This device package is a vendor-developed package that is readily available from the original
vendor.
An up-to-date listing of partners that leverage the API are available at the following URL:
http://www.cisco.com/c/en/us/solutions/data-center-virtualization/unified-fabric/aci_ecosystem.html

Services Deployment Guide Reference


The diagram below shows a high level overview of the Layer 4 to Layer 7 services workflow when attempting
to integrate a device.
Figure 49: Layer 4 to Layer 7 Workflow

For information about deploying Layer 4 to Layer 7 services, see the Cisco APIC Layer 4 to Layer 7 Services
Deployment Guide.
The key sections of the Cisco APIC Layer 4 to Layer 7 Services Deployment Guide are listed below:

Device Types
Cisco Application Centric Infrastructure (ACI) supports integration with Layer 4 to Layer 7 devices using
several different methods, including:
• Device Clusters
• Chassis Manager
• Device Manager
A Layer 4 to Layer 7 device cluster is a cluster of up to two identically configured Layer 4 to Layer 7 devices.
The individual devices within a device cluster are referred to as concrete devices. When the Layer 4 to Layer

Operating Cisco Application Centric Infrastructure


159
Layer 4 to Layer 7 Service Insertion
Services Deployment Guide Reference

7 device cluster is managed, the Application Policy Infrastructure Controller (APIC) communicates directly
with the concrete devices.
As virtual Layer 4 to Layer 7 devices become more pervasive, some vendor implementations provide a chassis
platform on which multiple virtual Layer 4 to Layer 7 services run. With the proper device package support,
ACI integrates with chassis manager implementation to ensure proper configuration of the entire virtual Layer
4 to Layer 7 services solution.
ACI also supports integration with Layer 4 to Layer 7 vendors who provide a separate device manager solution.
For example, the BIG-IQ solution from F5 provides centralized management of BIG-IP Local Traffic
Management (LTM) modules and Application Delivery Controllers (ADCs). When a Layer 4 to Layer 7
device manager is available, the APIC communicates with the device manager platform, as opposed to
communicating directly with the Layer 4 to Layer 7 device cluster.

Device Modes
Each Layer 4 to Layer 7 device cluster configured in ACI is either managed or unmanaged. In managed mode,
ACI is responsible for the configuration of both the ACI fabric and the Layer 4 to Layer 7 device. The Layer
4 to Layer 7 device essentially becomes an extension of the ACI fabric, with all configuration managed through
the APIC GUI or RESTful APIs. When configuring the Layer 4 to Layer 7 device as unmanaged, ACI only
handles the fabric portion of the configuration, with the configuration of the Layer 4 to Layer 7 device left to
one of the traditional methods (GUI, CLI, etc.) of that device.
The following table summarizes the differences between managed and unmanaged modes:

Mode Fabric Configuration Layer 4 to Layer 7 Device Layer 4 to Layer 7 Device


Configuration Health Monitoring

Managed Yes Yes Yes

Unmanaged Yes No No

Import Device Package


To begin the process of Layer 4 to Layer 7 services integration, ACME will import the vendor/model-specific
device packages, as shown in this section of the Cisco APIC Layer 4 to Layer 7 Services Deployment Guide.
This step is only reqied when the Layer 4 to Layer 7 device operates in managed mode.

Create a Device
Once the device package is imported, the Layer 4 to Layer 7 devices are added through a process of creating
a logical device cluster and creating a relationship between this logical device and the concrete device. This
is done with a physical or virtual Layer 4 to Layer 7 device. The configuration steps differ slightly for physical
devices and virtual devices, but are very similar.

Modify a Device
You can modify a device's configuration as described in this section of the Cisco APIC Layer 4 to Layer 7
Services Deployment Guide.

Create Layer 4 to Layer 7 Service Graph Template


This section of the Cisco APIC Layer 4 to Layer 7 Services Deployment Guide explains how to create a service
graph template.

Operating Cisco Application Centric Infrastructure


160
Layer 4 to Layer 7 Service Insertion
Service Graph Monitoring

Apply a Service Graph Template to EPGs


Once the application endpoint groups have been created, the process to apply a service graph template between
endpoint groups is found in this section of the Cisco APIC Layer 4 to Layer 7 Services Deployment Guide.

Service Graph Monitoring


After ACME Inc. has deployed service graphs for Layer 4 to Layer 7 service insertion, the requirement of
observing the service graphs becomes an operational imperative. To support these efforts, there are a few
techniques that can be employed, including:
• Monitoring a service graph instance
• Monitoring and resolving service graph faults
• Monitoring a device cluster

Monitoring a Service Graph Instance


Once a service graph template is configured and associated with a contract that is attached to an endpoint
group, there are some primary monitoring aspects that should be considered:
• State of the service graph
• Functions of a graph instance
• Resources allocated to a function
• Parameters specified for a function

To monitor a service graph instance using the GUI:


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > L4-L7 Services > Deployed Graph Instances. The
Work pane displays information about the deployed graph instances, including a list of the deployed
service graphs, the associated contracts, and the current state of the graph policy. A state of "applied"
means the graph has been applied and is active in the fabric and the service device.

For more information about the possible states and other relevant states, see the Cisco APIC Layer 4 to Layer
7 Services Deployment Guide.

Monitoring and Resolving Service Graph Faults


To monitor a service graph's faults using the GUI:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > L4-L7 Services > Deployed Graph Instances.

Operating Cisco Application Centric Infrastructure


161
Layer 4 to Layer 7 Service Insertion
Monitoring a Device Cluster

4. Choose the deployed graph instance that you want to monitor.


5. In the Work pane, choose the Faults tab. The Work pane displays the faults that are related to the active
service graph.

To monitor a service graph's faults using the CLI:


1. Open an SSH session to one of the APICs.
2. Execute the show faults l4l7-graph command.

To understand the faults listed and possible resolutions, see information about resolving service graph faults
in the Cisco APIC Layer 4 to Layer 7 Services Deployment Guide.

Monitoring a Device Cluster


After you configure a service graph template and deploy the graph between endpoint groups, you can monitor
the device clusters associated with the service graphs of a tenant. Monitoring the device clusters tells you
what device clusters are associated, which VLANs are configured for a device cluster, the functions in use
and the function parameters passed to the devices, the statistics from the devices, and the health of the devices
in a device cluster.
To monitor a device cluster using the GUI:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > L4-L7 Services > L4-L7 Devices. The Work pane
displays information about the device cluster, such as faults and health scores.

To monitor a device cluster using the CLI:


1. Open an SSH session to one of the Application Policy Infrastructure Controller (APIC).
2. Execute the show l4l7-cluster command. For example, to view the configuration for cluster "fw1" in
tenant "tenant1", enter the following command:
rtp2-apic1# show l4l7-cluster tenant tenant1 cluster fw1
Device Cluster : fw1
Total Graph Instances : 1
Active Graphs : sg1
Encaps Used : vlan-2150,vlan-2152

Graph Instance : 1
Consumer EPg : epg-external
Provider EPg : epg-internal
Contract Name : c1
Graph Name : sg1

Function Connector : consumer


Encap : vlan-2150
pctag : 16388
scope : 2523138
Bridge-Domain : bd-external
Contract Name : c1
Graph Name : sg1
Node Name : N1
Device Interface : fw1_Device_1([GigabitEthernet0/1]): vnic "Network adapter 3"

Operating Cisco Application Centric Infrastructure


162
Layer 4 to Layer 7 Service Insertion
ASAv Sample Configuration

Function Connector : provider


Encap : vlan-2152
pctag : 32773
scope : 2523138
Bridge-Domain : bd-internal
Contract Name : c1
Graph Name : sg1
Node Name : N1
Device Interface : fw1_Device_1([GigabitEtnernet0/0]): vnic "Network adapter 2"

3. To view the health for a device cluster, execute the show health l4l7-cluster command.
4. To view the faults for a device cluster, execute the show faults l4l7-cluster command.

ASAv Sample Configuration


One of the service nodes that ACME Inc. will integrate is an ASAv deployed in single-node, routed firewall
mode. This example details the process they followed to configure the ASAv firewall virtual service appliance
as a single node in routed mode. As a routed node, the ASAv is the default gateway for the hosts in the 2
endpoint groups that are connected by the contract to which this service graph is associated.
The high level steps are:
• Create Logical and Concrete device clusters
• Define a firewall ruleset/graph
• Deploy the graph between 2 endpoint groups

Verifying the ASAv Virtual Machine Configuration


The first set of steps performed is to verify ASAv virtual machine configuration and upload the ASA device
package (or verify if it has already been done).
1. Log in to the ASAv VM.
2. Enter enable mode.
3. Enter the following command:
ciscoasa# show interface ip brief

4. Verify that the ASAv has a correct IPv4 address on the Management 0/0 interface.
5. Verify connectivity from the Application Policy Infrastructure Controller (APIC) to the management 0/0
interface of the ASAv.
1. Open an SSH session to one of the APICs.
2. Enter the following command:
apic1# ping ASAv_Management0/0_interface_IP_address

3. The return response should be similar to the following example:

64 bytes from 172.16.10.10: icmp_seq=1 ttl=64 time=0.050 ms

Operating Cisco Application Centric Infrastructure


163
Layer 4 to Layer 7 Service Insertion
Removing the Gateway IP Address from the Relevant Fabric Bridge Domains

If the response is different, then there is likely some sort of connectivity issue. Resolve the connectivity
problems before moving on.

6. In the GUI, on the menu bar, choose L4-L7 Services > Packages.
7. In the Navigation pane, expand L4-L7 Service Device Types.
8. If an ASA device package is not listed, then perform the following actions:
1. Right click on the L4-L7 Services Device Types.
2. Choose Import Device Package.
3. Follow the prompts to upload the device package.

Removing the Gateway IP Address from the Relevant Fabric Bridge Domains
Once the ASAv package and VM are verified, the next step is to remove bridge domain or gateway IP addresses
from the fabric bridge domains so the Layer 3 routed firewall can become the default gateway.
To remove the routing default gateway function on the EPG1 and EPG2 bridge domains:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Networking > Bridge Domains > BD-EPG1.
4. In the Work pane, perform the following actions:
1. For the L2 Unknown Unicast radio buttons, click Flood.
2. In the L3 Configurations tab, uncheck the Unicast Routing check box.
3. Click Submit.

Repeat this process for the bridge domains of the affected endpoint groups.

Creating a Layer 4 to Layer 7 Device


Perform the following steps to add logical and concrete device clusters to a tenant:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation Pane choose Tenant_Name > L4-L7 Services > Function Profiles.
4. In the Work pane, click Create Profile Group.
5. In the Create a L4-L7 Function Profile dialog box, perform the following actions:
1. Enter a name that is relevant to the tenant and function, such as "TXX-FP-Group".
2. In the Navigation pane, choose the function profile group.
3. Right click the function profile group and choose Create L4-L7 Services Function Profile.

Operating Cisco Application Centric Infrastructure


164
Layer 4 to Layer 7 Service Insertion
Creating a Layer 4 to Layer 7 Device

4. Enter a meaningful name, such as "TXX-ASAv-Profile".


5. In the Profile drop-down list, choose WebPolicyForRoutedMode.
6. In the Feature and Parameters section, choose the All Parameters tab. You will configure IP
addressing under Interface Related Configuration for both external and internal interfaces
(externalIf and interalIf).
7. Expand Interface Related Configuration for externalIf.
8. Expand Interface Specific Configuration.
9. Expand IPv4 Address Configuration.
10. Double-click IPv4 Address.
11. Enter the IPv4 address in the "a.b.c.d/m.n.o.p" format.
12. Click Update.
13. Repeat steps 4f to 4j for the internalIf interface.

6. Choose L4-7 Services > Function Profiles > ALL PARAMETERS.


7. Verify the external and internal interfaces IPv4 addresses.

The following steps create a Layer 4 to Layer 7 device:


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > L4-L7 Services > L4-L7 Devices.
4. In the Work pane, click Create L4-L7 Devices.
5. In the Create L4-L7 Devices dialog box, perform the following actions:
1. Enter a meaningful name: Txx-ASAv-Cluster
2. Device Package: CISCO-ASA-1.x Model: ASAv
3. Mode: Single Node
4. Function Type: Goto
5. Connectivity VMM Domain: Txx-vCenter
6. APIC to Device: Out of Band
7. Credentials: username_and_password
8. Under Device 1, specify the following values:
1. Management IP address: ASAv IP address
2. Management Port: https
3. VM: Tenant ASAv Controller (in the dropdown box)
4. Virtual Interfaces: Create two entries; click + twice; enter interface values accordingly:

Operating Cisco Application Centric Infrastructure


165
Layer 4 to Layer 7 Service Insertion
Creating a Layer 4 to Layer 7 Service Graph Template

1. Name: GigabitEthernet0/0 vNIC: Network Adapter 2 Direction: provider


2. Name: GigabitEthernet0/1 vNIC: Network Adapter 3 Direction: consumer

5. Click UPDATE after each entry.


6. Click NEXT.
7. Click FINISH.

Verify the Logical and Concrete Device Clusters have been configured:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation Pane choose Tenant_Name > L4-L7 Services > L4-L7 Devices.
4. Expand both TXX-ASAv-Cluster and TXX-ASAv-Cluster_Device_1 to view the logical and physical
interfaces.
5. Select TXX-ASAv-Cluster_Device_1 to see a graphic view of the concrete device.

Note: This completes the Logical and Concrete device creation.

Creating a Layer 4 to Layer 7 Service Graph Template


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > L4-L7 Services > L4-L7 Service Graph Templates.
4. In the Work pane, choose Actions > Create a L4-L7 Service Graph Template.
5. In the Create L4-L7 Devices dialog box, perform the following actions:
1. In the Name field, enter "TXX-ASAv-L3-Routed-Template".
2. In the Type drop-down list, choose Single Node - Firewall in Routed Mode.
3. In the Device Function drop-down list, choose CISCO-ASA-1.x/Firewall.
4. In the Profile drop-down list, choose TXX-ASAv-FP, which is the functional profile you created
previously.
5. Click Submit.

6. You can verify that the template was created successfully by expanding Tenant_Name > L4-L7 Services
> L4-L7 Service Graph Templates > Txx-ASAv-L3-Routed-Template > Function Node - Firewall.

Apply the Service Graph Template


1. On the menu bar, choose Tenants > ALL TENANTS.

Operating Cisco Application Centric Infrastructure


166
Layer 4 to Layer 7 Service Insertion
Verifying Service Node Configuration

2. In the Work pane, choose the tenant.


3. In the Navigation pane, choose Tenant_Name > L4-L7 Services > L4-L7 Service Graph Templates.
4. Right click Txx-ASAv-L3-Routed-Template and choose Apply L4-L7 Service Graph Template.
5. In the Apply L4-L7 Service Graph Template to EPGs dialog box, perform the following actions:
1. In the Consumer EPG / External Network drop-down list, choose EPG1.
2. In the Provider EPG / External Network drop-down list, choose EPG2.
3. In the Service Graph Template drop-down list, choose Txx-ASAv-L3-Routed-Template.
4. For the Contract radio buttons, click Create A New One.
5. Check the No Filter (Allow All Traffic) check box.
6. In the Contract Name field, enter "TXX-EPG1-to-EPG2".
7. Click Next.
8. In the L4-L7 Devices drop-down list, choose Txx-ASAv-Cluster.
9. In the Features and Parameters section, choose the All Parameters tab.
10. Double click Device Config > Interface Related Configuration externalIf > Access Group >
Inbound Access List.
11. In the Value drop-down list, choose access-list-inbound.
12. Click Update.
13. Expand Device Config > Interface Related Configuration externalIf > Interface Related
Configuration to verify the IP address assignment. If the mask is missing, the configuration will
not push to the ASA.
14. Double click Device Config > Interface Related Configuration internalIf > Access Group >
Inbound Access List.
15. Click Reset. This unassigns the inbound access list from the internal interface. This inbound access
list is not desirable for the lab traffic-flow.
16. Expand Device Config > Interface Related Configuration internalIf > Interface Specific
Configuration to verify the IP address assignment with the mask.
17. Click Finish. The Devices Selection Polices folder and Deployed Graph Instances folder are now
populated.

6. Choose TXX-EPG1-to-EPG2-TXX-ASAv-L3-Router-Template-TXXProduction. You can see that


the Consumer and Provider EPGs are associated with the EPG1 and EPG2 server EPGs.

Verifying Service Node Configuration


Once the Device has been integrated and the Service Graph has been configured and associated, the resulting
configuration pushed to the service node can be verified by simple show commands on the real service node
device.

Operating Cisco Application Centric Infrastructure


167
Layer 4 to Layer 7 Service Insertion
Verifying Service Node Configuration

Display the Access List configuration pushed-down from APIC


SSH to the ASAv service node for access list validation. Issue the following command:
ciscoasa# show access-list

This will show the access list configuration and you can relate that to the configuration that was done in the
APIC.

Display the Interface configuration pushed-down from APIC


SH to the ASAv service node for interface configuration validation. Issue the following command:
ciscoasa# show interface ip brief

This will show the interface configuration where the IP address configuration was pushed from the APIC.

Display the current Interface names


SSH to the ASAv service node for interface name configuration validation. Issue the following command:
ciscoasa# show nameif

This will show the interface names pushed from the APIC and will show the related interface names to the
logical interface names that were configured in the APIC above.

Operating Cisco Application Centric Infrastructure


168
CHAPTER 8
Health Scores
• Understanding Health Scores, on page 169
• Understanding Faults, on page 172
• How Health Scores Are Calculated, on page 173
• Health Score Use Cases, on page 175

Understanding Health Scores


ACME's Operations team has been challenged on a regular basis to answer basic questions regarding the
current status, performance, and availability of the system they are responsible for operating. To address these
challenges they can now utilize the Cisco Application Centric Infrastructure (ACI), which provides health
scores that provide information on status, performance, and availability. While providing such answers might
be easy as it relates to an independent device or link, this information by itself is of little to no value without
additional data on its effect on the overall health of the network. To manually collect and correlate information
would have previously been a long and tedious task, but with health scores, data throughout the fabric is
collected, computed, and correlated by the Application Policy Infrastructure Controller (APIC) in real time
and then presented in an understandable format.
Traditional network monitoring and management systems attempt to provide a model of the infrastructure
that has been provisioned, and describe the relationship between the various devices and links. The object
model at the heart of ACI is inherent to the infrastructure. A single consolidated health score therefore shows
the current status of all of the objects including links, devices, their relationships, the real-time status of their
utilization, and a quick at-a-glance assessment of the current status of the entire system or any subset of the
system. This visibility has a number of practical use cases, and in this chapter we will classify these use cases
as reactive and proactive. ACI also provides the flexibility to monitor some aspects of how the health scores
are calculated, and how various faults impact the calculation of the health score.
Most objects in the model will have an associated health score, which can be found from the Dashboard or
Policy tabs of the object from the GUI. To check the overall fabric health, in the APIC GUI, go to System >
Dashboard. You can view the following information:
• The controller health
• Nodes with health less than 99
• Tenants with health less than 99
• A health graph depicting the health score of the system over a period of time

Operating Cisco Application Centric Infrastructure


169
Health Scores
Understanding Health Scores

The health graph is a good indication of any system issues. If the system is stable, the graph will be a constant,
otherwise it will fluctuate.
All health scores are instantiated from the healthInst class and can be extracted through the API.
In a reactive capacity, ACI health scores provide a quick check in which a newly occurred issue instantly
results in a degradation of the health score. The root cause of the issue can be found by exploring the faults.
Health scores also provide a real-time correlation in the event of a failure scenario, immediately providing
feedback as to which tenants, applications, and EPGs are impacted by that failure.
Almost every object and policy has a Health tab. As an example, to check if a specific EPG has faults, you
can go to Tenants > APIC GUI > Tenants > Tenant > Application Profile > YourProfile > YourEPG. In
the work pane, look for the Health tab. You can also access the Health tab under History > Health. This tab
provides the affected object and how it is tied within the larger model. By clicking on the +, you can explore
the health tree of any affected object or policy to reveal the faults.
Figure 50: Object with a fault

Operating Cisco Application Centric Infrastructure


170
Health Scores
Understanding Health Scores

Proactively, ACI health scores can help identify potential bottlenecks in terms of hardware resources, bandwidth
utilization, and other capacity planning exercises. Operations teams also stand a better chance of identifying
issues before they impact customers or users.
Ideally, the health of all application and infrastructure components should always be at 100%. However, this
is not always realistic given the dynamic nature of data center environments. Links, equipment, and endpoints
have failures. Instead the health score should be seen as a metric that will change over time, with the goal of
increasing the average health score of a given set of components over time.

Viewing a Health Score Using the NX-OS-Style CLI


You can use the NX-OS-style CLI to view the health of specific objects.
To view the health of a tenant:
show health tenant tenant

To view the health of bridge domain of a tenant:


show health tenant tenant bridge domain bd

To view the health of an endpoint group of an application within a tenant:


show health tenant tenant application app epg epg

To view the health of a leaf:


show health leaf leafnode

The following example views the health of tenant "tenant1":


apic1# show health tenant tenant1
Score Change(%) UpdateTS Dn
----- ----- ------------------- ------------------------------
100 0 2015-11-13T18:23:14 uni/tn-pineapple/health
.767-08:00

The following example views the health of leaf 101:


apic1# show health leaf 101
Score Change(%) UpdateTS Dn
----- ----- ------------------- ------------------------------
72 10 2015-11-11T12:55:52 topology/pod-1/node-101/sys/health
.847-08:00

Viewing a Health Score Using the iShell


You can use the iShell to view the health of specific objects.
To view the health of an APIC:
show health controller ID

To view the health of a switch:


show health switch node

The following example views the health of switch 101:


admin@apic1:~> show health switch 101
Current Score Previous Score Timestamp Dn
------------- -------------- --------------------- -------------------
72 65 2015-11- topology/pod-1/
11T12:55:52.847-08:00 node-101/sys/health

Operating Cisco Application Centric Infrastructure


171
Health Scores
Understanding Faults

Understanding Faults
From a management point of view we look at the Application Policy Infrastructure Controller (APIC) from
two perspectives:
1. Policy Controller - Where all fabric configuration is created, managed and applied. It maintains a
comprehensive, up-to-date run-time representation of the administrative or configured state.
2. Telemetry device - All devices (Fabric Switches, Virtual Switches, integrated Layer 4 to Layer 7 devices)
in an Cisco Application Centric Infrastructure (ACI) fabric report faults, events and statistics to the APIC.
Faults, events, and statistics in the ACI fabric are represented as a collection of Managed Objects (MOs)
within the overall ACI Object Model/Management Information Tree (MIT). All objects within ACI can be
queried, including faults. In this model, a fault is represented as a mutable, stateful, and persistent MO.
Figure 51: Fault Lifecycle

When a specific condition occurs, such as a component failure or an alarm, the system creates a fault MO as
a child object to the MO that is primarily associated with the fault. For a fault object class, the fault conditions
are defined by the fault rules of the parent object class. Fault MOs appear as regular MOs in MIT; they have
a parent, a DN, RN, and so on. The Fault "code" is an alphanumerical string in the form FXXX. For more
information about fault codes, see the Cisco APIC Faults, Events, and System Messages Management Guide.

Operating Cisco Application Centric Infrastructure


172
Health Scores
How Health Scores Are Calculated

The following example is a REST query to the fabric that returns the health score for a tenant named "3tierapp":

https://hostname/api/node/mo/uni/tn-3tierapp.xml?query-target=self&rsp-subtreeinclude=
health

The following example is a REST query to the fabric that returns the statistics for a tenant named "3tierapp":

https://hostname/api/node/mo/uni/tn-3tierapp.xml?query-target=self&rsp-subtreeinclude=
stats

The following example is a REST query to the fabric that returns the faults for a leaf node:

https://hostname/api/node/mo/topology/pod-1/node-103.xml?query-target=self&rspsubtree-
include=faults

As you can see, MOs can be queried by class and DN, with property filters, pagination, and so on.
In most cases, a fault MO is automatically created, escalated, de-escalated, and deleted by the system as
specific conditions are detected. There can be at most one fault with a given code under an MO. If the same
condition is detected multiple times while the corresponding fault MO is active, no additional instances of
the fault MO are created. In other words, if the same condition is detected multiple times for the same affected
object, only one fault is raised while a counter for the recurrence of that fault will be incremented. A fault
MO remains in the system until the fault condition is cleared. To remove a fault, the condition raising the
fault must be cleared, whether by configuration, or a change in the run time state of the fabric. An exception
to this is if the fault is in the cleared or retained state, in which case the fault can be deleted by the user by
acknowledging it.
Severity provides an indication of the estimated impact of the condition on the capability of the system or
component to provide service.
Possible values are:
• Warning (possibly no impact)
• Minor
• Major
• Critical (system or component completely unusable)
The creation of a fault MO can be triggered by internal processes such as:
• Finite state machine (FSM) transitions or detected component failures
• Conditions specified by various fault policies, some of which are user configurable
For example, you can set fault thresholds on statistical measurements such as health scores, data traffic, or
temperatures.

How Health Scores Are Calculated


Health scores exist for systems and pods, tenants, managed objects (such as switches and ports), as well as
an overall health score for the overall system. All health scores are calculated using the number and importance
of faults that apply to it. System and pod health scores are a weighted average of the leaf health scores, divided
by the total number of learned end points, multiplied by the spine coefficient which is derived from the number
of spines and their health scores. In other words:

Operating Cisco Application Centric Infrastructure


173
Health Scores
How Health Scores Are Calculated

Figure 52: Health Score calculation

Tenant health scores are similar, but contain health scores of logical components within that tenant. For
example, it will only be weighted by the end points that are included in that tenant.
You can see how all of these scores are aggregated by looking at how managed object scores are calculated,
which is directly by the faults they have associated with them. Each fault is weighted depending on the level
of importance. Critical faults might have a high fault level at 100%, while warnings might have a low fault
level at only 20%. Faults that have been identified as not impacting might even be reassigned a percentage
value of 0% so that it does not affect the health score computation.
Luckily there is really no need to understand the calculations of the health scores to use them effectively, but
there should be a basic understanding of whether faults should have high, medium, low, or "none" fault levels.
Though faults in ACI come with default values, it is possible to change these values to better match your
environment.
Keep in mind, because of the role-based access control, not all administrators will be able to see all of the
health scores. For example, a fabric admin will be able to see all health scores, but a tenant admin would only
be able to see the health scores that pertain to the tenants to which they have access. In most cases, the tenant
admin should be able to drill into the health scores that are visible to them, but it is possible a fault may be
occurring that is affecting more than that one tenant. In this case the fabric administrator may have to start
troubleshooting. The tenant and fabric admins may also see health scores of any layer four through seven
devices, such as firewalls, load balancers, and intrusion prevention/detection systems. These, along with faults
within our VMM domains will all roll up into our tenant, pod, and overall system health scores.

Operating Cisco Application Centric Infrastructure


174
Health Scores
Health Score Use Cases

For more information on how to use faults, see Troubleshooting Cisco Application Centric Infrastructure at
http://aci-troubleshooting-book.readthedocs.org/en/latest/.

Health Score Use Cases


Using Health Scores for Proactive Monitoring
While ACME administrators have traditionally spent a lot of time reacting to issues on the network, ACI
health scores will allow them to start preventing issues. Health scores not only act as indicators of faults, they
are essentially baselines to which you can make comparisons later. If you see that one of the leaf switches is
at 100% (green for good) one week, and the next week the leaf is showing a warning, you can drill down to
see what changed. In this scenario, it is possible the links are oversubscribed and so it can be time to either
move some of of the workload to another leaf or maybe to add more bandwidth by connecting more cables.
Since it is still only a warning, there is time to resolve the issue before any bottlenecks on the network are
noticeable.
The same scenario can observed with a load balancer or firewall that is getting overloaded. In these cases
adding another load balancer, or firewall, or maybe even optimizing the rules may be needed to make traffic
flow more efficient. As shown in the above examples, this baselining method can be used as a capacity planning
tool.
Other ways health scores can be used to proactively monitor your ACI environment are by giving visibility
of certain components to other groups. Since you can export the scores and faults, it is possible to send these
notifications to application owners, VMware administrators, Database Administrator, and so on. This would
provide monitoring of the environment across the network that has not previously been available and which
is not able to be retrieved by any other means.

Using Health Scores for Reactive Monitoring


Reactively, health scores can be used to diagnose problems with the ACI fabric. Upon notification that a health
score has been degraded, an operator can use the GUI to easily navigate the relationships and faults that are
contributing to that health score. Once the root cause faults have been identified, the fault itself will contain
information about possible remediation steps.
Most objects will have a Health tab which can be used to explore the relationship between objects, and their
associated faults. This provides the ability to "double-click to root cause".

Operating Cisco Application Centric Infrastructure


175
Health Scores
Using Health Scores for Reactive Monitoring

Operating Cisco Application Centric Infrastructure


176
CHAPTER 9
Monitoring
• Proactive Monitoring - Tenant and Fabric Policies, on page 177
• Monitoring APICs, on page 184
• Monitoring Switch CPU Utilization, on page 188
• Monitoring Switch Memory Utilization, on page 190
• Monitoring File System Health, on page 191
• Monitoring CoPP (Control Plane Policing) Statistics, on page 193
• Physical Interface Statistics and Link State, on page 194
• Module Status, on page 195
• Switch Fan Status, on page 196
• Switch Power Supply Status, on page 197
• LLDP Neighbor Status, on page 198
• CDP Neighbor Status, on page 198
• GOLD Diagnostic Results, on page 199
• Proactive Monitoring Use Cases, on page 200
• Reactive Monitoring, on page 201
• Reactive Monitoring Tools, on page 204
• Reactive Monitoring Use Cases, on page 210

Proactive Monitoring - Tenant and Fabric Policies


Proactive monitoring is a very important piece of the network administrator's job, but is often neglected
because putting out fires in the network usually takes priority. However, since the Application Policy
Infrastructure Controller (APIC) makes it incredibly easy to gather statistics and perform analyses, this will
save network administrators both time and frustration. Since statistics are gathered automatically and policies
are used and can be re-used in other places, the human error and effort is minimal.
Statistics gathering has been a somewhat manual and even resource intensive process for ACME in the past.
Even when they have used tools to gather data on layer one through seven devices, it has still been necessary
to manually specify which devices are to be monitored and how they should be monitored. For example,
SNMP and a third party tool may have been used to monitor the CPU of switches or bandwidth utilization on
ports, but they struggled with entering correct SNMP information on each device, or often forgot to add a
new device to their Network Monitoring System (NMS). Cisco Application Centric Infrastructure (ACI)
provides an APIC which will do all of the statistics gathering, and provides the ability to proactively monitor
your entire environment without all of the hassle of maintaining a third party monitoring tool.

Operating Cisco Application Centric Infrastructure


177
Monitoring
Create Tenant Monitor Policy

The APIC, whether accessed through the GUI, CLI, or API, can be used to drill into any of the components
and provides the ability to click on a Stats tab to display on-demand statistics, but more importantly it enables
the setup of policies to keep persistent data to analyze trends in the environment, as well as to troubleshoot
or predict any issues that may be arising. When planning to move an application from a legacy network to
the ACI infrastructure, it is sensible to start by testing before going straight to production. Add test VMs to
port groups on either a DVS or AVS associated with the APIC, and add physical test servers to VPCs on the
leaf switches. This could also be in a testing tenant which is completely separate from the production
environment. At this point the APIC is already gathering statistics for the VMM domain and the physical
devices. The next step is to configure a policy for trend analysis.
There are four different scopes for statistics gathering: Common or Fabric Wide, Fabric, Tenant, or Access.
A Fabric Wide policy would be created as a default policy to be applied to all tenants. However, to override
that policy for a particular tenant, the tenant policy will override the Fabric policy. In the following testing
example, a Tenant policy is created to gather statistics. Even if this tenant is shared with other applications,
customers, test cases, it will provide a real world example of how the application will behave in a production
environment.

Create Tenant Monitor Policy


To create a tenant monitoring policy:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane, choose Tenant_Name > Monitoring Policies.
4. In the Work pane, choose Actions > Create Monitoring Policies.
5. In the Create Monitoring Policies dialog box, perform the following actions:
1. In the Name field enter a name for the Monitoring Policy.
2. Click Submit.

6. In the Navigation pane, choose Tenant_Name > Monitoring Policies > Policy_Name to display the
following information:
• Stats Collection Policies
• Stats Export Policies
• Callhome, SNMP, and Syslog
• Event Severity Assignment Policies
• Fault Severity Assignment Policies
• Fault Lifecycle Policies

Stats Collection Policies


Clicking on Stats Collection Policies will display the default retention periods and admin states
(Enabled/Disabled) for ALL Monitored Objects. Most likely the defaults will be kept, but a double click on
them will change the admin state or retention periods. For example, to have it poll a component every 5

Operating Cisco Application Centric Infrastructure


178
Monitoring
Stats Export Policies

minutes, but be retained for 2 hours, just click on the policy that specifies a 5 minute granularity and change
the retention period to 2 hours. It is similarly possible to change the policies for specific Monitoring Objects.
A monitoring object tells the APIC which components to gather statistics about. For example, to change the
information gathered for Bridge Domains, use the Bridge Domain (infra.RSOInfraBD) Monitoring Object.
To add monitoring objects:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Monitoring Policies > Monitoring Policy_Name >
Stats Collection Policies
1. Click on the Pencil icon to edit the Monitoring Objects.
2. Put a checkmark next to the Monitoring Objects to be included, and remove any checkmarks next
to Monitoring Objects to be left out.
3. Click Submit.

For this example, changes might be made to Monitoring Object policies for Tenant, VXLAN Pool, Leaf Port,
and/or Taboo Contract. There are several options and this will all depend on what is important to monitor in
the environment. Click on the pull down menu to select a monitoring object and add a retention policy to it.
To add a policy to a Monitoring Object:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Monitoring Policies > Monitoring Policy_Name > Stats Collection
Policies.
4. In the Work pane, in the Stats Collection Policy dialog box, perform the following actions:
1. Select the Monitoring Object.
2. Click + to add the policy.
3. Select the granularity with which it is to poll.
4. Leave the state as inherited to stick with the defaults as set for ALL, or explicitly select enabled or
disabled.
5. The retention policy may either be inherited or explicitly specified as enabled or disabled as well.
6. Click Update.

Stats Export Policies


It is desirable to collect these ongoing statistics as well as to see how this data behaves over time. Use the
Stats Export Policies option in the left navigation pane, located under the monitoring policy. Much like the
Stats Collection Policies, it is possible to create a policy for ALL monitoring objects, or select specific
monitoring objects and specify where this information will be saved.
To create a Stats Export Policy:

Operating Cisco Application Centric Infrastructure


179
Monitoring
Diagnostics Policies Using the GUI

1. On the menu bar, choose Tenants > ALL TENANTS.


2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane choose Tenant_Name > Monitoring Policies > Monitoring Policy_Name >
Stats Export Policies.
4. In the Work pane, in the Stats Export Policy dialog box, perform the following actions:
1. Select ALL or a specific monitoring object from the drop-down list.
2. Click + to add the policy.
3. Now define the Stats Export Policy in the wizard.
4. Choose either JSON or XML as the format. There's really no difference other than personal preference,
or it may be dictated by the tool used to read it.
5. Choose to compress it using GZIP, or leave it uncompressed.
6. Click + under Export Destinations to specify a server where this information is to be collected.
Another wizard will pop up to enable specification of the protocols and credentials used to connect
to this server.
7. Click Ok.

5. Click Submit.

Diagnostics Policies Using the GUI


The diagnostics policies are in the navigation pane on the left. This feature allows the setup of diagnostics
test for the Monitoring Objects that were specified in the Stats Collection Policies. Next to the Monitoring
Object is the Pencil button which enables selection of the monitoring objects to be configured with diagnostics
policies. There are two different kind of policies for configuration: Boot-Up diagnostics or Ongoing diagnostics.
To configure diagnostic policies:
1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane choose Tenant_Name > Monitoring Policies > Diagnostics Policies.
3. In the Work pane, in the Diagnostic Policies dialog box, perform the following actions:
Click on the Pencil Icon and put checks next to the Monitoring Objects to which diagnostics tests are
to be added.
1. Select one of the Monitoring Objects.
2. Click + to add an Object.
1. Select either Boot-Up or Ongoing.
2. Boot-Up runs the tests while the devices are booting, and Ongoing will run the tests as often as
specified within the wizard.
3. In the wizard give it a name and select the admin state.

Operating Cisco Application Centric Infrastructure


180
Monitoring
Call Home/SNMP/Syslog

4. There are five different diagnostics tests available: ASIC, CPU, Internal Connectivity, Peripherals,
and System Memory. Double-click on each to obtain the option of specifying no tests, full tests,
or recommended tests.
5. Click Submit.

The diagnostics found here can be useful in finding failed components before they cause major issues within
your environment.

Call Home/SNMP/Syslog
There are a few different ways to setup notification or alert policies. The Call Home/SNMP/Syslog policy
will allow alerting to be configured in a flexible manner. Cisco Call Home is a feature in many Cisco products
that will provide email or web-based notification alerts in several different formats for critical events. This
allows administrators to resolve issues before they turn into outages. SNMP or syslog policies can also be
used with current notification systems. Different logging levels may be selected for notifications and alert
levels specified for Monitoring Objects from which alerts are to be received.

Event Severity and Fault Severity Assignments


Event and fault severities can be changed for events raised by Monitoring Objects. Most likely, the default
severity assignments for Events and Faults will be kept, but there are examples where an ACI administrator
may decide the event or fault is more or less severe than the default value. For example, if only critical faults
are being notified, but there is a major fault you'd also like to be notified about immediately, you can change
the severity for that particular fault code.
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane, choose Tenant_Name > Monitoring Policies > Monitoring_Policy > Fault
Lifecycle Policies.
4. In the Work pane, in the Fault Severity Assignment Policies dialog box, perform the following actions:
1. Select a Monitoring Object, which will dictate the fault codes for which you are changing the fault
severity.
2. Click + to add an Object.
3. Select the particular fault code for which severity is to be changed.
4. Select the severity: Cleared, Critical, Major, Minor, Squelched, Inherit, Warning, Info.
Squelched gives it a weight of 0%, meaning it does not affect health scores.

5. Click Update.

The Event Severity Assignment Policies are configured in the same way.

Operating Cisco Application Centric Infrastructure


181
Monitoring
Fault Lifecycle Policies

Fault Lifecycle Policies


Fault Lifecycle is the term Cisco uses to describe the life of a fault. Once a fault is detected it is in the "soaking"
state. After a certain amount of time, referred to as the "soaking interval" it will move on to the "raised" state.
"Raised" means the fault is still present after the soaking interval. After the fault clears it's in a state called
"raised clearing." It is only in this state briefly and moves on to the "clearing time" state. It remains in the
"clearing time" state for the amount of time specified in the "clearing interval." Lastly it moves on to the
"retaining" state and does not get removed until the end of the "retaining interval."
To change Fault Lifecycle Intervals:
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the Tenant_Name .
3. In the Navigation pane, choose Tenant_Name > Monitoring Policies > Monitoring_Policy > Fault
Lifecycle Policies.
4. In the Work pane, in the Fault Lifecycle Policies dialog box, perform the following actions:
1. Select a Monitoring Object, which will dictate the fault codes for which you are changing the default
intervals.
2. Click +.
3. Specify times for the Clearing Interval, Retention Interval, and Soaking Interval (all in seconds).
Note: The default for the Clearing Interval is 120 seconds; the Retention Interval is 3600 seconds;
and the Soaking Interval is 120 seconds.

At this point there will be a fully working tenant monitoring policy. ACME will have other policies to configure
in the fabric as outlined in the following sections.

TCAM Policy Usage


The physical ternary content-addressable memory (TCAM) in which policy is stored for enforcement is an
expensive component of switch hardware and therefore tends to lower policy scale or raise hardware costs.
Within the Cisco Application Centric Infrastructure (Cisco ACI) fabric, policy is applied based on the EPG
rather than the endpoint itself. This policy size can be expressed as n*m*f, where n is the number of sources,
m is the number of destinations, and f is the number of policy filters. Within the Cisco ACI fabric, sources
and destinations become one entry for a given EPG, which reduces the number of total entries required.
TCAM is a fabric resource that should be monitored. There is a system wide view of available TCAM resources.
To view the TCAM resources, on the menu bar, choose Operations > Capacity Dashboard. The Work pane
displays a table that summarizes the capacity for all nodes.
TCAM is a critical system resource in a Cisco ACI fabric and should be monitored for utilization. The
architecture/design team should articulate what the assumptions were for TCAM utilization. There is a Fabric
Resource Calculation tool on Github that will help with estimation of normal operating parameters:
https://github.com/datacenter/FabricResourceCalculation.
As a general rule, the default monitoring policies will alert you to a resource shortage and lower overall fabric
health score. If your environment has a high rate of change, or you anticipate the possibility of consistently
being oversubscribed, you may want to set different thresholds.

Operating Cisco Application Centric Infrastructure


182
Monitoring
Create TCAM Policy Monitor

Create TCAM Policy Monitor


1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Monitor Policies > d efault > Stats Collection Policies.
3. In the Work pane, in the Stats Collection Policies dialog box, perform the following actions:
1. Select the Monitoring Object Equipment Capacity Entity (eqptcapacity.Entity).
2. Select the Stats Type Policy Entry.
3. Click + under Config Thresholds.
4. In the Thresholds For Collection 5 Minute window, select the blue pencil icon next to policy CAM
entries usage current value.

TCAM Prefix Usage


This procedure manages a TCAM Prefix Usage.
1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Monitor Policies > default > Stats Collection Policies.
3. In the Work pane, in the Stats Collection Policies dialog box, perform the following actions:
1. Select the Monitoring Object Equipment Capacity Entity (eqptcapacity.Entity).
2. Select the Stats TypeLayer3 Entry.
3. Click + under Config Thresholds.
4. In the Thresholds For Collection 5 Minute window, select the blue pencil icon next to policy CAM
entries usage current value.

Health Score Evaluation Policy


1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Monitor Policies > Common Policies > Health Score Evaluation
Policy > Health Score Evaluation Policy.
3. In the Work pane, in the Properties dialog box, perform the following actions:
1. In the Penalty of fault severity critical dropdown menu, select the desired %.
2. In the Penalty of fault severity major dropdown menu, select the desired %.
3. In the Penalty of fault severity minor dropdown menu, select the desired %.
4. In the Penalty of fault severity warning dropdown menu, select the desired %.

4. Click Submit.

Operating Cisco Application Centric Infrastructure


183
Monitoring
Communication Policy

Communication Policy
1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, expand Pod Policies > Policies > Communication.
3. In the Work pane, choose Actions > Create Communication Policy.
4. In the Create Communication Policy dialog box, perform the following actions:
1. Enter Communication Policy Name.
2. From the HTTP Admin State dropdown menu select the desired state.
3. From the HTTP Port dropdown menu select the desired port.
4. Select the desired HTTP redirect state.
5. From the HTTPS Admin State dropdown menu select the desired state.
6. From the HTTPS Port dropdown menu select the desired port.
7. Select the desired HTTPS redirect state.
8. From the SSH Admin State dropdown menu select the desired state.
9. From the Telnet Admin State dropdown menu select the desired state.
10. From the Telnet Port dropdown menu select the desired port.

5. Click Submit.

Monitoring APICs
CPU Utilization and Memory
GUI
The easiest way to quickly verify the health of the controllers is the APIC. When logging into the system
dashboard, the health of the APICs and the health of the cluster itself are displayed right at the dashboard.
The normal state for an APIC is to be green in a "fully fit" state, implying the APICs are synchronized with
each other.
A more detailed drilldown is available by clicking on System > Controllers.

REST API
Controllers provide information regarding the current status of CPU and memory utilization by creating
instances of the procEntity class. procEntity is a container of processes in the system. This object holds detailed
information about various processes running on the APIC. The procEntity objects contain the following useful
properties:
cpuPct - CPU utilization

Operating Cisco Application Centric Infrastructure


184
Monitoring
Disk Utilization

maxMemAlloc - The maximum memory allocated for the system


memFree - The maximum amount of available memory for the system
Sample Usage: This information can be retrieved for all APIC controllers using the following REST call:
http[s]://apic_ip/api/node/class/procEntity.xml?

CLI
The Linux Top utility also comes built into the APIC controllers and can be used for troubleshooting and/or
verification.

user@apic1:~> top
top - 11:41:51 up 16:50, 4 users, load average: 4.19, 4.27, 4.29
Tasks: 354 total, 1 running, 353 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.3%us, 0.4%sy, 0.0%ni, 99.3%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 131954932k total, 7473180k used, 124481752k free, 409540k buffers
Swap: 0k total, 0k used, 0k free, 1952656k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
32102 root 20 0 556m 205m 85m S 3.3 0.2 38:11.04 svc_ifc_applian
32120 ifc 20 0 660m 343m 86m S 2.0 0.3 27:58.73 svc_ifc_dbgr.bi
32121 ifc 20 0 631m 286m 86m S 2.0 0.2 17:41.92 svc_ifc_topomgr
32105 root 20 0 659m 258m 85m S 1.7 0.2 17:08.35 svc_ifc_bootmgr
32113 ifc 20 0 1083m 721m 69m S 1.7 0.6 20:03.37 svc_ifc_observe
32128 ifc 20 0 639m 315m 69m S 1.7 0.2 16:28.34 svc_ifc_reader.
32132 ifc 20 0 657m 252m 71m S 1.7 0.2 17:13.74 svc_ifc_scripth
1291 root 20 0 834m 419m 94m S 1.3 0.3 20:35.24 nginx.bin

Disk Utilization
GUI
There are several disks and file systems present on the APICs. The GUI provides ready access to disk space
utilization of all partitions on the system and can be used for monitoring this information.
The disk utilization can be viewed by clicking on System > Controllers > Apic-X > Storage
The work pane displays the utilization of all partitions in the system.

REST API
This information can be retrieved for all APIC controllers using the following REST call:

http[s]://apic-ip/api/node/class/eqptStorage.xml?

CLI

user@apic1:~> df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/dm-1 41282880 10518960 28666872 27% /
tmpfs 4194304 56456 4137848 2% /dev/shm
tmpfs 65977464 964 65976500 1% /tmp
/dev/mapper/vg_ifc0-data
41282880 10518960 28666872 27% /data
/dev/mapper/vg_ifc0-firmware
41284928 13860672 25327104 36% /firmware

Operating Cisco Application Centric Infrastructure


185
Monitoring
Physical and Bond Interface Statistics

/dev/mapper/vg_ifc0-data2
583149656 1281104 552246280 1% /data2

* Note that not all file systems are visible from the CLI as some require root access to reach the mount points.
The GUI should be used as a single source of truth for file system utilization.

Physical and Bond Interface Statistics


APICs use a bonded interface that is typically dual-homed to two leaves for connectivity to the ACI fabric
and have the ability to use a bonded interface that can be dual homed to the out-of-band management network.
Bond0 is the bond interface used to connect to the fabric itself (to connect to leaves that connect into the
fabric).
Bond1 is the bond interface used to connect to the out-of-band segment (to connect to an OOB segment that
allows setup of the APIC itself).
The bond interfaces rely on underlying physical interfaces and it is important to note that the GUI provides
link information for both the physical and logical bond interfaces.

GUI
To view interface status for the interfaces on the APICs, navigate to System > Controllers > Apic-x >
Interfaces

REST API
This information can be retrieved for all APIC controllers using the following REST call:

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-1/sys.json?querytarget=
subtree&target-subtree-class=l3EncRtdIf

CLI
Both "ifconfig" and the "ip link" CLI commands can be used to verify link state. The CLI also provides
information on detailed interface statistics such as RX and TX counters.

Fan Status
The following section describes methodologies to retrieve the status of the fan trays on the APICs.

GUI
To view interface status for the interfaces on the APICs, navigate to System > Controllers > Apic-x >
Equipment-Fans

REST API
This information can be retrieved for all APIC controllers using the following REST call:

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-1.json?querytarget=
subtree&target-subtree-class=eqptFan

Operating Cisco Application Centric Infrastructure


186
Monitoring
Temperature Status

CLI
The Fan status for the APICs can be monitored using the CLI on the CIMC port of the APIC. To obtain this,
login to the CIMC using the credentials used for setting up the CIMC (may not be the same as the credentials
used for APIC). If this has not been setup previously, the default username is admin and the default password
is password.
The CIMC port is the integrated lights-out management port that can be used to recover an APIC in the event
of a catastrophic failure.

user@apic1:~> ssh -l admin 172.16.176.179


Warning: Permanently added '172.16.176.179' (RSA) to the list of known hosts.
admin@172.16.176.179's password:
C220-FCH1807V02V# scope sensor
C220-FCH1807V02V /sensor # show fan
Name Sensor Reading Units Min. Max. Min. Max.
Status Warning Warning Failure Failure
----------- ------- -------- ----- --------- --------- -------- ---------
FAN1_TACH1 Normal 7490 RPM 1712 N/A 1284 N/A
FAN1_TACH2 Normal 7490 RPM 1712 N/A 1284 N/A
FAN2_TACH1 Normal 7490 RPM 1712 N/A 1284 N/A
FAN2_TACH2 Normal 7276 RPM 1712 N/A 1284 N/A
FAN3_TACH1 Normal 7704 RPM 1712 N/A 1284 N/A
FAN3_TACH2 Normal 7276 RPM 1712 N/A 1284 N/A
FAN4_TACH1 Normal 7704 RPM 1712 N/A 1284 N/A
FAN4_TACH2 Normal 7276 RPM 1712 N/A 1284 N/A
FAN5_TACH1 Normal 7704 RPM 1712 N/A 1284 N/A

Temperature Status
To monitor the temperature state of the various sensors available on the APICs use the following steps.

GUI
To view interface status for the interfaces on the APICs, navigate to System > Controllers > Apic-x >
Equipment-Sensors

REST API
This information can be retrieved for all APIC controllers using the following REST call:

https://{{apic-ip}}//api/node/mo/topology/pod-1/node-1.json?querytarget=
subtree&target-subtree-class=eqptSensor

CLI

C220-FCH1807V02V /sensor # show temperature


Name Sensor Reading Units Min. Max. Min. Max.
Status Warning Warning Failure Failure
------------------ -------- -------- ------- ------- --------- -------- ---------
P1_TEMP_SENS Normal 49.5 C N/A 81.0 N/A 86.0
P2_TEMP_SENS Normal 50.5 C N/A 81.0 N/A 86.0
RISER1_INLET_TMP Normal 45.0 C N/A 60.0 N/A 70.0
RISER2_INLET_TMP Normal 41.0 C N/A 60.0 N/A 70.0
RISER1_OUTLETTMP Normal 50.0 C N/A 60.0 N/A 70.0
RISER2_OUTLETTMP Normal 41.0 C N/A 60.0 N/A 70.0
FP_TEMP_SENSOR Normal 37.0 C N/A 60.0 N/A 70.0

Operating Cisco Application Centric Infrastructure


187
Monitoring
Power Supply Status

DDR3_P1_A1_TEMP Normal 42.0 C N/A 65.0 N/A 85.0


DDR3_P1_B1_TEMP Normal 43.0 C N/A 65.0 N/A 85.0
DDR3_P1_C1_TEMP Normal 44.0 C N/A 65.0 N/A 85.0
DDR3_P1_D1_TEMP Normal 44.0 C N/A 65.0 N/A 85.0
DDR3_P2_E1_TEMP Normal 43.0 C N/A 65.0 N/A 85.0
DDR3_P2_F1_TEMP Normal 43.0 C N/A 65.0 N/A 85.0
DDR3_P2_G1_TEMP Normal 42.0 C N/A 65.0 N/A 85.0
DDR3_P2_H1_TEMP Normal 41.0 C N/A 65.0 N/A 85.0
VICP81E_0_TMP3 Normal 56.0 C N/A 85.0 N/A 90.0
PSU1_TEMP Normal 37.0 C N/A 60.0 N/A 65.0
PCH_TEMP_SENS Normal 51.0 C N/A 80.0 N/A 85.0

Power Supply Status


To monitor the temperature state of the various sensors available on the APICs use the following steps.

CLI

C220-FCH1807V02V /sensor # show psu


Name Sensor Reading Units Min. Max. Min. Max.
Status Warning Warning Failure Failure
------------------ -------- -------- -------- ------- --------- -------- ---------
P1_TEMP_SENS Normal 49.5 C N/A 81.0 N/A 86.0
POWER_USAGE Normal 160 Watts N/A N/A N/A 800
PSU1_POUT Normal 136 Watts N/A 624 N/A 648
PSU1_PIN Normal 160 Watts N/A 720 N/A 744
PSU1_STATUS Normal present
PSU2_STATUS Normal absent
PSU1_PWRGD Normal good
PSU1_AC_OK Normal good

Monitoring Switch CPU Utilization


There are several methods to poll CPU utilization and trend it over different periods of time. The following
sections describe a few of the methods available.

GUI

REST API
Spine and Leaf switches CPU utilization can be monitored using the following classes, based on the desired
timescale and granularity.
proc:SysCPU5min - A class that represents the most current statistics for System cpu in a 5 minute sampling
interval. This class updates every 10 seconds.
proc:SysCPU15min - A class that represents the most current statistics for System cpu in a 15 minute sampling
interval. This class updates every 5 minutes.
proc:SysCPU1h - A class that represents the most current statistics for System cpu in a 1 hour sampling
interval. This class updates every 15 minutes.
proc:SysCPU1d - A class that represents the most current statistics for System cpu in a 1 day sampling
interval. This class updates every hour.

Operating Cisco Application Centric Infrastructure


188
Monitoring
Monitoring Switch CPU Utilization

proc:SysCPU1w - A class that represents the most current statistics for System cpu in a 1 week sampling
interval. This class updates every day.
proc:SysCPU1mo - A class that represents the most current statistics for System cpu in a 1 month sampling
interval. This class updates every day.
proc:SysCPU1qtr - A class that represents the most current statistics for System cpu in a 1 quarter sampling
interval. This class updates every day.
proc:SysCPU1year - A class that represents the most current statistics for System cpu in a 1 year sampling
interval. This class updates every day.
ACME would like to see the average CPU utilization of all of the fabric switches over the last day.

http[s]://apic_ip//api/node/class/procSysCPU1d.xml?

CLI

Leaf-1# show proc cpu sort


PID Runtime(ms) Invoked uSecs 1Sec Process
----- ----------- -------- ----- ------ -----------
4012 69510 493837 140 1.3% t2usd_tor
4065 7239 27609 262 1.3% python
4292 3841 134758 28 0.8% svc_ifc_opflexe
4391 2355 4423 532 0.4% nginx
4067 1911 206 9278 0.4% svc_ifc_policye
4302 1904 1862 1022 0.3% svc_ifc_observe
4311 1811 1018 1779 0.3% svc_ifc_confele
4123 1407 251 5606 0.3% svc_ifc_eventmg
4310 1802 689 2616 0.3% svc_ifc_dbgrele
4846 119693 36527 3276 0.2% stats_manager
3923 15406 2645 5824 0.1% pfmclnt
4864 2361 2812 839 0.1% ospfv3
4865 2402 2717 884 0.1% ospf
13606 435 211 2065 0.0% bgp
4296 6263 7413 844 0.0% snmpd
4297 6667 4542 1467 0.0% dc3_sensor
4299 8559 8225 1040 0.0% policy_mgr
4301 1860 19152 97 0.0% plog
4866 2792 3269 854 0.0% isis
5025 1611 1743 924 0.0% mcecm

In order to obtain a historical view of CPU utilization from the CLI it may be necessary to jump into an
alternative shell from the switch bash prompt. This shell is called vsh (or v-shell).

Leaf-1# show processes cpu history


1 1 33 1
746554661885833055376572545534667663554785033943645665335644
100
90
80
70
60
50
40 #
30 ##
20 ##
10 # ### ####### ######## # ## ##### ## #### # # #### ##
0....5....1....1....2....2....3....3....4....4....5....5....
0 5 0 5 0 5 0 5 0 5
CPU% per second (last 60 seconds)

Operating Cisco Application Centric Infrastructure


189
Monitoring
Monitoring Switch Memory Utilization

# = average CPU%
32 13311134111111111311111111131 11111113 1111 11231 1111111
749513800432206328353370732175609342000769025791144192680117
100
90
80
70
60
50
40 * * * *
30 * ** ** * * * *
20 ** **** ** * * ** * * *** ** ** ** ** *
10 ############################################################
0....5....1....1....2....2....3....3....4....4....5....5....
0 5 0 5 0 5 0 5 0 5
CPU% per minute (last 60 minutes)
* = maximum CPU% # = average CPU%
1
440
030
100 *
90 *
80 *
70 *
60 *
50 *
40 ***
30 ***
20 ***
10 ###
0....5....1....1....2....2....3....3....4....4....5....5....6....6....7.
0 5 0 5 0 5 0 5 0 5 0 5 0
CPU% per hour (last 72 hours)
* = maximum CPU% # = average CPU%

Monitoring Switch Memory Utilization


There are several methods to poll memory utilization and trend it over different periods of time. The following
sections describe a few of the methods available.

REST API
Spine and Leaf switches memory utilization can be monitored using the following classes, based on the desired
timescale and granularity.
proc:SysMem5min - A class that represents the most current statistics for System memory in a 5 minute
sampling interval. This class updates every 10 seconds.
proc:SysMem15min - A class that represents the most current statistics for System memory in a 15 minute
sampling interval. This class updates every 5 minutes.
proc:SysMem1h - A class that represents the most current statistics for System memory in a 1 hour sampling
interval. This class updates every 15 minutes.
proc:SysMem1d - A class that represents the most current statistics for System memory in a 1 day sampling
interval. This class updates every hour.
proc:SysMem1w - A class that represents the most current statistics for System memory in a 1 week sampling
interval. This class updates every day.

Operating Cisco Application Centric Infrastructure


190
Monitoring
Monitoring File System Health

proc:SysMem1mo - A class that represents the most current statistics for System memory in a 1 month
sampling interval. This class updates every day.
proc:SysMem1qtr - A class that represents the most current statistics for System memory in a 1 quarter
sampling interval. This class updates every day.
proc:SysMem1year - A class that represents the most current statistics for System memory in a 1 year
sampling interval. This class updates every day.
ACME would like to monitor memory over the last day, and would use the following REST call:

http[s]://apic_ip/api/node/class/procSysMem1d.xml?

CLI

Leaf-1# show system resources


Load average: 1 minute: 1.21 5 minutes: 1.14 15 minutes: 0.80
Processes : 513 total, 2 running
CPU states : 4.1% user, 2.5% kernel, 93.4% idle
Memory usage: 16401072K total, 9054020K used, 7347052K free
Current memory status: OK

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective. See the Cisco ACI MIB Support List.

Monitoring File System Health


CLI
Currently, the CLI is only way to monitor the utilization of the file system on the leaves. It is normal to see
a higher % utilization on some of the mount points in the file system hierarchy. The critical volumes to keep
track of in terms of utilization are /volatile, bootflash and logflash.

Leaf-1# df
df: `/nxos/tmp': No such file or directory
df: `/var/home': No such file or directory
df: `/var/tmp': No such file or directory
df: `/nginx': No such file or directory
df: `/debugfs': No such file or directory
df: `/recovery': No such file or directory
df: `/cfg0': No such file or directory
df: `/cfg1': No such file or directory
df: `/logflash/INXOS_SYSMGR/startup-cfg': No such file or directory
df: `/mnt/plog': No such file or directory
Filesystem 1K-blocks Used Available Use% Mounted on
rootfs 512000 1064 510936 1% /
rootfs 512000 1064 510936 1% /
none 512000 1064 510936 1% /isan
none 512000 1064 510936 1% /var
none 51200 2288 48912 5% /etc
none 51200 108 51092 1% /var/log
none 3145728 336664 2809064 11% /dev/shm
none 512000 0 512000 0% /volatile
/dev/sda4 7782036 1080636 6306088 15% /bootflash

Operating Cisco Application Centric Infrastructure


191
Monitoring
Monitoring File System Health

/dev/sda5 60485 5356 52006 10% /mnt/cfg/0


/dev/sda6 60485 5356 52006 10% /mnt/cfg/1
/dev/sda3 120979 13349 101384 12% /mnt/pss
/dev/sda7 512000 1064 510936 1% /logflash
/dev/sda9 15748508 591216 14357292 4% /mnt/ifc/cfg
/dev/sda8 15748508 991204 13957304 7% /mnt/ifc/log
/dev/sda8 15748508 991204 13957304 7% /var/log/dme/oldlog
/dev/sda9 15748508 591216 14357292 4% /controller
rootfs 716800 665728 51072 93% /mnt/ifc/cfg/mgmt/opt/controller/sbin
rootfs 716800 665728 51072 93% /controller/sbin
/dev/sda8 15748508 991204 13957304 7% /data/techsupport
rootfs 716800 665728 51072 93% /bin
/dev/sda4 7782036 1080636 6306088 15% /bootflash
rootfs 716800 665728 51072 93% /data/challenge.old.plugin
/dev/sda9 15748508 591216 14357292 4% /controller
rootfs 716800 665728 51072 93% /controller/sbin
rootfs 716800 665728 51072 93% /dev
none 3145728 336664 2809064 11% /dev/shm
none 51200 2288 48912 5% /etc
none 2097152 682360 1414792 33% /isan/plugin/0/isan/utils
none 2097152 682360 1414792 33% /isan/plugin/0/lc/isan/utils
none 2097152 682360 1414792 33% /isan/plugin/0/lc/isan/lib
none 2097152 682360 1414792 33% /isan/plugin/0/isan/lib
none 2097152 682360 1414792 33% /isan/lib
none 2097152 682360 1414792 33% /isan/plugin/0/lib
none 2097152 682360 1414792 33% /isan/utils
rootfs 716800 665728 51072 93% /lc/isan/utils
rootfs 716800 665728 51072 93% /lib
rootfs 716800 665728 51072 93% /mnt/cfg
/dev/sda5 60485 5356 52006 10% /mnt/cfg/0
/dev/sda6 60485 5356 52006 10% /mnt/cfg/1
rootfs 716800 665728 51072 93% /mnt/ifc
/dev/sda9 15748508 591216 14357292 4% /mnt/ifc/cfg
rootfs 716800 665728 51072 93% /mnt/ifc/cfg/mgmt/opt/controller/sbin
/dev/sda8 15748508 991204 13957304 7% /mnt/ifc/log
/dev/sda3 120979 13349 101384 12% /mnt/pss
rootfs 716800 665728 51072 93% /sbin
/dev/sda8 15748508 991204 13957304 7% /data/techsupport
none 1572864 39444 1533420 3% /tmp
rootfs 716800 665728 51072 93% /usr
none 51200 108 51092 1% /var/log
/dev/sda8 15748508 991204 13957304 7% /var/log/dme/oldlog
none 51200 108 51092 1% /var/log/messages
rootfs 716800 665728 51072 93% /var/log/dme
rootfs 716800 665728 51072 93% /var/log/dme/nginx
rootfs 716800 665728 51072 93% /usr/share/vim
/dev/sda7 11811760 375608 10836140 4% /var/log/dme/log
/dev/sda8 15748508 991204 13957304 7% /var/log/dme/oldlog
none 512000 1064 510936 1% /var/run/mgmt/log
none 512000 1064 510936 1% /var/run/utmp
/dev/sda7 11811760 375608 10836140 4% /var/sysmgr
none 40960 8 40952 1% /var/sysmgr/startup-cfg
/dev/sda7 11811760 375608 10836140 4% /logflash/core
rootfs 716800 665728 51072 93% /usb
none 512000 0 512000 0% /volatile

Operating Cisco Application Centric Infrastructure


192
Monitoring
Monitoring CoPP (Control Plane Policing) Statistics

Monitoring CoPP (Control Plane Policing) Statistics


CLI
CoPP is enabled by default and the parameters cannot be changed at this time. CoPP statistics are available
through the CLI.
To show the CoPP policy that is programed by the system use the following CLI command:

Leaf-1# show copp policy


COPP Class COPP proto COPP Rate COPP Burst
mcp mcp 500 500
ifc ifc 5000 5000
igmp igmp 1500 1500
nd nd 1000 1000
cdp cdp 1000 1000
pim pim 500 500
dhcp dhcp 1360 340
lacp lacp 1000 1000
ospf ospf 2000 2000
arp arp 1360 340
lldp lldp 1000 1000
acllog acllog 500 500
stp stp 1000 1000
eigrp eigrp 2000 2000
coop coop 5000 5000
traceroute traceroute 500 500
isis isis 1500 5000
icmp icmp 500 500
bgp bgp 5000 5000

To show drops against specific CoPP classes, use the following CLI command:

Leaf-1# show copp policy stats


COPP Class COPP proto COPP Rate COPP Burst AllowPkts AllowBytes DropPkts DropBytes
mcp mcp 500 500 0 0 0 0
ifc ifc 5000 5000 195072 161613961 0 0
igmp igmp 1500 1500 3 192 0 0
nd nd 1000 1000 6 564 0 0
cdp cdp 1000 1000 494 140543 0 0
pim pim 500 500 0 0 0 0
dhcp dhcp 1360 340 4 1400 0 0
lacp lacp 1000 1000 0 0 0 0
ospf ospf 2000 2000 0 0 0 0
arp arp 1360 340 1284 90068 0 0
lldp lldp 1000 1000 5029 1717208 0 0
acllog acllog 500 500 0 0 0 0
stp stp 1000 1000 0 0 0 0
eigrp eigrp 2000 2000 0 0 0 0
coop coop 5000 5000 4722 470546 0 0
traceroute traceroute 500 500 0 0 0 0
isis isis 1500 5000 17141 2167565 0 0
icmp icmp 500 500 0 0 0 0
bgp bgp 5000 5000 864 73410 0 0

Operating Cisco Application Centric Infrastructure


193
Monitoring
Physical Interface Statistics and Link State

Physical Interface Statistics and Link State


GUI
To access interface link state information, in the APIC GUI, navigate to Fabric > Inventory > Pod-1 >
Leaf-X > Interfaces > Physical Interfaces. In the work pane, the oper state column displays the operational
state of the link. Note that there are other tabs available in the work pane that reference other types of interfaces
like port-channels, virtual port-channels, routed interfaces, loopbacks, etc.
To access interface statistics, in the APIC GUI, navigate to Fabric > Inventory > Pod-1 > Leaf-X > Interfaces
> Physical interfaces > Eth X/Y, and then click on the Stats tab in the work pane. You can click on the check
icon enables you to select additional statistics that can be graphed.

REST API
For customers that prefer the REST API interface to poll for interface statistics, several objects are available.
There are several such counters that are available (e.g. RX/TX, input/output / duplex, 30 second rates, 5 minute
rate, unicast packets, multicast packets, etc.). As a pointer, the parent managed object is provided below, as
the children can be derived from it.
It is expected that the reader has a good understanding of the object model and is able to navigate through the
model to obtain the information desiered using the example below, information provided in preceding sections
and the tools described therein.
An example of the base API call for physical interface statistics is:

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/phys-[eth1/1].json

For example, to determine the total ingress bytes on Leaf 101 port Eth1/1, the ACME operator could issue
the following API call:

/topology/pod-1/node-101/sys/phys-[eth1/1].json

Visore allows the operator to dig deeper into the hierarchical tree. From the prior command, the operator could
see children of the interface object, such as ingress and egress bytes. One of the child objects includes the
following:

/topology/pod-1/node-101/sys/phys-[eth1/1]/dbgEtherStats

CLI
The show interface eth x/y command can be used to monitor interfaces from the CLI. Other supported
commands include "show interface port-channel x/y"

Leaf-1# show int e1/1


Ethernet1/1 is up
admin state is up, Dedicated Interface
Hardware: 1000/10000/auto Ethernet, address: 7c69.f60f.8771 (bia 7c69.f60f.8771)
MTU 9000 bytes, BW 1000000 Kbit, DLY 1 usec
reliability 255/255, txload 1/255, rxload 1/255
Encapsulation ARPA, medium is broadcast
Port mode is trunk
full-duplex, 1000 Mb/s, media type is 1G
Beacon is turned off

Operating Cisco Application Centric Infrastructure


194
Monitoring
Module Status

Auto-Negotiation is turned on
Input flow-control is off, output flow-control is off
Auto-mdix is turned off
Rate mode is dedicated
Switchport monitor is off
EtherType is 0x8100
EEE (efficient-ethernet) : n/a
Last link flapped 04:19:13
Last clearing of "show interface" counters never
1 interface resets
30 seconds input rate 169328 bits/sec, 97 packets/sec
30 seconds output rate 424528 bits/sec, 115 packets/sec
Load-Interval #2: 5 minute (300 seconds)
input rate 644416 bps, 134 pps; output rate 365544 bps, 114 pps
RX
2474537 unicast packets 8434 multicast packets 2 broadcast packets
2482973 input packets 1686129815 bytes
0 jumbo packets 0 storm suppression bytes
0 runts 0 giants 0 CRC 0 no buffer
0 input error 0 short frame 0 overrun 0 underrun 0 ignored
0 watchdog 0 bad etype drop 0 bad proto drop 0 if down drop
0 input with dribble 712 input discard
0 Rx pause
TX
1673907 unicast packets 575 multicast packets 7 broadcast packets
1674489 output packets 455539518 bytes
0 jumbo packets
0 output error 0 collision 0 deferred 0 late collision
0 lost carrier 0 no carrier 0 babble 0 output discard
0 Tx pause

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective for interfaces. See: Cisco ACI MIB Support List.

Module Status
Even though the leaves are considered fixed switches, they have a supervisor component which refers to the
CPU complex. From a forwarding perspective, there are two data plane components, viz. the NFE (Network
Forwarding Engine ASIC) which provide the front panel ports, and the ALE or ALE2 (Application Leaf
Engine ASIC) depending on the generation of switch hardware, which provides uplink connectivity to the
spines. The following methods can be used to determine the status of the modules in the switch.

GUI
To access module status for the NFE and the CPU complex, in the APIC GUI, navigate to Fabric > Inventory
> Pod-1 > Leaf-X > Chassis > Module > Supervisor modules and the status of the module is displayed in
the work pane.
To access module status for the ALE/ALE2, in the APIC GUI, navigate to Fabric > Inventory > Pod-1 >
Leaf-X > Chassis > Module > Line modules and the status of the module is displayed in the work pane.

REST API
The following REST API call(s) can be used to monitor the state of the supervisor and the module.

Operating Cisco Application Centric Infrastructure


195
Monitoring
Switch Fan Status

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/supslot-1/sup
https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/lcslot-1/lc

CLI
The show module command can be used to obtain the status of the base module and the uplink module.

Leaf-1# show module


Mod Ports Module-Type Model Status
--- ----- ----------------------------------- ------------------ ----------
1 48 1/10G Ethernet Module N9K-C9396PX active
GEM 12 40G Ethernet Expansion Module N9K-M12PQ ok
Mod Sw Hw
--- -------------- ------
1 11.1(0.152) 0.2050
Mod MAC-Address(es) Serial-Num
--- -------------------------------------- ----------
1 7c-69-f6-0f-87-71 to 7c-69-f6-0f-87-ad SAL17267Z9U
Mod Online Diag Status
--- ------------------
1 pass

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective for interfaces. See: Cisco ACI MIB Support List.

Switch Fan Status


The following section describes methodologies to retrieve the status of the fan trays on the leaf switches.

GUI
To access fan status for the leaf switch, in the APIC GUI, navigate to Fabric > Inventory > Pod-1 > Leaf-X
> Chassis > Fan Tray and the status of the modules is displayed in the work pane.

REST API
The following REST API call(s) and their child objects can be used to monitor the state of the fans on a leaf
switch (note that there are 3 slots on this particular switch).

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/ftslot-1
https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/ftslot-2
https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/ftslot-3

CLI
The following CLI command can be used to monitor the state of the fans on a leaf switch.

Leaf-1# show environment fan


Fan:
------------------------------------------------------
Fan Model Hw Status
------------------------------------------------------

Operating Cisco Application Centric Infrastructure


196
Monitoring
Switch Power Supply Status

Fan1(sys_fan1) N9K-C9300-FAN1-B -- ok
Fan2(sys_fan2) N9K-C9300-FAN1-B -- ok
Fan3(sys_fan3) N9K-C9300-FAN1-B -- ok
Fan_in_PS1 -- -- unknown
Fan_in_PS2 -- -- ok
Fan Speed: Zone 1: 0x5f
Fan Air Filter : Absent

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective for fans. See: Cisco ACI MIB Support List.

Switch Power Supply Status


The following sections describe methodologies to retrieve the status of the power supplies on the leaf switches.

GUI
To access power supply status for the leaf switch, in the APIC GUI, navigate to Fabric > Inventory > Pod-1
> Leaf-X > Chassis > Power Supply Units and the status of the modules is displayed in the work pane.

REST API
The following REST API call(s) and their child objects can be used to monitor the state of the fans on a leaf
switch (note that there are 3 slots on this particular switch).

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/psuslot-1
https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/ch/psuslot-2

CLI
The following CLI commands can be used to monitor the state of the fans on a leaf switch:

Leaf-1# show environment power


Power Supply:
Voltage: 12.0 Volts
Power Actual Total
Supply Model Output Capacity Status
(Watts ) (Watts )
------- ------------------- ----------- ----------- --------------
1 UCSC-PSU-650W 0 W 648 W shut
2 UCSC-PSU-650W 168 W 648 W ok
Actual Power
Module Model Draw Allocated Status
(Watts ) (Watts )
-------- ------------------- ----------- ----------- --------------
1 N9K-C9396PX 168 W 456 W Powered-Up
fan1 N9K-C9300-FAN1-B N/A N/A Powered-Up
fan2 N9K-C9300-FAN1-B N/A N/A Powered-Up
fan3 N9K-C9300-FAN1-B N/A N/A Powered-Up
N/A - Per module power not available
Power Usage Summary:
--------------------
Power Supply redundancy mode (configured) Non-Redundant(combined)
Power Supply redundancy mode (operational) Non-Redundant(combined)
Total Power Capacity (based on configured mode) 648 W

Operating Cisco Application Centric Infrastructure


197
Monitoring
LLDP Neighbor Status

Total Power of all Inputs (cumulative) 648 W


Total Power Output (actual draw) 168 W
Total Power Allocated (budget) N/A
Total Power Available for additional modules N/A

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective for power supplies. See: Cisco ACI MIB Support List.

LLDP Neighbor Status


The APIC provides a single pane of glass to query and determine all LLDP neighbors in a fabric.

GUI
To obtain a list of LLDP neighbors on an interface, navigate to Fabric > Inventory > Pod-1 > Leaf-X >
Protocols > LLDP > Neighbors > eth x/y.
A full listing of all LLDP neighbors on the interface can be obtained in the work pane.

REST API
The following rest API call can be used to obtain the same information:

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/lldp/inst/if-[eth1/1]

CLI

Leaf-1# show lldp neighbors


Capability codes:
(R) Router, (B) Bridge, (T) Telephone, (C) DOCSIS Cable Device
(W) WLAN Access Point, (P) Repeater, (S) Station, (O) Other
Device ID Local Intf Hold-time Capability Port ID
apic2 Eth1/1 120 4c:4e:35:09:77:2f
apic3 Eth1/4 120 90:e2:ba:4b:fa:d4
5548-2 Eth1/7 120 B Eth1/3
Spine-1 Eth1/49 120 BR Eth4/1
Spine-2 Eth1/50 120 BR Eth4/1
Spine-3 Eth1/51 120 BR Eth1/3
Spine-4 Eth1/52 120 BR Eth1/3
Spine-5 Eth1/53 120 BR Eth1/5
Spine-6 Eth1/54 120 BR Eth1/5
Total entries displayed: 9

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective for LLDP. See: Cisco ACI MIB Support List.

CDP Neighbor Status


The APIC provides a single pane of glass to query and determine all CDP neighbors in a fabric.

Operating Cisco Application Centric Infrastructure


198
Monitoring
GOLD Diagnostic Results

GUI
To obtain a list of LLDP neighbors on an interface, navigate to Fabric > Inventory > Pod-1 > Leaf-X >
Protocols > CDP > Neighbors > eth x/y.
A full listing of all CDP neighbors on the interface can be obtained in the work pane.
In the above workflow clicking on Neighbors (instead of eth x/y) gives you a list of all LLDP neighbors on
the switch.

REST API
The following rest API call can be used to obtain the same information:

https://{{apic-ip}}/api/node/mo/topology/pod-1/node-101/sys/cdp/inst/if-[eth1/1]

CLI

Leaf-1# show cdp neighbors


Capability Codes: R - Router, T - Trans-Bridge, B - Source-Route-Bridge
S - Switch, H - Host, I - IGMP, r - Repeater,
V - VoIP-Phone, D - Remotely-Managed-Device,
s - Supports-STP-Dispute
Device-ID Local Intrfce Hldtme Capability Platform Port ID
Services-UCS-A(SSI15450J63)
Eth1/5 129 S I s UCS-FI-6248UP Eth1/17
5548-2(SSI154300VL)
Eth1/7 123 S I s N5K-C5548UP Eth1/3

SNMP
As mentioned in the URL for the SNMP reference guide for ACI release 1.x, the following SNMP objects
are supported from an SNMP polling perspective for CDP. See: Cisco ACI MIB Support List.

GOLD Diagnostic Results


GOLD is covered in greater detail in the Hardware Replacement section.
GOLD diagnostics provide an easy and quick way for operations teams to confirm that bootup and
non-disruptive tests that run during normal operations have executed properly, as well as the ability to run on
demand diagnostics to isolate potential hardware at fault.

GUI
To view GOLD Diagnostic test results in the GUI for the Supervisors, click on Fabric > Inventory > Pod-1
> Leaf-1 > Chassis > Supervisor Modules > Slot-1. Then click troubleshooting in the work pane.
To view the same for modules, click on Fabric > Inventory > Pod-1 > Leaf-1 > Chassis > Line Modules
> Slot-x. Then click Troubleshooting in the work pane.

CLI

Leaf-1# show diagnostic result module all


Current bootup diagnostic level: bypass

Operating Cisco Application Centric Infrastructure


199
Monitoring
Proactive Monitoring Use Cases

Module 1: 1/10G Ethernet Module (Active)


Test results: (. = Pass, F = Fail, I = Incomplete,
U = Untested, A = Abort, E = Error disabled)
1) bios-mem-----------------------> .
2) mgmtp-lb-----------------------> .
4) nsa-mem------------------------> .
6) fabp-prbs:
Port 1 2 3 4 5 6 7 8 9 10 11 12
-----------------------------------------
. . . . . . . . . . . .
22) cpu-cache----------------------> .
23) mem-health---------------------> .
24) ssd-acc------------------------> .
25) act2-acc-----------------------> .
26) ge-eeprom----------------------> .
29) usb-bus------------------------> .
30) cons-dev-----------------------> .
31) obfl-acc-----------------------> .
32) nvram-cksum--------------------> .
33) fpga-reg-chk-------------------> .
34) asic-scratch-------------------> .
40) rtc-test-----------------------> .
41) pcie-bus-----------------------> .

Proactive Monitoring Use Cases


Monitoring Workload Bandwidth
ACME would like to proactively monitor connections to servers to determine whether adequate bandwidth
is available to a given workload. This enables them to answer questions about whether a server needs to be
upgraded from 10G to 40G, or multiple interfaces need to be bonded to provide more bandwidth to the server.
The following will provide an example of how statistics policies and thresholds can be used to alert the
operators when additional bandwidth is required to a server.
ACME's server team has determined that they would like to monitor link utilization over a 5 minute period,
and when the average utilization is above 80%, they would like to raise a fault for the affected interface. To
accomplish these tasks requires configuring a monitoring policy with two distinct types of policies. First,
ACME will configure a stats collection policy to collect the average utilization of a link over the desired 5
minute interval. Next they will configure a threshold policy to generate a fault when the link utilization exceeds
various thresholds according to the following table.
Create an interface monitoring policy.
We have now created a policy which will monitor associated interfaces and ingress traffic rate at 5 minute
intervals. Next we will configure a threshold which will alert us if the utilization exceeds 80% and assign an
default fault severity to it.
Note: In this example, we are interested in an absolute percentage, these policies can be further customized
to provide a normal value, and look for deviations above or below that normal value.
In this scenario, 80% utilization does not necessarily mean that the application performance is degraded, so
we will flag this as a warning. Additional levels/severities can also be specified if desired.
The set column specifies the level at which the fault will be raised, and the reset column will specify the the
level at which the fault will be cleared. For example, we will be raising a warning when the utilization goes

Operating Cisco Application Centric Infrastructure


200
Monitoring
EPG Level Statistics

above 80, and clear the warning when the utilization falls below 75. Repeat these steps for the egress statistics
as well.
Finally, we will associate the newly created policy with an interface policy group that represents the interfaces
we to monitor with this policy.
For our example, we will apply the policy to the UCS-10G-PG

EPG Level Statistics


The application owner would like to be able to monitor network-related information for their application, such
as the aggregate amount of traffic to a specific tier. As an example, we will monitor the amount of traffic to
the web tier of a given application. In this example, the default monitoring policies are appropriate, and they
are simply extracting them from the system to be consumed externally. This information is useful in scenarios
such as a new release being pushed, and to make sure that no traffic anomalies are created after the push.

REST API
Additionally, this information can be gathered from the API:

http[s]://apic_ip/api/node/mo/uni/tn-mynewproject/ap-app1/epg-web-epg.xml?querytarget=
self&rsp-subtree-include=stats

Reactive Monitoring
It is crucial that the ACME operational staff are able to react to any indication of something going wrong. If
there is a notification that something has gone wrong, such as a fault notification, a low health score, or a
ticket/report that end-user functionality has been impacted, knowledge of the available monitoring tools is
important for the identification and collection of evidence. This is especially true the box by box approach to
troubleshooting gets replaced by system-wide approach. It is vital to understand the tools that are available
to assist you with your troubleshooting efforts, which take a top/down approach and effectively zoom in to
the problem. You can then use this evidence to identify and analyze the root cause of the problem before
taking corrective action. For more information regarding faults and health scores please refer to those specific
sections within this book.
A deep dive into the processes of troubleshooting is out of the scope of this book. Please refer to
Troubleshooting Cisco Application Centric Infrastructure, "Analytical problem solving applied to the policy
driven data center" available at: http://aci-troubleshooting-book.readthedocs.org/en/latest/

Tenant—Troubleshoot Policies
Within the Application Policy Infrastructure Controller (APIC) GUI, under each tenant you can find a
Troubleshoot Policy section. This section allows configuration of policies that are specific to one tenant, and
the monitoring of traffic and test connectivity between endpoints.
As seen in the image above, the following troubleshooting policies can be configured:
• SPAN (Switched Port ANalyzer)—Configuration of SPAN and ERSPAN sources and destinations to
be used in external monitoring of Tenant traffic flows.
• Endpoint-To-Endpoint Traceroute—Configuration of a path validation tool for verifying validity of
communications between Tenant endpoints in an Cisco Application Centric Infrastructure (ACI) fabric.

Operating Cisco Application Centric Infrastructure


201
Monitoring
Operations Tab

• Endpoint-To-External-IP Traceroute—Configuration of a path validation tool for verifying validity of


communications between a tenant endpoint and an external device outside of the ACI fabric.
• Atomic Counters—Configuration of a set of customizable counters to collect and report on information
between a definable set of objects. A policy can be configured to collect statistics between endpoints,
between endpoint groups, between endpoint groups and specific IPs and other special objects, such as
Any or External traffic flows.

Fabric—Troubleshoot Policies
For troubleshooting within the entire fabric, there are the following tools and policies:
• SPAN (Switched Port Analyzer)—Configuration of SPAN and ERSPAN sources and destinations to be
used in external monitoring of fabric traffic flows.
• On-demand Diagnostics—Configuration of a policy for collection of diagnostic information that can be
executed at a point in time and which will return a set of valuable output for investigation.
• Leaf Nodes Traceroute—Configuration of a path validation tool for verifying validity of communications
between ACI fabric nodes. The traceroute for a leaf node allows you to determine the path a packet takes
to get to a destination from a given source by returning the sequence of hops the packet traversed.
• Traffic Map—As of release 1.2, this tool has been moved to the Operations tab and is renamed
Visualization. It still provides an at-a-glance hotspot map of node-to-node traffic flow in an ACI fabric.

Other Tools
• iPing—A troubleshooting tool in the ACI fabric that can be used to verify reachability of a device
connected to the fabric utilizing the fabric as the pervasive source.
• Audit Logs—Audit logs are continually collected on all actions taken in an ACI fabric and can give a
quick indication of which user took which actions at what time.

Reactive Monitoring Use Cases


At the end of this chapter, we are going to describe two situations where ACME ran into issues and how they
made use of the tools previously described.
1. No access to application: An end-user calls and reports that they can no longer access a web application
running within the fabric.
2. Users report that an application running in the fabric is slow or there is a report of slowness to the web
application running within the fabric.

Operations Tab
The Operations tab provides a single location that includes several commonly used tools and outputs required
for troubleshooting endpoint connectivity. The Operations tab contains the following subtabs:
• Enhanced Troubleshooting Wizard (Visibility & Troubleshooting) tab—Quickly identifies connectivity
issues when troubleshooting connectivity between endpoints within the fabric. The Enhanced
Troubleshooting Wizard provides a single location that includes several commonly used tools and
outputs required for troubleshooting end point connectivity.
• Capacity Dashboard tab—Gets a summary of critical fabric resource thresholds.

Operating Cisco Application Centric Infrastructure


202
Monitoring
Visibility and Troubleshooting—Enhanced Troubleshooting Wizard

• ACI Optimizer tab—Enables you to enter your network requirements to determine how many leafs you
will need for your network, and to learn how to deploy each application and external endpoint group on
each leaf without violating any constraints.
• EP Tracker tab—Allows you to enter an endpoint IP or MAC address, and quickly see the location of
this endpoint, the endpoint group that it belongs to, the VLAN encapsulation used, and if any transitions
(flaps) have occurred for this endpoint.
• Visualization tab—Allows you to view traffic statistics for a set of spine and leaf switches.

Visibility and Troubleshooting—Enhanced Troubleshooting Wizard


The Enhanced Troubleshooting Wizard provides a visual view of the connectivity between two endpoints. In
releases prior to 1.2(1x), the endpoints must reside in the same VRF and tenant space. Starting in the 1.2(1x)
release, the endpoints must be in the same tenant, but the bridge domain and VRF can be in the Common
tenant.
Other scenarios such as inter-tenant can also be viewed, but many of the tools that comprise the Enhanced
Troubleshooting Wizard will not work, such as atomic counters and traceroute, due to hardware-based topology
restrictions on those features. This is unrelated to the Enhanced Troubleshooting Wizard tool itself.
1. In the menu bar, choose Operations > Visibility and Troubleshooting to launch the enhanced
troubleshooting wizard.
2. In the Name field, enter a name for the new session or choose an existing session.
3. In the Source field, enter the MAC or IP address for the source endpoint and click Search.
4. (Optional) If the endpoint is external, put a check in the check box.
5. Click on the endpoint once it is displayed.
6. In the Destination field, enter the MAC or IP address for the destination endpoint and click Search.
7. (Optional) If the endpoint is external, put a check in the check box.
8. Click on the endpoint once it is displayed.
9. Click Start.
10. Choose the Drop/Stats tab to view the next screen. You can choose the other tabs to view additional
information about these endpoints. You can enter various endpoint topologies, but not all of the available
tools that are contained in the Enhanced Troubleshooting Wizard will work.

Capacity Dashboard
The Capacity Dashboard tab can be used to get a summary of critical fabric resource thresholds. This allows
you to see quickly how close you are to reaching the approved scalability limits. Per leaf usage is also shown,
allowing you to see quickly which leaf may be hitting resource constraints.
1. In the menu bar, choose Operations > Capacity Dashboard to launch the Capacity Dashboard
troubleshooting tool.

Note Disabling the 5-minute interval on the fabric default monitoring policy causes less information to appear on
the Capacity Dashboard.

Operating Cisco Application Centric Infrastructure


203
Monitoring
Endpoint Tracker

Endpoint Tracker
The Endpoint Tracker tab allows you to enter a fabric-attached endpoint IP or MAC address and quickly
see the location of this endpoint, the endpoint group it belongs to, the VLAN encapsulation used, and if any
transitions (flaps) have occurred for this endpoint.
1. In the menu bar, click Operations > EP Tracker to launch the Endpoint Tracker troubleshooting tool
2. In the End Point Search field, enter the IP address or MAC address of the endpoint and click Search.
3. Click on the endpoint once it is displayed.

The Endpoint Tracker tool displays the date and time of each state transition along with the IP address, MAC
address, owning endpoint group, action (attached or detached), physical node, Interface, and VLAN
encapsulation during the event.

Reactive Monitoring Tools


Switch Port Analyzer (SPAN)
SPAN is generally used in two ways:
• Proactively as part of a third party or offline analysis requirement.
• Security tools (IDS/IPS, Data Loss Prevention)
• Call Recording
• Troubleshooting application and networking issues within the fabric.
It may be helpful to perform a capture of some particular traffic to see what is going on within the stream of
data. Looking through traffic flows will allow investigation of packet and protocol level details, such as traffic
resets, misbehaving protocols, improper host requests or responses, or node level communications. This will
provide deeper insight into how devices are using the network than simple traffic flow and fabric configuration
review.
Switched Port ANalyzer, or SPAN, is a standard feature that allows copy and replication of traffic to a network
analyzer for further decoding and investigation. It can be used to copy traffic from one or more ports, VLANs,
or endpoint groups (EPGs).
The SPAN feature process is non-disruptive to any connected devices and is facilitated in hardware, which
prevents any unnecessary CPU load.
SPAN sessions can be configured to monitor traffic received by the source (ingress traffic), traffic transmitted
from the source (egress traffic), or both. By default, SPAN monitors all traffic, but filters can be configured
to monitor only selected traffic.

Multinode SPAN
APIC traffic monitoring policies can enforce SPAN at the appropriate places to copy traffic from members
of each End Point Group wherever they are connected. If a member moves, APIC automatically pushes the
policy to the new leaf switch. For example, when a VMotion event relocates an Endpoint to a new leaf switch,
the SPAN feature configuration automatically adjusts.

Operating Cisco Application Centric Infrastructure


204
Monitoring
Configuring a SPAN Session

SPAN Guidelines and Restrictions


• Use SPAN for troubleshooting. SPAN traffic competes with user traffic for switch resources. To minimize
the load, configure SPAN to copy only the specific traffic that you want to analyze.
• An l3extLIfP Layer 3 subinterface cannot be configured as a SPAN source. The entire port must be used
for monitoring traffic from external sources.
• Tenant and access SPAN use the encapsulated remote extension of SPAN (ERSPAN) type I, while fabric
SPAN uses ERSPAN type II. For information regarding ERSPAN headers, refer to the IETF Internet
Draft at this URL: https://tools.ietf.org/html/draft-foschiano-erspan-00
• See the Verified Scalability Guide for Cisco ACI document for SPAN-related limits, such as the maximum
number of active SPAN sessions.

Configuring a SPAN Session


This procedure shows how to configure a SPAN policy to forward replicated source packets to a remote traffic
analyzer.
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Policies > Troubleshoot > SPAN > SPAN Destination
Groups.
4. In the Work pane, choose Actions > Create SPAN Destination Group.
5. In the Create SPAN Destination Group dialog box, perform the following actions:
1. In the Name field, enter a name for the SPAN destination group.
2. In the Destination EPG dropdowns, select the destination Tenant, Application Profile, and EPG.
3. Enter the Destination IP.
4. Enter the Source IP Prefix.
5. Optionally, modify the other fields as needed.
6. Click OK.
7. If needed, add additional destinations.
8. Click Submit.

6. Under SPAN, right-click SPAN Source Groups and choose Create SPAN Source Group.
7. In the Create SPAN Source Group dialog box, perform the following actions:
1. In the Name field, enter a name for the SPAN source group.
2. From the Destination Group drop-down list, choose the SPAN destination group that you configured
previously.
3. In the Create Sources table, click the + icon to open the Create Sources dialog box.
4. In the Name field, enter a name for the source.

Operating Cisco Application Centric Infrastructure


205
Monitoring
Traceroute

5. In the Direction field, choose the radio button based on whether you want to replicate and forward
packets that are incoming to the source, outgoing from the source, or both incoming and outgoing.
6. From the Source EPG drop-down list, choose the EPG (identified by Tenant/ApplicationProfile/EPG)
whose packets will be replicated and forwarded to the SPAN destination. Click OK to save the SPAN
source.
7. Click Submit to save the SPAN source group.

Traceroute
The traceroute tool is used to discover the routes that packets actually take when traveling to their destination.
Traceroute identifies the path taken on a hop-by-hop basis and includes a time stamp at each hop in both
directions. You can use traceroute to test the connectivity of ports along the path between the generating
device and the device closest to the destination. If the destination cannot be reached, the path discovery traces
the path up to the point of failure. Traceroute is a useful feature in traditional networking. In Cisco Application
Centric Infrastructure (ACI), this feature is implemented taking into account the way the fabric works.
Traceroute supports a variety of modes, including endpoint-to-endpoint, and leaf-to-leaf (tunnel endpoint, or
TEP to TEP). It discovers all paths across the fabric, discovers point of exits for external endpoints, and helps
to detect if any path is blocked.
A traceroute that is initiated from the tenant endpoints shows the default gateway as an intermediate hop that
appears at the ingress leaf switch.

Note If traceroute is done from the OS of a connected server or VM, it will show the hops for the leaves and spines
as unknown, and will keep recording the information after the packet gets out of the fabric. For more precise
information, use traceroute from the Application Policy Infrastructure Controller (APIC) (GUI or CLI).

Traceroute Guidelines and Restrictions


• When the traceroute source or destination is an endpoint, the endpoint must be dynamic and not static.
Unlike a dynamic endpoint (fv:CEp), a static endpoint (fv:StCEp) does not have a child object
(fv:RsCEpToPathEp) that is required for traceroute.
• See the Verified Scalability Guide for Cisco ACI document for traceroute-related limits.
• Traceroute results will display the IP address of the remote node and interface which it came it came in
on. In the APIC GUI, go to Fabric > Inventory > Fabric Management to view the IP address information
for correlation.
• Traceroute cannot be used for endpoints that reside in an external endpoint groups.

Performing a Traceroute Between Endpoints


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Policies > Troubleshoot > Endpoint-to-Endpoint
Traceroute Policies.
4. In the Work pane, choose Actions > Create Endpoint-to-Endpoint Traceroute Policy.

Operating Cisco Application Centric Infrastructure


206
Monitoring
Atomic Counters

5. In the Create Endpoint-to-Endpoint Traceroute Policy dialog box, perform the following actions:
1. In the Name field, enter a name for the traceroute policy.
2. In the Source End Points table, click the + icon to edit the traceroute source.
3. From the Source MAC drop-down list, choose or enter the MAC address of the source endpoint and
click Update.
4. In the Destination End Points table, click the + icon to edit the traceroute destination.
5. From the Destination MAC drop-down list, choose or enter the MAC address of the destination
endpoint and click Update.
6. In the State field, click the Start radio button.
7. Click Submit to launch the traceroute.

6. In the Navigation pane or the Traceroute Policies table, click the traceroute policy. The traceroute policy
is displayed in the Work pane.
7. In the Work pane, click the Operational tab, click the Source End Points tab, and click the Results tab.
8. In the Traceroute Results table, verify the path or paths that were used in the trace.
1. More than one path might have been traversed from the source node to the destination node.
2. For readability, increase the width of one or more columns, such as the Name column.

Atomic Counters
Atomic Counters are useful for troubleshooting connectivity between endpoints, EPGs, or an application
within the fabric. A user reporting application may be experiencing slowness, or atomic counters may be
needed for monitoring any traffic loss between two endpoints. One capability provided by atomic counters is
the ability to place a trouble ticket into a proactive monitoring mode, for example when the problem is
intermittent, and not necessarily happening at the time the operator is actively working the ticket.
Atomic counters can help detect packet loss in the fabric and allow the quick isolation of the source of
connectivity issues. Atomic counters require NTP to be enabled on the fabric.
Leaf-to-leaf (TEP to TEP) atomic counters can provide the following:
• Counts of drops, admits, and excess packets
• Short-term data collection such as the last 30 seconds, and long-term data collection such as 5 minutes,
15 minutes, or more
• A breakdown of per-spine traffic (available when the number of TEPs, leaf or VPC, is less than 64)
• Ongoing monitoring
Leaf-to-leaf (TEP to TEP) atomic counters are cumulative and cannot be cleared. However, because 30 second
atomic counters reset at 30 second intervals, they can be used to isolate intermittent or recurring problems.
Tenant atomic counters can provide the following:
• Application-specific counters for traffic across the fabric, including drops, admits, and excess packets
• Modes include the following:

Operating Cisco Application Centric Infrastructure


207
Monitoring
Configuring Atomic Counters

• Endpoint to endpoint MAC address, or endpoint to endpoint IP address. Note that a single target endpoint
could have multiple IP addresses associated with it.
• EPG to EPG with optional drill down
• EPG to endpoint
• EPG to * (any)
• Endpoint to external IP address

Note Atomic counters track the amount packets of between the two endpoints and use this as a measurement. They
do not take into account drops or error counters in a hardware level.

Dropped packets are calculated when there are less packets received by the destination than transmitted by
the source.
Excess packets are calculated when there are more packets received by the destination than transmitted by
the source.

Configuring Atomic Counters


1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Troubleshooting Policies > Atomic Counter Policy.
4. Choose a policy (traffic topology). Traffic can be measured between a combination of endpoints, endpoint
groups, external interfaces, and IP addresses.
5. In the Work pane, choose Actions > Add Policy_Name Policy.
6. In the Add Policy dialog box, perform the following actions:
1. In the Name field, enter a name for the policy.
2. Choose or enter the identifying information for the traffic source. The required identifying information
differs depending on the type of source (endpoint, endpoint group, external interface, or IP address).
3. Choose or enter the identifying information for the traffic destination.
4. (Optional) In the Filters table, click + to specify filtering of the traffic to be counted. In the resulting
Create Atomic Counter Filter dialog box, specify filtering by the IP protocol number (TCP=6, for
example) and by source and destination IP port numbers.
5. Click Submit to save the atomic counter policy.

7. In the Navigation pane, under the selected topology, choose the new atomic counter policy. The policy
configuration is displayed in the Work pane.
8. In the Work pane, choose the Operational tab and choose the Traffic subtab to view the atomic counter
statistics.

Operating Cisco Application Centric Infrastructure


208
Monitoring
Traffic Map

Traffic Map

Note In the 1.2 release, this was moved to the Operations tab and renamed "Visualization".

Low performance and congestion can be identified by use of Traffic maps.


Traffic maps make use of atomic counters to continuously monitor and display traffic between leaf switches
to help with quick debugging and isolation of application connectivity issues.

Configuring Traffic Map


1. On the menu bar, choose Fabric > Fabric Policies.
2. In the Navigation pane, choose Troubleshooting Policies > Traffic Map.
3. Set the drop-down menu options to view the source Leaf to destination Leaf traffic paths.
• Last interval and cumulative
• Sent, received, dropped and excess
• All spines and a specific spine switch

The percentage is shown in relative terms to all traffic by Source or received by Destination.
4. Clicking on a cell opens a table with all data for all trails and links.

IPing
IPing is used to test and validate connectivity within the from leaf node to endpoints within the fabric, taking
into account the private network. IPing is a troubleshooting tool for network users similar to the PING
command.

Using IPing
iping [ -V vrf ] [ -c count ] [ -i wait ] [ -p pattern ] [ -s packetsize ] [ -t timeout ] host

Examples
pod1-leaf1# iping -V overlay-1 10.0.59.154
PING 10.0.59.154 (10.0.59.154): 56 data bytes
64 bytes from 10.0.59.154: icmp_seq=0 ttl=55 time=0.254 ms
64 bytes from 10.0.59.154: icmp_seq=1 ttl=55 time=0.256 ms
64 bytes from 10.0.59.154: icmp_seq=2 ttl=55 time=0.245 ms
64 bytes from 10.0.59.154: icmp_seq=3 ttl=55 time=0.241 ms
64 bytes from 10.0.59.154: icmp_seq=4 ttl=55 time=0.23 ms
--- 10.0.59.154 ping statistics ---
5 packets transmitted, 5 packets received, 0.00% packet loss
round-trip min/avg/max = 0.23/0.245/0.256 ms

Operating Cisco Application Centric Infrastructure


209
Monitoring
Audit Logs

Audit Logs
At times it may be required to view changes which have taken place in the fabric. An outage reported on a
host or application in the fabric may need to be tracked, or data pulled for an audit requirement.
Audit logs are records of who made a change, when the change was made, and a description of the action.
Audit logs also record when users logon and logoff.
Audit logs can be found in several places within the GUI, filtered to show only those events relevant to the
current GUI context. Wherever a History tab appears in the GUI Work pane, the audit log can be viewed.
This procedure shows how to view tenant events as an example.

Viewing Audit Logs


This procedure shows how to view an audit log on a tenant.
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose Common.
3. In the Navigation pane, choose Common.
4. In the Work pane, choose the History tab.
5. Under the History tab, choose the Events subtab to view the event log.
6. Under the History tab, choose the Audit Log subtab to view the audit log.
7. Double-click a log entry to view additional details about the event.

Reactive Monitoring Use Cases


This chapter shows some examples of how ACME's operations teams can use their Cisco Application Centric
Infrastructure (ACI) monitoring tools to react to a few common possible scenarios.

Note These examples assume that basic low-level investigation has been done and the issue has been isolated to
an issue with traffic flows across the fabric. Cables and connectivity have been verified, hosts are up, virtual
machines are running, processes are running, memory and CPU utilization has been checked, and so on.

A great way to begin in any use case is to use the Visibility and Troubleshooting Tool (Enhanced
Troubleshooting Wizard), which is a built-in capability of the Application Policy Infrastructure Controller
(APIC).

Loss of Connectivity to Endpoint


The ACME application owner has reported that two servers have lost connectivity. These two endpoints (EPs)
belong to two different endpoint groups (EPGs), within the same subnet, bridge domain and Tenant, and each
endpoint is connected to different leaf switches. The bridge domain has unicast routing enabled, therefore the
default gateway for both endpoints exist on the Cisco Application Centric Infrastructure (ACI) leaf switches.
The following steps troubleshoot this situation:

Operating Cisco Application Centric Infrastructure


210
Monitoring
Loss of Connectivity to Endpoint

1. Check that the endpoints have been learned by the leaf switches.
2. Verify that the required contracts are in place between the endpoints.

Checking that the Endpoints Have Been Learned by the Leaf Switches
You can use the Application Policy Infrastructure Controller (APIC) GUI to check that the endpoints have
been learned by the leaf switches.
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Application Profiles > App_Profile_Name > Application
EPGs > EPG_Name.
4. In the Work pane, choose the Operational > Client End-Points tabs.
5. Verify that the endpoint is present
6. Repeat steps 1 to 5 for the destination endpoint group.

Alternately, you can use the End Point Tracker tool to check that the endpoints have been learned by the leaf
switches.
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Application Profiles > App_Profile_Name > Application
EPGs > EPG_Name.
4. In the Work pane, choose the Operational > EP Tracker tabs.
5. Verify the location of the relevant endpoints and view the history for those endpoints.

Verifying that the Required Contracts are in Place Between the Endpoints
You can use the Application Policy Infrastructure Controller (APIC) GUI to verify that the required contracts
are in place between the endpoints.
1. On the menu bar, choose Tenants > ALL TENANTS.
2. In the Work pane, choose the tenant.
3. In the Navigation pane, choose Tenant_Name > Application Profiles > App_Profile_Name > Application
EPGs > EPG_Name.
4. In the Work pane, choose the Operational > Contracts tabs.
5. Check for a relationship between the source endpoint group and destination endpoint group, noting the
type because it states the direction, such as provider/consumer. Additionally, the type states the contract
subject that is in use.
6. Check the egress/ingress cumulative packets for each subject and relevant filters.
7. Inspect the contents of each filter by examining the contract under the Security Policies folder and
verifying that each filter contains the appropriate filter entries.
8. If the endpoints are discovered within each endpoint group and the contract relationships look correct,
examine the troubleshooting policies.

The following alternate techniques are available to validate communications between endpoints within the
ACI fabric:
• Use the Visibility and Troubleshooting Tool.

Operating Cisco Application Centric Infrastructure


211
Monitoring
Users Report that an Application Running in the Fabric is Slow

• Use endpoint-to-endpoint traceroute to show if there are paths available between those endpoints.
• Inside the fabric, use the iPing tool to verify connectivity between the default gateway and the endpoints,
from the CLI. Each leaf has an SVI used as the default gateway (assuming this is the configuration with
a subnet defined at the bridge domain/endpoint group level). If this test is successful, the connectivity
between endpoints and leaf switches is not the problem. To check the connectivity to the remote end,
use iPing from each leaf to the remote endpoint, using the default gateway as the source.
If you still cannot locate the issue, you can use SPAN to verify where the traffic is entering and leaving the
fabric, and make sure that the frames have the correct format.

Users Report that an Application Running in the Fabric is Slow


ACME test users report slow response of the web servers running in the fabric. This performance issue could
be caused due to latency, packet drops, or intermittent connectivity loss. In this case, the end-user is trying to
access the web portal from a test virtual machine. The virtual machine and the web portal belong to a different
EPGs in the same bridge domain and tenant.
First the operations staff should make sure endpoints are learned by the leaf switches in a consistent way so
that the EPs are visible in the operational tab under the Tenant > Application Profile > EPGs > Operational.
Once they verify endpoints have been learned, they can use EP-to-EP Traceroute to show the path validity.
Atomic counters can also be deployed to check if there are any drops or irregularities between the defined
devices. Looking through the Operations > Visualization tool can also show an at-a-glance view in the
fabric and highlight any possible hotspots or congestion in certain elements of the fabric. Check specific
counters for CRC errors on the interfaces used to transmit EP specific traffic.
If everything in the fabric looks fine, SPAN may be used to verify where the traffic is entering and leaving
the fabric and make sure frames have the right format. Corrupted frames could cause drops in different points,
from the EPs on a OS level to the switches.

Operating Cisco Application Centric Infrastructure


212
CHAPTER 10
Scripting
• Leveraging Network Programmability, on page 213
• ACI and Scripting, on page 214
• API Inspector, on page 218
• Development Techniques, on page 219
• POSTman, on page 220
• Cobra SDK and Arya, on page 222
• ACI Toolkit, on page 226
• GitHub, on page 230

Leveraging Network Programmability


The industrial revolution modernized the techniques used to manufacture goods, going from hand production
methods to mechanized manufacturing. This movement from manual to automated operations changed human
productivity, allowing people to free themselves from repetitive tasks that could be more easily accomplished
by a machine. The associated decrease in costs, increase in speed and increased quality allowed for more work
to be done for less money in less time, yielding a higher quality product. Programmability promises to offer
the same outcome for networks as the industrial revolution did for goods.
The inevitable move toward automation in the IT industry has provided people and businesses a faster way
to achieve their desired goals, a more cost-effective way to rapidly provision infrastructure in a timely fashion
according to demand, and yielded more consistency in the configured results. ACI is able to take advantage
of all of these benefits by completely exposing all of the native functionality in programmable ways, using
common tools and languages to provide network engineers, developers and even novices an approachable
path toward automation. Though ACME is just getting started with true DevOps in their IT organization, they
realize that these benefits will allow them to keep up with the pace of business.
Given the comprehensiveness of the programmability features available on ACI, everyone can benefit. ACME's
network engineering and design teams can benefit from the quick time to provision large configurations, and
the consistency provided by the ability to automate all of the moving parts. Their operations teams can utilize
the plethora of information contained within the APIC to streamline their processes, gather better metrics and
correlate events more accurately, yielding faster time to resolution and higher customer satisfaction.

Operating Cisco Application Centric Infrastructure


213
Scripting
ACI and Scripting

ACI and Scripting


The goals for network programmability are clear, however the methods by which these goals may be realized
have been more difficult to grasp. Traditional networking devices provide output that is meant for visual
consumption by people, and configurations are driven using text input that is simpler for a person to type,
however these goals stand in contrast to an automation-driven approach. Machines are able to more easily
process data that is provided in some structured form. Structured data that may not be visually appealing can
be rapidly parsed, and also can easily represent the full detail that a comprehensive object-oriented configuration
model may represent.
ACI uses an advanced object model that represents network configuration with application-based semantics
which can be consumed and posted against using a well documented REST API. In addition to providing this
interface into the object model, ACI also provides a number of access methods to read and manipulate this
data, at a variety of levels that will cater to the level of comfort the user has with programming, all of which
use open standards and open source.

Reference to Object Model


Figure 53: Representation of the top levels of the Object Model

While a comprehensive overview of the Object Model is outside of this book, from a programmability
perspective it is important to note that every aspect of ACI functionality is encompassed within the object
model. This means that all of the configuration that can be made on the fabric, can be made programmatically
using the REST API. This includes internal fabric networking, external networking, virtualization integration,
compute integration, and all other facets of the product.
This data is stored within the Management Information Tree, with every piece of the model represented as a
programmatic object with properties, identity, and consistency rules that are enforced. This ensures that the
configured state of the model will never get out of hand with stale nodes or entries, and every aspect can be
inspected, manipulated, and made to cater for the user's needs.

Programmatic Interfaces
APIC is very flexible in terms of how it can accept configuration and provide administrative and operable
states, as well as extending that configuration into subordinate components. There are two primary categories
of interfaces that facilitate these functions: the northbound REST API and the southbound programmatic
interfaces.
The northbound REST API is responsible for accepting configuration, as well as providing access to
management functions for the controller. This interface is a crucial component for the GUI and CLI, and also

Operating Cisco Application Centric Infrastructure


214
Scripting
About the REST API

provides a touch point for automation tools, provisioning scripts and third party monitoring and management
tools. The REST API is a singular entry point to the fabric for making configuration changes, and as such is
a critical aspect of the architecture for being able to provide a consistent programmatic experience.
Southbound interfaces on APIC allow for the declarative model of intent to be extended beyond the fabric,
into subordinate devices. This is a key aspect to the openness of the ACI fabric, in that policy can be
programmed once via APIC and then pushed out to hypervisors, L4-7 devices and potentially more in the
future, without the need to individually configure those devices. This southbound extension is realized through
two methods: L4-7 Device Packages and OpFlex.
The L4-7 device package interface allows for ACI to apply policy to existing L4-7 devices that do not have
an implicit knowledge of ACI policy. These devices can be from any vendor, so long as the device has some
form of interface which is accessible via IP. The actual implementation of device packages is done via Python
scripts which run on the APIC within a contained execution environment, which can reach the device through
their native configuration interfaces, be that REST, CLI, SOAP or others. As a user makes changes to service
graphs or EPG policy, the device package will translate the APIC policy into API calls on the L4-7 device.
OpFlex is designed to allow a data exchange of a set of managed objects that is defined as part of an
informational model. OpFlex itself does not dictate the information model, and can be used with any tree-based
abstract model in which each node in the tree has a universal resource identifier (URI) associated with it. The
protocol is designed to support XML and JSON (as well as the binary encoding used in some scenarios) and
to use standard remote procedure call (RPC) mechanisms such as JSON-RPC over TCP. In ACI, OpFlex is
currently used to extend policy to the Application Virtual Switch as well as extend Group Based Policy into
OpenStack.

About the REST API


The Application Policy Infrastructure Controller (APIC) REST API is a programmatic interface that uses
REST architecture. The API accepts and returns HTTP (not enabled by default) or HTTPS messages that
contain JavaScript Object Notation (JSON) or Extensible Markup Language (XML) documents. You can use
any programming language to generate the messages and the JSON or XML documents that contain the API
methods or MO descriptions.
The REST API is the interface into the MIT and allows manipulation of the object model state. The same
REST interface is used by the APIC command-line interface (CLI), GUI, and SDK, so that whenever
information is displayed, it is read through the REST API, and when configuration changes are made, they
are written through the REST API. The REST API also provides an interface through which other information
can be retrieved, including statistics, faults, and audit events, and it even provides a means of subscribing to
push-based event notification, so that when a change occurs in the MIT, an event can be sent through a web
socket.
Standard REST methods are supported on the API, which includes POST, GET, and DELETE operations
through HTTP. The POST and DELETE methods are idempotent, meaning that there is no additional effect
if they are called more than once with the same input parameters. The GET method is nullipotent, meaning
that it can be called zero or more times without making any changes (or that it is a read-only operation).
Payloads to and from the REST interface can be encapsulated through either XML or JSON encoding. In the
case of XML, the encoding operation is simple: the element tag is the name of the package and class, and any
properties of that object are specified as attributes of that element. Containment is defined by creating child
elements.
For JSON, encoding requires definition of certain entities to reflect the tree-based hierarchy; however, the
definition is repeated at all levels of the tree, so it is fairly simple to implement after it is initially understood.

Operating Cisco Application Centric Infrastructure


215
Scripting
About the REST API

• All objects are described as JSON dictionaries, in which the key is the name of the package and class,
and the value is another nested dictionary with two keys: attribute and children.
• The attribute key contains a further nested dictionary describing key-value pairs that define attributes on
the object.
• The children key contains a list that defines all the child objects. The children in this list are dictionaries
containing any nested objects, which are defined as described here.

Read Operations
After the object payloads are properly encoded as XML or JSON, they can be used in create, read, update, or
delete operations on the REST API. The following diagram shows the syntax for a read operation from the
REST API.
Figure 54: REST syntax

Because the REST API is HTTP based, defining the universal resource identifier (URI) to access a certain
resource type is important. The first two sections of the request URI simply define the protocol and access
details of the APIC. Next in the request URI is the literal string /api, indicating that the API will be invoked.
Generally, read operations are for an object or class, as discussed earlier, so the next part of the URI specifies
whether the operation will be for an MO or class. The next component defines either the fully qualified Dn
being queried for object-based queries, or the package and class name for class-based queries. The final
mandatory part of the request URI is the encoding format: either .xml or .json. This is the only method by
which the payload format is defined (the APIC ignores Content-Type and other headers).

Write Operations
Create and update operations in the REST API are both implemented using the POST method, so that if an
object does not already exist, it will be created, and if it does already exist, it will be updated to reflect any
changes between its existing state and desired state.

Operating Cisco Application Centric Infrastructure


216
Scripting
About the REST API

Both create and update operations can contain complex object hierarchies, so that a complete tree can be
defined in a single command so long as all objects are within the same context root and are under the 1MB
limit for data payloads for the REST API. This limit is in place to guarantee performance and protect the
system under high load.
The context root helps define a method by which the APIC distributes information to multiple controllers and
helps ensure consistency. For the most part, the configuration should be transparent to the user, though very
large configurations may need to be broken into smaller pieces if they result in a distributed transaction.
Figure 55: REST Payload

Create and update operations use the same syntax as read operations, except that they always are targeted at
an object level, because you cannot make changes to every object of a specific class (nor would you want to).
The create or update operation should target a specific managed object, so the literal string /mo indicates that
the Dn of the managed object will be provided, followed next by the actual Dn. Filter strings can be applied
to POST operations; if you want to retrieve the results of your POST operation in the response, for example,
you can pass the rsp-subtree=modified query string to indicate that you want the response to include any
objects that have been modified by your POST operation.
The payload of the POST operation will contain the XML or JSON encoded data representing the managed
object the defines the Cisco API command body.

Authentication
REST API username- and password-based authentication uses a special subset of request URIs, including
aaaLogin, aaaLogout, and aaaRefresh as the Dn targets of a POST operation. Their payloads contain a
simple XML or JSON payload containing the MO representation of an aaaUser object with the attribute name
and pwd defining the username and password: for example, <aaaUser name='admin' pwd='insieme'/>.
The response to the POST operation will contain an authentication token as both a Set-Cookie header and an
attribute to the aaaLogin object in the response named token, for which the XPath is /imdata/aaaLogin/@token

Operating Cisco Application Centric Infrastructure


217
Scripting
API Inspector

if the encoding is XML. Subsequent operations on the REST API can use this token value as a cookie named
APIC-cookie to authenticate future requests.

Filters
The REST API supports a wide range of flexible filters, useful for narrowing the scope of your search to allow
information to be located more quickly. The filters themselves are appended as query URI options, starting
with a question mark (?) and concatenated with an ampersand (&). Multiple conditions can be joined together
to form complex filters.
The following query filters are available:
Figure 56: Query Filters

Subscription
The REST API supports the subscription to one or more MO during your active API session. When Any MO
is created, changed, or deleted because of a user- or system-initiated action, an event is generated. If the event
changes the data on any of the active subscribed queries, the APIC will send out a notification to the API
client that created the subscription.

API Inspector
All operations that are performed in the GUI invoke REST calls to fetch and commit the information being
accessed. The API Inspector further simplifies the process of examining what is taking place on the REST

Operating Cisco Application Centric Infrastructure


218
Scripting
Development Techniques

interface as the GUI is navigated by displaying in real time the URIs and payloads. When a new configuration
is committed, the API Inspector displays the resulting POST requests, and when information is displayed on
the GUI, the GET request is displayed.
To get started with the API Inspector, it can be accessed from the Account menu, visible at the top right of
the Cisco APIC GUI. Click Welcome, <username> and then choose the Show API Inspector option
After the API Inspector is brought up, time stamps will appear along with the REST method, URIs, and
payloads. There may also be occasional updates in the list as the GUI refreshes subscriptions to data being
shown on the screen.
From the output above it can see that the last logged item has a POST request with the JSON payload containing
a tenant named Cisco and some attributes defined on that object:
url: http://172.16.176.176/api/node/mo/uni/tn-Cisco.json

{
"fvTenant": {
"attributes": {
"name": "Cisco",
"status": "created"
},
"children": [
{
"fvBD": {
"attributes": {
"mac": "00:22:BD:F8:19:FF",
"name": "CiscoBd",
"status": "created"
},
"children": [
{
"fvRsCtx": {
"attributes": {
"tnFvCtxName": "CiscoVrf",
"status": "created,modified"
},
"children": []
}
}
]
}
},
{
"fvCtx": {
"attributes": {
"name": "CiscoVrf",
"status": "created"
},
"children": []
}
}
]
}
}

Development Techniques
ACI has a number of methods for developing code that can be used by engineers who have varying levels of
comfort with programming or interacting with programmatic interfaces.

Operating Cisco Application Centric Infrastructure


219
Scripting
POSTman

The most basic and straight-forward technique involves simply taking information gleaned by the API inspector,
Visore, or by saving XML/JSON directly from the GUI, and using common freely available tools, such as
POSTman, to send this information back to the REST API.
A step up from this method enables users to use common terminology and well understood networking
constructs, coupling these with the power and flexibility of the ACI policy language and the popular Python
programming language to configure ACI in a programmatic fashion. ACI Toolkit is a utility developed in
open-source that exposes the most common ACI building blocks, to enable users to rapidly create tenants,
application profiles, EPGs and the associated concepts to connect those to physical infrastructure. The
streamlined interface provided makes it very quick to adopt and allows users to begin to quickly develop their
applications.
The most powerful of the development tools available is the Cobra SDK. With a complete representation of
the ACI object model available, comprehensive data validation, and extensive support for querying and
filtering, Cobra ensures that the complete ACI experience is available to developers and users alike.

POSTman
POSTman is an open source extension for the Chrome web browser, which provides REST client functionality
in an easy-to-use package. POSTman can be used to interact with the APIC REST interface, to both send and
receive data which may represent configuration, actions, policy and operational state data. For an individual
unfamiliar with the structure of REST, it is very simple to utilize the API Inspector to view what the underlying
calls being made to the GUI are for certain operations, capture those, and then use POSTman to replay those
operations. Furthermore POSTman allows for the requests to be modified: GUI operations can be made once,
attributes changed in the captured data and then sent back to the REST API to make the modifications.

Installation
To get started with POSTman, the first step is to download the plugin for the Chrome web browser, which is
available at http://www.getpostman.com. Once the plugin is installed, it can be accessed using the Chrome
App launcher.
Initially the user will be presented with an interface that has two primary sections: the sidebar on the left and
the request constructor on the right. Using the sidebar, the user can switch between the history of REST
requests sent by POSTman, as well as Collections of requests that contain common tasks.

Collections
A useful post to create in a collection is a basic Login operation. In order to do this, the user should first click
into the Collections tab in the sidebar. Within the sidebar, a small folder with a plus (+) sign will become
visible, which should then be clicked, at which point a popup will appear prompting the user to give a name
to the collection. For this example, the collection can be named "APIC", after which the Create button should
be clicked.

Build Login Request


Now a new request can be built. In the request constructor, where "Enter request URL here" is shown, the
following request URI should be entered, substituting APICIPADDRESS with the IP of the APIC:
https://apicipaddress/api/mo/aaaLogin.xml

Operating Cisco Application Centric Infrastructure


220
Scripting
POSTman

This request URI will call the Login method in the REST API. Since a Login will require posting data, the
HTTP method should be changed, which can be done by clicking the dropdown list to the right of the request
URL. By default it will be a GET request, but POST will need to be selected from the drop down list.
With the POST method selected, it is now possible to provide the REST payload. Given that the data will be
sent via REST, the "raw" Request body selector should be picked.
Now the payload for the request can be entered, which will be the simple XML containing the username and
password that will be used for authentication. Note that the URL is https, meaning that it will be encrypted
between the web browser and the APIC, so no data is being transmitted in clear text. The following request
body should be entered, substituting the correct username and password in place of USERNAME and
PASSWORD:
<aaaUser name='USERNAME' pwd='PASSWORD'/>

With this request built, it is now possible to Send the request, but since this will be a commonly used method,
the request should be added to a collection. This can be accomplished by clicking the "Add to collection"
button beneath the request body. Select the "APIC" collection from the existing collection list, and change
the Request name to "Login" and then click "Add to collection".
By adding the request to a collection it can later be quickly accessed to establish a login session with APIC
as needed.
After completing the above steps, the request is ready to be sent. Click the "Send" button in the request
constructor, and the REST API will return the XML representing a login session with the APIC. The following
will be visible in the POSTman GUI:

Make Query to APIC


The next request that will be built is one that queries the APIC for a list of tenants on the system. First click
the "Reset" button in the request constructor, and proceed with the same steps as above, except that the request
URL will be shown as:
https://apicipaddress/api/class/fvTenant.xml

and the request method will be changed to GET.


Click "Add to collection" and place the request into the APIC collection, and for the name enter "Query APIC
for tenants"
Now upon clicking "Send", this request will return an XML encoded list of tenants in the response body
section of the constructor pane on the right.

Make Configuration Change in APIC


Making a configuration change will use a POST request similar to logging in, however the request URL and
body will contain a different set of information.
For this example, a new tenant will be created in the fabric. Click the "Reset" button in the request constructor
to clear out all existing request fields, and use this URL:
https://apicipaddress/api/mo/uni.xml

and change the method to POST.


In the request payload, enter the following data:
<fvTenant name="Cisco"/>

Operating Cisco Application Centric Infrastructure


221
Scripting
Cobra SDK and Arya

The request URL specifies that the target for this query will be the policy universe, which is where tenants
live. With this target properly scoped, the data representing the tenant can be provided in the payload, in this
case creating a tenant named Cisco.

Use API Inspector for Query Guidance


As discussed in the Introduction to Scripting section, API inspector can be used as a guideline for building
custom REST requests. Furthering on the example in that section, where the request URL is:
https://apicipaddress/api/node/mo/uni/tn-Cisco.json

and the payload is the following compacted version of JSON:

{"fvTenant": {"attributes": {"name": "Cisco", "status": "created"},


"children": [{"fvBD": {"attributes": {"mac": "00:22:BD:F8:19:FF",
"name": "CiscoBd", "status": "created"}, "children": [{"fvRsCtx":
{"attributes": {"tnFvCtxName": "CiscoVrf", "status":
"created,modified"}, "children": [] } } ] } }, {"fvCtx": {"attributes":
{"name": "CiscoVrf", "status": "created"}, "children": [] } } ] } }

It is possible to modify the request URI and payload and substitute the tenant name "Cisco" with another
tenant name, to create an entirely new tenant, with the same configuration. The new request URL and JSON
would be:
https://apicipaddress/api/node/mo/uni/tn-Acme.json

{"fvTenant": {"attributes": {"name": "Acme", "status": "created"},


"children": [{"fvBD": {"attributes": {"mac": "00:22:BD:F8:19:FF",
"name": "AcmeBd", "status": "created"}, "children": [{"fvRsCtx":
{"attributes": {"tnFvCtxName": "AcmeVrf", "status": "created,modified"},
"children": [] } } ] } }, {"fvCtx": {"attributes": {"name": "AcmeVrf",
"status": "created"}, "children": [] } } ] } }

These values can be placed into a POST request in POSTman, and after establishing a Login session using
the saved Login request, the new tenant "Acme" can be created, identical to the previously created Cisco
tenant, without needing to manually click through the GUI or use other manual methods.

Cobra SDK and Arya


The complete Cisco ACI Python SDK is named Cobra. It is a pure Python implementation of the API that
provides native bindings for all the REST functions and also has a complete copy of the object model so that
data integrity can be ensured, as well as supporting the complete set of features and functions available in
ACI. Cobra provides methods for performing lookups and queries and object creation, modification, and
deletion that match the REST methods used by the GUI and those that can be found using API Inspector. As
a result, policy created in the GUI can be used as a programming template for rapid development.
The installation process for Cobra is straightforward, and you can use standard Python distribution utilities.
Cobra is distributed on the APIC as an .egg file and can be installed using easy_install, and is also available
on github at http://github.com/datacenter/cobra.
The complete documentation for the Cobra SDK is available at http://cobra.readthedocs.org/en/latest/.

Operating Cisco Application Centric Infrastructure


222
Scripting
Establish Session

Establish Session
The first step in any code that uses Cobra is establishing a login session. Cobra currently supports username-
and password-based authentication, as well as certificate-based authentication. The example here uses username-
and password-based authentication.

import cobra.mit.access
import cobra.mit.session
apicUri = 'https://10.0.0.2'
apicUser = 'username'
apicPassword = 'password'
ls = cobra.mit.session.LoginSession(apicUri, apicUser, apicPassword)
md = cobra.mit.access.MoDirectory(ls)
md.login()

This example provides an MoDirectory object named md, which is logged into and authenticated for Cisco
APIC. If for some reason authentication fails, Cobra will display a cobra.mit.request.CommitError exception
message. With the session logged in, you are ready to proceed.

Work with Objects


Use of the Cobra SDK to manipulate the MIT generally follows this workflow:
1. Identify the object to be manipulated.
2. Build a request to change attributes or add or remove children.
3. Commit the changes made to the object.
For example, if you want to create a new tenant, you must first identify where the tenant will be placed in the
MIT, where in this case it will be a child of the policy Universe managed object (polUniMo):

import cobra.model.pol
polUniMo = cobra.model.pol.Uni('')

With the polUniMo object defined, you can create a tenant object as a child of polUniMo:

import cobra.model.fv
tenantMo = cobra.model.fv.Tenant(polUniMo, 'cisco')

All these operations have resulted only in the creation of Python objects. To apply the configuration, you must
commit it. You can do this using an object called a ConfigRequest. ConfigRequest acts as a container for
MO-based classes that fall into a single context, and they can all be committed in a single atomic POST
operation.

import cobra.mit.request
config = cobra.mit.request.ConfigRequest()
config.addMo(tenantMo)
md.commit(config)

The ConfigRequest object is created, then the tenantMo object is added to the request, and then you commit
the configuration through the MoDirectory object.
For the preceding example, the first step builds a local copy of the polUni object. Because it does not have
any naming properties (reflected by the empty double single quotation marks), you don't need to look it up
in the MIT to figure out what the full Dn for the object is; it is always known as uni.

Operating Cisco Application Centric Infrastructure


223
Scripting
Cisco APIC REST to Python Adapter

If you wanted to post something deeper in the MIT, where the object has naming properties, you would need
to perform a lookup for that object. For example, if you wanted to post a configuration to an existing tenant,
you could query for that tenant and create objects beneath it.

tenantMo = md.lookupByClass('fvTenant', propFilter='eq(fvTenant.name, "cisco")')


tenantMo = tenantMo[0] if tenantMo else None

The resulting tenantMo object will be of class cobra.model.fv.Tenant and will contain properties such as
.dn, .status, and .name, all describing the object itself. The lookupByClass() entry returns an array, because
it can return more than one object. In this case, the command is specific and is filtering on an fvTenant object
with a particular name. For a tenant, the name attribute is a special type of attribute called a naming attribute.
The naming attribute is used to build the relative name, which must be unique in its local namespace. As a
result, you can be assured that lookupByClass on an fvTenant object with a filter on the name always returns
either an array of length 1 or None, meaning that nothing was found.
To entirely avoid a lookup, you can build a Dn object and make an object a child of that Dn. This method
works only in cases in which the parent object already exists.

topDn = cobra.mit.naming.Dn.fromString('uni/tn-cisco')
fvAp = cobra.model.fv.Ap(topMo, name='AppProfile')

These fundamental methods for interacting with Cobra provide the building blocks necessary to create more
complex workflows that can help automate network configuration, perform troubleshooting, and manage the
network.

Cisco APIC REST to Python Adapter


The process of building a request can be time consuming, because you must represent the object data payload
as Python code reflecting the object changes that you want to make. Because the Cobra SDK is directly
modeled on the Cisco ACI object model, you should be able to generate code directly from what resides in
the object model. As expected, you can do this using a tool developed by Cisco Advanced Services. The tool
is the Cisco APIC REST to Python Adapter, known as Arya.
Figure 57: Sample REST to Python Adapter

The above figure clearly shows how the input that might come from the API Inspector, Visore, or even the
output of a REST query and can then be quickly converted into Cobra SDK code, tokenized, and reused in
more advanced ways.

Operating Cisco Application Centric Infrastructure


224
Scripting
Cisco APIC REST to Python Adapter

Installation of Arya is relatively simple, and the tool has few external dependencies. To install Arya, you must
have Python 2.7.5 and git installed. Use the following quick installation steps to install it and place it in your
system Python.

git clone https://github.com/datacenter/ACI.git


cd ACI/arya
sudo python setup.py install

After Arya has been installed, you can take XML or JSON representing Cisco ACI modeled objects and
convert it to Python code quickly. For example, enter:

arya.py -f /home/palesiak/simpletenant.xml

The entry will yield the following Python code:

#!/usr/bin/env python
'''
Autogenerated code using arya.py
Original Object Document Input:
<fvTenant name='bob'/>
''' raise RuntimeError('Please review the auto generated code before ' +
'executing the output. Some placeholders will ' +
'need to be changed')
# list of packages that should be imported for this code to work
import cobra.mit.access
import cobra.mit.session
import cobra.mit.request
import cobra.model.fv
import cobra.model.pol
from cobra.internal.codec.xmlcodec import toXMLStr
# log into an APIC and create a directory object
ls = cobra.mit.session.LoginSession('https://1.1.1.1', 'admin', 'password')
md = cobra.mit.access.MoDirectory(ls)
md.login()
# the top level object on which operations will be made
topMo = cobra.model.pol.Uni('')
# build the request using cobra syntax
fvTenant = cobra.model.fv.Tenant(topMo, name='bob')
# commit the generated code to APIC
print toXMLStr(topMo)
c = cobra.mit.request.ConfigRequest()
c.addMo(topMo)
md.commit(c)

The placeholder raising a runtime error must first be removed before this code can be executed; it is purposely
put in place to help ensure that any other tokenized values that must be updated are corrected. For example,
the Cisco APIC IP address, which defaults to 1.1.1.1, should be updated to reflect the actual Cisco APIC IP
address. The same applies to the credentials and any other placeholders.
Note that if you provide input XML or JSON that does not have a fully qualified hierarchy, Arya may not be
able to identify it through heuristics. In this case, a placeholder will be populated with the text REPLACEME,
which you will need to replace with the correct Dn. You can find this Dn by querying for the object in Visore
or inspecting the request URI for the object shown in the API Inspector.

Operating Cisco Application Centric Infrastructure


225
Scripting
ACI Toolkit

ACI Toolkit
The complete Cisco Application Centric Infrastructure (ACI) object model contains many entities, which may
be daunting for a user being first introduced to network programmability. The ACI Toolkit makes available
a simplified subset of the model that can act as an introduction to the concepts in ACI, and give users a way
to quickly bring up common tasks and workflows. In addition, a number of applications have been built on
top of ACI Toolkit.
The complete documentation for the ACI Toolkit is available at http://datacenter.github.io/acitoolkit/
While the ACI Toolkit provides some useful tools for an operator to immediately use, the real value is in the
ability to take these examples as a starting point, and modify or extend these samples to suit your particular
needs. Give it a try! Be sure to share your work back with the community!

ACI Toolkit Applications


Endpoint Tracker
The endpoint tracker application creates a subscription to the endpoint class (fvCEp) and populates a MySQL
database with pertinent details about each endpoint present on the fabric (for example servers, firewalls, load
balancers, and other devices). Installing MySQL is outside the scope of this book, so we will assume you
have access to create a new database on a MySQL server. The endpoint tracker application has two primary
components that are both python scripts.
• aci-endpoint-tracker.py - This script creates the subscription to the endpoint class and populates the
MySQL database
• aci-endpoint-tracker-gui.py - This script creates a web interface that provides a way to present the
contents of the database to the operator. A sample is shown below:
Figure 58: Endpoint Tracker

To launch Endpoint Tracker run the following python scripts. The first script, aci-endpoint-tracker.py, will
actually connect to the APIC and populate the database. The second script enables the content to be viewed
in an understandable web UI.

user@linuxhost:~/acitoolkit/applications/endpointtracker$ ./aci-endpoint-tracker.py
MySQL IP address: 127.0.0.1
MySQL login username: root

Operating Cisco Application Centric Infrastructure


226
Scripting
Endpoint Tracker

MySQL Password:
user@linuxhost::~/acitoolkit/applications/endpointtracker$ python aci-endpointtracker-
gui.py
MySQL IP address: 127.0.0.1
MySQL login username: root
MySQL Password:
* Running on http://127.0.0.1:5000/
* Restarting with reloader

After running those python scripts you can now bring up a browser and go the Web UI. Using the ACI Endpoint
Tracker is simply a matter of inputting an IP or MAC address into the search field, and the table is filtered
accordingly. In the example below, the IP address 192.168.5.20 has been input into the search field, and the
matching results are displayed.

One more interesting usage of the endpoint tracker applications is a series of visualizations that can represent
how various endpoints are mapped to other fabric constructs including Tenants, Applications, and EPGs.
Some sample screenshots are shown below. These are representations of where end points are within the ACI
fabric and how they relate to or depend on other objects in the environment.
Figure 59: Pie chart view of endpoint distribution

Operating Cisco Application Centric Infrastructure


227
Scripting
ACI Lint

Figure 60: Tree view of endpoint relationships

Figure 61: Force diagram of endpoint location

ACI Lint
In computer programming, Lint is a term that refers to identifying discrepancies, or simple debug tool for
common errors. In the sense that ACI provides infrastructure as code, it is appropriate for ACI to also have
a Lint application. ACI Toolkit provides just that. ACI Lint is an application that checks and notifies an
operator of misconfiguration errors in two primary capacities:
Security Issues - supports the ability to tag EPGs as either secure or insecure, and then runs a validation that
contracts are not used to cross security boundaries.
Configuration Issues - checks for common configuration errors and reports them to the user.
A sample output is provided here for reference:

user@linuxhost:~/acitoolkit/applications/lint$ ./acilint.py
Getting configuration from APIC....

Operating Cisco Application Centric Infrastructure


228
Scripting
ACI Cable Plan Module

Processing configuration....
Critical 001: EPG 'default' in tenant 'infra' app 'access' is not assigned security
clearance
Critical 001: EPG 'x' in tenant 'common' app 'default' is not assigned security
clearance
Warning 001: Tenant 'Cisco' has no Application Profile.
Warning 001: Tenant 'Books' has no Application Profile.
Warning 001: Tenant '3tierapp' has no Application Profile.
Warning 001: Tenant 'mgmt' has no Application Profile.
Warning 002: Tenant 'Books' has no Context.
Warning 002: Tenant '3tierapp' has no Context.
Warning 004: Context 'oob' in Tenant 'mgmt' has no BridgeDomains.
Warning 005: BridgeDomain 'CiscoBd' in Tenant 'Cisco' has no EPGs.
Warning 005: BridgeDomain 'inb' in Tenant 'mgmt' has no EPGs.
Warning 006: Contract 'default' in Tenant 'common' is not provided at all.
Warning 006: Contract 'WebServers' in Tenant 'Acme' is not provided at all.
Warning 006: Contract 'External' in Tenant 'Acme' is not provided at all.
Warning 007: Contract 'default' in Tenant 'common' is not consumed at all.
Warning 007: Contract 'WebServers' in Tenant 'Acme' is not consumed at all.
Warning 007: Contract 'External' in Tenant 'Acme' is not consumed at all.
Warning 007: Contract 'outside-to-web' in Tenant 'roberbur' is not consumed at all.

ACI Cable Plan Module


Cable management is a crucial aspect for supporting a data center, and cabling issues can causes several hours
of delay when deploying something new in the data center. The Cable Plan module allows the programmer
to import existing cable plans easily from XML files, import the currently running cable plan from an
Application Policy Infrastructure Controller (APIC) controller, export previously imported cable plans to a
file, and compare cable plans. More advanced users can use the Cable Plan to build a cable plan XML file
easily, query a cable plan, and modify a cable plan.

ACI CLI Emulator Module


Cisco Application Centric Infrastructure (ACI) has many new concepts and its policy-driven architecture can
be hard for some users to grasp at first. For users who want to integrate both the CLI that they are previously
familiar with along with the policy-driven architecture, the ACI CLI emulator assists with this task. With the
CLI emulator module, you can run the show commands on tenants, contexts, and other policies that are unique
to ACI.

ACI Multisite Application


The multisite application allows a Cisco Application Centric Infrastructure (ACI) fabric to be extended across
multiple sites. These sites are independent ACI fabrics where each fabric has its own Application Policy
Infrastructure Controller (APIC) cluster. The multisite application preservers the group based policy model
of ACI by allowing a contract to be extended across multiple sites so that endpoint groups from different sites
can communicate.

ACI Configuration Snapshot and Rollback


Snapback is a configuration snapshot and rollback tool for Cisco Application Centric Infrastructure (ACI)
fabrics. Specifically, the tool allows an administrator to perform the following tasks:
• Live snapshots of the running ACI fabric configuration
• One-time and recurring snapshots, both immediate and scheduled
• Versioned storage of the configuration
• Full viewing of any snapshot configuration including the differences between snapshots

Operating Cisco Application Centric Infrastructure


229
Scripting
ACI EventsFeeds: ACI Events to Atom Feed

• Rollback to any previous configuration snapshot: full or partial


• Web-based or command line administration

ACI EventsFeeds: ACI Events to Atom Feed


The EventFeeds application subscribes to Application Policy Infrastructure Controller (APIC) managed objects
and records any updates to the objects over a websocket connection. These updates can be viewed in a variety
of Atom feeds provided over HTTP.
Some sample use cases for the Cisco Application Centric Infrastructure (ACI) Events to Atom Feed app:
• Display recent endpoints in a NOC
• Display updated tenants on an IPTV
• Monitor endpoint group changes in a feed client

GitHub
Source Control
Open source software has been a popular movement in IT, and has been the motivation behind many successful
projects, including consumer software, web servers, databases and even entire operating systems. One of the
key aspects to the success of open source is the ability for many developers around the globe to collaborate
together on a single project. Previous tools like Concurrent Version Control (CVS), and Subversion (SVN)
were used to allow many developers to work together, with a central server maintaining a common database
of source code. While these tools have and continue to work well, there has been a slow migration away from
those server-based tools to decentralized utilities, with the foremost being Git. Git was created by Linus
Torvalds, the author of the popular open-source operating system Linux. Git has a number of advantages over
most other source control tools: complete local repository copies, distributed architecture, and more efficient
support for branches.

GitHub
GitHub is a hosting platform based around git, which provides both free and paid hosting services, that allow
for individuals to collaborate with over eight-million other GitHub users on projects together. Aside from
being a wrapper around git, GitHub also provides techniques for tracking issues, securing access to projects,
and built-in project documentation. The combination of all of these features has made GitHub a very common
place for members of the community to share code with one another, build on each other's work, and contribute
their efforts back into larger projects.
What is stored on GitHub is usually source code, not limited to any specific language, however the git protocol
itself supports storage and version control of any file type, so it's not uncommon for users to store documentation
or other constantly changing files in git. The primary advantage is that the version control provided by git
allows a user to revert a file back to any previously stored version, or alternately move forward to a newer
version. Git also maintains an audit of changes that have been made to files and even has advanced support
for branching versions of files to allow multiple concurrent modifications to a file to take place, and allow
for them to be merged after work efforts have completed.

"It's on github"
A common phrase in modern IT jargon is, "It's on github", and for users familiar with GitHub, this is an
invitation to download, modify and contribute to the project, however for those who have not had an introduction

Operating Cisco Application Centric Infrastructure


230
Scripting
GitHub

it can seem like a complex topic. GitHub is actually a very simple tool to use, and the simplest way to begin
to take advantage of the information stored on GitHub is to simply access a projects main page and look for
the "Download ZIP" button at the bottom right of any project's main page. The resulting downloaded file will
contain the latest version of the files in the project. What a user does with these files will greatly depend on
what the contents are, however one of the most highly encouraged behaviors on GitHub is to provide clear
and obvious documentation for a project, so if a new user accesses the front page of a project on Git, they
will typically be able to find instructions on how to download and install the project, right on the first page
they see.
For users looking to contribute back to a project, the next step would be to sign up for an account on GitHub,
and download a graphical-based client to provide a simpler interface to the command line-based git tool.
GitHub itself has a graphical client with the Windows version available at http://windows.github.com and the
Mac versions at http://mac.github.com. Other common source control tools include SourceTree from Atlassian,
available at http://sourcetreeapp.com.
Once a user has an account and a github client, they can "Fork", or split off a project that is available into
their own private repository, make changes and commit those back to their private branch. If those changes
work, and the user wishes to contribute them back into the original project, it is possible to submit a "Pull"
request, which essentially means that the user is proposing their efforts should be pulled back into the original
project. The process can be that simple, though many more advanced projects have standards and rules for
contributing to those projects that put in place requirements around how work is committed back into the
projects, which may require some reading before attempting to contribute.

Operating Cisco Application Centric Infrastructure


231
Scripting
GitHub

Operating Cisco Application Centric Infrastructure


232
CHAPTER 11
Hardware Expansion and Replacement
• Expanding and Shrinking the Fabric, on page 233
• Hardware Diagnostics and Replacement, on page 238

Expanding and Shrinking the Fabric


ACME may decide to expand their ACI fabric as their data center grows, which means adding new leaf and
spine switches, and possibly APICs. Generally, spine switches are added for more throughput, and leaf switches
are added for more access ports. APICs are added as the number of policies and endpoints increase. Additionally,
some switches or APICs may need to be decommissioned. Also, there may be times when you need to replace
failed hardware, which is discussed in the Hardware Replacements chapter.
This section will walk through the operations of adding and removing switches and APICs in your existing
ACI fabric. This is done the same way for both spine and leaf switches. Adding APICs will also be covered.

Switches
There are two ways switches can be added to ACME's existing fabric: by discovering the switches automatically
in the APIC after they have been cabled to the fabric, or by pre-provisioning the switches by adding their
serial numbers and later connecting them physically to the fabric when the switches arrive. Both methods
have the same outcome: an expanded fabric in the matter of minutes. This section will also cover
decommissioning switches.

Add a Connected Switch


The following procedure adds a switch that has already been attached to the fabric:

Note When replacing spine switches, you must take into account the BGP route reflector function. You must
configure at least two spine switches as BGP route reflectors for a Layer 3 Cisco Application Centric
Infrastructure (Cisco ACI) fabric. You can make this configuration change under System > System Settings >
BGP Route Reflectors, under Route Reflector Nodes. If you replace or remove the spine switches, make
the appropriate configuration changes to keep at least one route reflector active while you replace or remove
the spine switches, and have at least two active route reflectors after you complete the changes.
For more information about BGP route reflectors, see the Cisco APIC Layer 3 Networking Configuration
Guide.

Operating Cisco Application Centric Infrastructure


233
Hardware Expansion and Replacement
Pre-Provision Switch Before Connection

1. In the case of a leaf switch, cable the switch to all of the spine switches. In the case of a spine switch,
cable the switch to all of the leaf switches. Ideally, a best-practice Cisco ACI fabric is connected in a full
mesh topology with every leaf switch cabled to every spine switch. All devices should connect to the leaf
switches, leaf switches should never connect to other leaf switches, and spine switches should never
connect to other spines.
2. In the Cisco Application Policy Infrastructure Controller (Cisco APIC) click on Fabric at the top of the
screen.
3. Click on Fabric Membership in the left navigation pane.
4. When the new switch appears, you'll see a node with a serial number but no Node ID or Node Name
configured. Double-click the switch and assign a Node ID and a Node Name. As a best practice, number
leaf nodes starting with 101, and spine nodes with 201. Lower numbers are reserved for the Cisco APICs.
5. Optionally, add a Rack Name name. This is commonly used to identify the physical location of the switch
in the data center.
6. Click Submit.
7. Repeat this process for all of the new switches that are connected to the fabric.

Pre-Provision Switch Before Connection


Pre-provisioning a switch is a handy operationally proactive step to get the switch registered before it even
arrives to your data center. You will need to know the serial number of the switch you will receive to
pre-provision. The following steps walk you through switch pre-provisioning for both leaves and spines:
1. On the menu bar, choose Fabric.
2. In the Navigation pane, choose Fabric Membership.
3. In the Work pane, choose Actions > Create Fabric Node Member.
4. In the Create Fabric Node Member dialog box, perform the following actions:
1. In the pop-up window, enter the serial number of the switch that will be arriving.
2. Assign a Node ID and a Switch Name. As a best practice, number leaf nodes starting with 101, and
spine nodes with 201. Lower numbers are reserved for APICs.

5. Click Submit.
Note: Repeat this process for all switches you wish to pre-provision.

The new entry in the Fabric Membership window will show Unsupported in the Role column until the switch
is actually connected to the fabric, but the switch will immediately become a member of the fabric once it
arrives and is cabled.
To be proactive, you can also pre-provision fabric policies. Fabric policies are covered in the Fabric Connectivity
chapter. For more information on pre-provisioning policies, refer to the following white paper:
http://www.cisco.com/c/en/us/solutions/collateral/data-center-virtualization/application-centric-infrastructure/
white-paper-c11-731960.html#_Toc405844675

Operating Cisco Application Centric Infrastructure


234
Hardware Expansion and Replacement
Decommission Existing Switch

Decommission Existing Switch


Decommissioning a switch can either remove it from the fabric entirely, or remove a switch temporarily to
perform maintenance. Ensure you do not have any devices connected, as the switch will not forward traffic
after decommissioning. There are two types of switch decommissioning: Regular, and Remove from Controller.
Regular decommissioning can be used for maintenance and essentially silences the switch from reporting
faults and sending SNMP information as a temporary solution, while keeping the switch's node ID and fabric
membership. The switch will show up under the Disabled Interfaces and Decommissioned Switches folder
in the left navigation pane.
The Remove from Controller option will completely remove the switch from the ACI fabric and all APICs.
The switch will no longer show up in the fabric membership as a registered node and the infrastructure VTEP
IP addresses it was assigned will be removed.
Perform the following steps to decommission a switch from the ACI fabric:
1. On the menu bar, choose Fabric.
2. In the Navigation pane, choose Inventory > Pod 1.
3. Click the switch to decommission in the Navigation pane.
1. Click the General tab.
2. Chose the Actions > Decommission.
3. In the pop-up, choose either Regular or Remove from Controller.

4. Click Submit.

Cisco Nexus 9300 Platform Switches to Cisco Nexus 9300-EX Platform Switches Migration
Use this procedure to migrate Cisco Nexus 9300 platform switches in virtual port channel (vPC) to Cisco
Nexus 9300-EX platform switches.

Procedure

Step 1 Remove the cables from Cisco Nexus 9300 platform switch. Power off the switch.
Step 2 Log in to Cisco APIC.
Step 3 Choose Fabric > Inventory > Unreachable Nodes.
Ensure that the node is unreachable. Make a note of the Node Name and Node ID.

Step 4 Select the node. From the Actions menu, choose Remove From Controller.
Wait for 5-10 minutes for the node to be removed from the Cisco APIC.

Step 5 Monitor the traffic on Cisco Nexus 9300 platform switch. All the traffic should be handled by the other Cisco
Nexus 9300 platform switch and there should be minimal or no impact to traffic.
Step 6 Replace Cisco Nexus 9300 platform switch with Cisco Nexus 9300-EX platform switch.
Step 7 Power on Cisco Nexus 9300-EX platform switch and connect the cables.
Step 8 Load the Cisco APIC Release 3.0(1) software on Cisco Nexus 9300-EX platform switch. Boot the switch.
Step 9 Log in to Cisco APIC.

Operating Cisco Application Centric Infrastructure


235
Hardware Expansion and Replacement
Cisco APICs

Step 10 Choose Fabric > Inventory > Fabric Membership.


Verify if the switch is displayed.

Step 11 Assign the Node Name and Node ID from step 3 to Cisco Nexus 9300-EX platform switch.
Step 12 Wait for a few minutes for all the relevant policies to be pushed to the Cisco Nexus 9300-EX platform switch
and for the end point synchronization to complete. To verify, choose Operations > Capacity Dashboard.
Port channel on this switch is not activated.
Step 13 Remove the cables from the other Cisco Nexus 9300 platform switch. Power off the switch.
Step 14 Repeat the steps 1-12 for the other Cisco Nexus 9300 platform switch.

Cisco APICs
Add New APIC
Before making any changes to an Application Policy Infrastructure Controller (APIC) cluster, ensure each
APIC in the cluster is fully fit and change the cluster size to reflect the new controller you are adding to the
cluster. Perform the following steps to verify cluster health:
1. On the menu bar, choose System > Controllers.
2. In the Navigation pane, choose Controllers.
1. Expand the first APIC in the folder.
2. Click the Cluster as Seen by Node folder.
3. Verify every controller shows Fully Fit under the Health State column.

If any of the APICs are not fully fit, refer to the Cisco APIC Troubleshooting Guide.
Perform the following steps to change the APIC cluster size:
1. On the menu bar, choose System > Controllers.
2. In the Navigation pane, choose Controllers > APIC_Name > Cluster as Seen by Node.
3. In the Work pane, choose Actions > Change Cluster Size.
1. Change the Target Cluster Administrative Size to reflect the new APICs being added.
Note: A cluster size of two is not permitted as that does not allow for quorum amongst APICs.

4. Click Submit.

Perform the following steps to add a new APIC to the cluster:


1. Install and stage the APIC by connecting it to the fabric by following the hardware installation guide:
http://www.cisco.com/c/en/us/support/cloud-systems-management/
application-policy-infrastructure-controller-apic/products-installation-guides-list.html
2. On the menu bar, choose System > Controllers.
3. In the Navigation pane, choose Controllers > APIC_Name > Cluster.

Operating Cisco Application Centric Infrastructure


236
Hardware Expansion and Replacement
Decommission an Existing Cisco APIC

1. The APIC controllers are added one by one and displayed in the sequential order starting with N + 1
and continuing until the target cluster size is achieved.
2. Verify that the APIC controllers are in operational state, and the health state of each controller is Fully
Fit from the Cluster folder under the new controller.

Note It will take several minutes for the APICs to synchronize and join the new APIC to the cluster. Fabric operation
will continue normally.

Decommission an Existing Cisco APIC


When decommissioning Cisco Application Policy Infrastructure Controllers (Cisco APICs), they must be
decommissioned sequentially in reverse order. For example, APIC5 must be decommissioned before APIC4.
Again, before making any changes to the Cisco APIC cluster, ensure that each Cisco APIC in the cluster is
fully fit with the exception of the faulty Cisco APIC being decommissioned. You cannot decommission a
powered on fully fit Cisco APIC.

Note If you decommission a Cisco APIC with the intent of replacing or re-adding the Cisco APIC after wiping it
(given some direction from Cisco TAC), wait at least 10 minutes between running the decommission command
and the recommission command. Failure to do so can result in cluster contention and, in the worst case scenario,
a disruption in traffic forwarding.

Perform the following steps to decommission a Cisco APIC that needs to be removed from the fabric:
1. On the menu bar, choose System > Controllers.
2. In the Navigation pane, choose Controllers > APIC_Name > Cluster.

Note Select a Cisco APIC that is NOT being decommissioned.

3. In the Work pane, choose Actions > Change Cluster Size.


1. Change the Target Cluster Administrative Size to reflect the new Cisco APICs being added.

Note A cluster size of two is not permitted as that does not allow for quorum amongst Cisco APICs.

4. Click Submit.
5. In the Navigation pane, choose Controllers > APIC_Name > Cluster.

Note In the main pane, click the Cisco APIC to be decommissioned.

Operating Cisco Application Centric Infrastructure


237
Hardware Expansion and Replacement
Hardware Diagnostics and Replacement

6. In the Work pane, choose Actions > Actions > Decommission.


1. Verify that the Cisco APIC no longer appears in the Cluster folder under any of the remaining
Cisco APICs.

Hardware Diagnostics and Replacement


The Cisco Application Centric Infrastructure (Cisco ACI) fabric employs a combination of key software and
hardware features that are specifically designed to reduce the mean time between failures (MTBF) and the
mean time to repair (MTTR). Regarding hardware, there are several hot-swappable components on both the
leaf and spine switches in addition to a few components that are fixed on the chassis. If ACME ever experiences
some sort of power surge or sees a component of their switches go bad, the hot-swappable components enable
them to replace failed hardware quickly and non-disruptively.

Note The procedures for replacing hardware typically expect the new hardware to be the same as the hardware that
you are replacing.

Examples of hot-swappable components on both the leaf switches and spine switches include:
• Power supplies
• Fan trays

Examples of hot-swappable components on the spines include:


• Power supplies
• Fan trays
• Supervisors
• System Controller cards
• Linecard modules

Despite significant advances in the above components that reduce the MTBF, there is always the possibility
of a failure on a leaf switch either in switch hardware or software, or a combination of the two that necessitates
a leaf switch replacement. In such an event, the stateless nature of the Cisco ACI fabric provides significant
advantages to administrators from an operations standpoint.

Identify Hardware Failure


When a hardware failure occurs in the fabric, faults are raised in the system dashboard and are presented to
the administrator. For cases where there is a component level failure with redundant components present in
the system, syslog messages and SNMP traps are generated.
Examples of hardware events that generate syslog messages and SNMP traps include:
• Linecard failure on a spine switch
• Supervisor failure on a spine switch

Operating Cisco Application Centric Infrastructure


238
Hardware Expansion and Replacement
Resolve Leaf Hardware Failure

• System controller failure on a spine switch


• Power supply or fan failures on a leaf or a spine switch
While Cisco Application Policy Infrastructure Controller (APIC) is a central point of management for the
entire fabric, operations teams can leverage their existing NMS tools. Logging messages can be sent to syslog
servers, such as Splunk, or SNMP messages can be sent to NMS systems, such as ZenOSS, to provide alerting.
The leaf and spine switches in the ACI fabric also support traditional methods of detecting failures, such as
SNMP polling at a set interval. If responses are not received from the switch in a certain timeframe, there is
a possibility that the hardware has failed.
However, while the leaf and spine switches report SNMP and Syslog messages for component level failures,
the APICs themselves do not have the ability to generate alerts using SNMP or syslog. For example a power
supply failure on the APIC will not generate an SNMP or syslog message and must be monitored and remediated
using the APIC dashboard.

Resolve Leaf Hardware Failure


As an example of a leaf failure, a Nexus 9396 leaf switch that is a part of the fabric is unreachable, perhaps
due to a hardware failure on the uplink modules. You can use the GUI to determine the node health to confirm
that the leaf has failed.
To view the node health score:
1. On the menu bar, choose Fabric > Inventory.
2. In the Navigation pane, choose Pod 1.
Note: The pod health displays in the Work pane and is zero.

After confirming that the leaf node has failed, you want to remove the failed switch and provision a new
switch as part of the fabric. The first step in replacing the failed switch is to get the failed switch's unique ID
(node ID). Each node is assigned an ID in the fabric, which is the reference object that allows a replacement
switch with a new serial number to inherit the same stateless configuration that was assigned to the old node.
To view the fabric node IDs using the GUI:
1. On the menu bar, choose Fabric > Inventory.
2. In the Navigation pane, choose Fabric Membership.
You can also use a single REST API call to periodically poll for a full list of nodes that are at or below a
certain health level, as shown in the following example:

{{protocol}}://{{apic}}/api/class/topSystem.xml?rsp-subtree-include=health&rspsubtree-
filter=le(healthInst.cur,"0")

In the case of a traditional operations model where each switch was managed as an independent entity, the
following high-level procedure replaces the switch:
1. Stand up the replacement switch.
2. Load the correct version of code.
3. Attempt to obtain the latest version of configurations from a configuration repository server.
4. Stage the device with the right configuration file and eliminate any errors. For example, update the AAA,
NTP, and syslog servers and the ACLs that are associated with each of them.
5. Copy the old configuration over to the switch.
6. Bring up links one by one and verify if data traffic is flowing correctly.

Operating Cisco Application Centric Infrastructure


239
Hardware Expansion and Replacement
Resolve Leaf Hardware Failure

In an ACI fabric, you can take advantage of the stateless nature of the hardware to instantiate the logical
configuration profiles. Replacing the node is as simple as decommissioning the switch and recommissioning
it.
To decommission and recommission a switch:
1. On the menu bar, choose Fabric > Inventory.
2. In the Navigation pane, expand Pod 1.
3. Right click the failed node and choose Decommission.
4. Replace the failed leaf switch with the new leaf switch.
5. On the menu bar, choose Fabric > Inventory.
6. In the Navigation pane, choose Fabric Membership.
7. The new leaf appears with a node ID of 0 and an IP address of 0.0.0.0.
8. In the Work pane, click on the new leaf.
9. Choose Actions > Commission Switch.
10. When prompted for the node ID, enter the old node's ID. In most cases, you can also reuse the same
leaf name.
11. Click Update.
If the new switch is not operational, the new switch's name and node ID are different from the name and ID
that you entered. You can get the name and ID by viewing the unreachable nodes.
To view the unreachable nodes:
1. On the menu bar, choose Fabric > Inventory.
2. In the Navigation pane, choose Unreachable Nodes.
3. Find the new switch and record its name and node ID.
4. Repeat the "To decommission and recommission a switch" procedure, starting with step 5. When prompted
for the name and node ID, enter the information that you recorded in this procedure.
When the new leaf switch is commissioned successfully, the APIC automatically loads the correct version of
the firmware into the leaf.
To view which version of the firmware that the APIC will load:
1. On the menu bar, choose Admin > Firmware.
2. In the Navigation pane, choose Fabric Node Firmware > Firmware Groups > All.
Note: In the Work pane, you can see the target firmware version, which is automatically set to the latest
firmware version.

In addition, by leveraging the stateless object modeling that replaces the traditional running configuration on
a device, APIC automatically loads the correct running configuration onto the device, such as AAA, syslog,
SNMP, NTP, ACLs, bridge domains, and EPGs.
In the event that the replacement switch runs standalone NX-OS software instead of ACI switch software,
you might need to copy the ACI switch software image to the switch in question.
To copy the ACI switch software image to the switch:
1. Connect to the switch console.
2. Set the IP address on the mgmt0 interface to allow connectivity between the switch and the APIC.
3. Enable SCP services:
# feature scp-server

Operating Cisco Application Centric Infrastructure


240
Hardware Expansion and Replacement
Resolve APIC Hardware Failure

4. Copy the firmware image from APIC to the switch:

# scp -r /firmware/fwrepos/fwrepo/switch_image_name
admin@switch_ip_address :switch_image_name

5. For dual supervisor systems, ensure that images are copied to the standby supervisor in case of a full
chassis replacement by using the command:

# copy bootflash:aci_image bootflash://sup-standby/

6. Configure the switch not to boot from Cisco NX-OS.

switch(config)# no boot nxos

7. Save the configuration.

switch(config)# copy running-config startup-config

8. Boot the active and standby supervisor modules with the ACI image.

switch(config)# boot aci bootflash:aci-image-name

9. Verify the integrity of the file by displaying the MD5 checksum.

switch(config)# show file bootflash:aci-image-name md5sum

10. Reload the switch.

switch(config)# reload

11. Log in to the switch as an administrator.

Login: admin

12. Verify whether you must install certificates for your device.

admin@apic1:aci> openssl asn1parse /securedata/ssl/server.crt

13. Look for PRINTABLESTRING in the command output. If "Cisco Manufacturing CA" is listed, the
correct certificates are installed. If something else is listed, contact TAC to generate and install the
correct certificates for your device.
Once you have confirmed the that certificate is installed and the switch is in ACI mode, the switch should
appear as an unmanaged fabric node when connected to the fabric.

Resolve APIC Hardware Failure


In this example, you must identify and remediate a hardware failure on one of the APICs in your APIC cluster.
From the GUI of an operational APIC:
1. On the menu bar choose System > Controllers.
2. In the Navigation pane, choose Controllers > apic_name > Cluster.
Note: In the Work pane, you should see the failed APIC in the "Unavailable" operational state.

Operating Cisco Application Centric Infrastructure


241
Hardware Expansion and Replacement
Diagnose Equipment Failures

3. Record the fabric name, target size, node ID of the failed APIC, and the TEP address space. This
information is also available through the acidiag avread command on APIC's CLI.
4. In the Work pane, click the failed APIC to select it.
5. Choose Actions > Decommission. The APIC changes to an "Out of Service" admin state.
6. Remove the failed APIC from your rack and install the replacement. The new APIC should boot to the
initial setup script.
7. Proceed through the setup script and enter the values of the failed APIC that you recorded in step 3.
Failure to configure the APIC with the same settings could result in the fabric entering a partially
diverged state.
8. Once the new APIC finishes booting, in the Navigation pane, choose Controllers > apic_name >
Cluster. You can choose any APIC.
9. In the Work pane, click the new APIC to select it.
10. Choose Actions > Commission.
11. The new APIC will receive an IP address, which will be reflected in the APIC GUI. It might take 5 to
10 minutes for this to occur. The new APIC might also cycle between the Available and Unavailable
operational states before becoming Fully Fit.
12. On the command line of the new APIC, you can verify that it has joined the fabric by logging in using
the credentials that are configured for the rest of the fabric.

Diagnose Equipment Failures


The ACI fabric provides bootup, runtime and on-demand diagnostics to help assess the hardware health of
several sub-systems on each leaf and spine switch.
1. Boot-up tests run when switch, card boots up. These are typically ONLY disruptive tests. Comes with
default set of tests that can be modified. Deployed via selectors.
2. Health (aka On-going) tests run periodically. Can only run non-disruptive tests. Comes with default set
of tests that can be modified and are deployed via selectors
3. On-Demand Tests are to be run on specific ports or cards for troubleshooting, there are no defaults, and
they can be disruptive.
By default, tests are logically grouped into collections.
To look at the default diagnostic policies, click Fabric > Fabric Policies > Monitoring Policies > default
> diagnostics policy
In the work pane select the fabric element for which you would like to view the diagnostic monitoring policy.
Test results are viewable by clicking on:
Fabric > Inventory > Pod-1 > Leaf-xx or Spine-xx > Chassis > Supervisor modules > Slot-1
AND
Fabric > Inventory > Pod-1 > Leaf-xx or Spine-xx > Chassis > Line modules > Slot-1
Once there, in the work pane select the Troubleshooting tab to view GOLD diagnostic results for the supervisor.
In a modular chassis-based system such as the Cisco Nexus 9500 series switch, diagnostic results are available
for all the supervisor, modules, system controller and the fabric modules in the system.

Operating Cisco Application Centric Infrastructure


242
Hardware Expansion and Replacement
Guidelines When Replacing a Leaf Switch That is Part of a vPC Pair

Guidelines When Replacing a Leaf Switch That is Part of a vPC Pair


When you replace a leaf switch that is part of a vPC pair, the following guidelines apply:
• Generation 1 switches are compatible only with other generation 1 switches. You can identify these
switch models by the lack of "EX" or "FX" at the end of the switch name. For example, N9K-9312TX.
• Generation 2 and later switches can be mixed together in a vPC domain. These switch models can be
identified with "EX," "FX," or "FX2" at the end of the switch name. For example N9K-93108TC-EX or
N9K-9348GC-FXP.
• When you replace the switch pair, the vPC peer leaf switches must match, and you will have an outage.

The following list provides examples of compatible vPC switch pairs:


• N9K-9312TX and N9K-9312TX
• N9K-93108TC-EX and N9K-9348GC-FXP
• N9K-93180TC-FX and N9K-93180YC-FX
• N9K-93180YC-FX and N9K-93180YC-FX

The following list provides examples of incompatible vPC switch pairs:


• N9K-9312TX and N9K-93108TC-EX
• N9K-9312TX and N9K-93180YC-FX

Alternately, you can change the configuration to break the vPC or introduce the switches as a new vPC pair
and migrate the configuration between the nodes.

Operating Cisco Application Centric Infrastructure


243
Hardware Expansion and Replacement
Guidelines When Replacing a Leaf Switch That is Part of a vPC Pair

Operating Cisco Application Centric Infrastructure


244
APPENDIX A
Appendix
• Classes, on page 245
• Package Decoder, on page 256
• Acronyms and Definitions, on page 261
• Reference Material, on page 278

Classes
The Application Policy Infrastructure Controller (APIC ) classes are crucial from an operational perspective
to understand how system events and faults relate to objects within the object model. Each event and/or fault
in the system is a unique object that can be accessed for configuration, health, fault, and/or statistics.
All the physical and logical components that comprise the Application Centric Infrastructure fabric are
represented in a hierarchical management information tree (MIT). Each node in the tree represents a managed
object (MO) or group of objects that contains its administrative state and its operational state.
The programmatic REST API uses a REST architecture. The API accepts and returns HTTP or HTTPS
messages that contain JSON or XML documents. You can use any programming language to generate the
messages, and the JSON or XML documents that contain the API methods or managed object (MO) descriptions.
You can invoke an API function by sending an HTTP/1.1 or HTTPS POST, GET, or DELETE message to
the APIC. The HTML body of the POST message contains a JSON or XML data structure that describes an
MO or an API method. The HTML body of the response message contains a JSON or XML structure that
contains requested data, confirmation of a requested action, or error information.
To access the complete list of classes, point to the APIC and reference the doc/html directory at the end of
the URL:
https://apic_ip_address/doc/html/

Fabric Monitoring
topSystem
Name: top:System
Description: Provides a list of all the devices within the fabric, including controllers, leafs and spines.
Usage: The topSystem class can be used to derive object properties including inb/oob management details,
current time, system uptime and current state.

Operating Cisco Application Centric Infrastructure


245
Appendix
Appendix

topSystem REST :: https://172.16.96.2/api/node/class/topSystem.json

fabricNode
Name: fabric:Node
Description: Provides a list of all the nodes that are part of the fabric, including controllers, leafs and spines.
Usage: The fabricNode class can be used to derive object properties including node serial numbers, assigned
node ids, node model numbers and device roles.
fabricNode REST :: https://172.16.96.2/api/node/class/fabricNode.json

faultInst
Name: fault:Inst
Description: Contains detailed information of the fault. This object is attached as a child of the object on which
the fault condition occurred. One instance object is created for each fault condition of the parent object. A
fault instance object is identified by a fault code.
Usage: The faultInst class can be used to derive all faults associated with the fabric, tenant or individual
managed objects within the APIC.
faultInst REST :: https://172.16.96.2/api/node/class/faultInst.json

fabricHealthTotal
Name: fabric:HealthTotal
Description: The fabric total health score instance.
Usage: The fabricHealthTotal class can be used to derive the overall system health.
fabricHealthTotal REST :: https://172.16.96.2/api/node/class/fabricHealthTotal.json

fvCEp
Name: fv:CEp
Description: A client endpoint attaching to the network.
Usage: The fvCEp class can be used to derive a list of end points attached to the fabric and the associated
ip/mac address and encapsulation for each object.
fvCEp REST :: https://172.16.96.2/api/node/class/fvCEp.json

fvRsCEpToPathEp
Name: fv:RsCEpToPathEp
Description: This is an internal object that provides a relation to a path endpoint.
Usage: The fvRsCEpToPathEp class can be used to derive path fabric details such as the node and port as
well as the tenant details such as the tenant name, application profile and end point group.
fvRsCEpToPathEp REST :: https://172.16.96.2/api/node/class/fvRsCEpToPathEp.json

eqptFabP
Name: eqpt:FabP

Operating Cisco Application Centric Infrastructure


246
Appendix
Appendix

Description: Fabric port, the fabric facing external IO port.


Usage: The eqptFabP class can be used to derive a list of fabric port and the associated details such as the line
card and chassis placement.
eqptFabP REST :: https://172.16.96.2/api/node/class/eqptFabP.json

eqptLeafP
Name: eqpt:LeafP
Description: Fabric port, the non-fabric facing external leaf IO port.
Usage: The eqptFabP class can be used to derive a list of non-fabric port and the associated details such as
the line card and chassis placement.
eqptLeafP REST :: https://172.16.96.2/api/node/class/eqptLeafP.json

eqptCh
Name: eqpt:ChA
Description: The hardware chassis container.
Usage: The eqptCh class can be used to derive a chassis list and the associated details such as the operational
state, serial number and model number.
eqptCh REST :: https://172.16.96.2/api/node/class/eqptCh.json

eqptLC
Name: eqpt:LCA
Description: The line card (IO card), containing IO ports.
Usage: The eqptLC class can be used to derive a list of line cards deployed within the fabric and the associated
details such as the redundancy state, model, serial numbers and the number of ports.
eqptLC REST :: https://172.16.96.2/api/node/class/eqptLC.json

eqptFt
Name: eqpt:Ft
Description: The inventoried fan tray.
Usage: The eqptFt class can be used to derive a list of fan trays and the associated details such as the operational
status, model number, serial number and hardware version.
eqptFt REST :: https://172.16.96.2/api/node/class/eqptFt.json

eqptPsu
Name: eqpt:Psu
Description: The power supply unit.
Usage: The eqptFt class can be used to derive a list of power supplies within the fabric and the associated
details such as the model number, serial number, operational status, and the voltage source.
eqptPsu REST :: https://172.16.96.2/api/node/class/eqptPsu.json

Operating Cisco Application Centric Infrastructure


247
Appendix
VM_Monitoring

eqptSupC
Name: eqpt:SupC
Description: The supervisor card, which contains the CPU running control plane.
Usage: The eqptFt class can be used to derive a list of supervisor cards deployed within the fabric and the
associated details such as the model number, serial number, operational status and redundancy state.
eqptSupC REST :: https://172.16.96.2/api/node/class/eqptSupC.json

ethpmPhysIf
Name: ethpm:PhysIf
Description: The physical interface information holder.
Usage: The ethpmPhysIf class can be used to derive a list of physical interfaces in the fabric and the associated
details such as a the speed, duplex, operational status, and usage state.
ethpmPhysIf REST :: https://172.16.96.2/api/node/class/ethpmPhysIf.json

dbgAcTrail
Name: dbg:AcTrail
Description: The atomic counter trail.
Usage: The dbgAcTrail class can be used to derive a list of the atomic counters deployed within the fabric
and the associated details such as dropped packet statistics and packet counts.
dbgAcTrail REST :: https://172.16.96.2/api/node/class/dbgAcTrail.json

dbgEpgToEpgRslt
Name: dbg:EpgToEpgRslt
Description: The endpoint group to endpoint group atomic counter, on-demand, entry.
Usage: The dbgEpgToEpgRsIt class can be used to derive a list of the EPG to EPG atomic counters deployed
within the fabric, and the associated details such as dropped packet statistics and packet counts.
dbgEpgToEpgRsIt REST :: https://172.16.96.2/api/node/class/dbgEpgToEpgRslt.json

dbgEpToEpRslt
Name: dbg:EpToEpRslt
Description: The endpoint to endpoint atomic counter, On-demand, Entry.
Usage: The dbgEpToEpTsIt class can be used to derive a list of the endpoint to endpoint atomic counters
deployed within the fabric and the associated details such as dropped packet statistics and packet counts.
dbgEpToEpTsIt REST :: https://172.16.96.2/api/node/class/dbgEpToEpRslt.json

VM_Monitoring
compVm
Name: comp:Vm

Operating Cisco Application Centric Infrastructure


248
Appendix
Layer 4 to Layer 7 Monitoring

Description: The Virtual machine object.


Usage: The compVm class can be used to derive a list of virtual machines deployed within the fabric and the
associated details such as the name and state.
compVm REST :: https://172.16.96.2/api/node/class/compVm.json

compHv
Name: comp:Hv
Description: An object representing the compute hypervisor.
Usage: The compVm class can be used to derive a list of compute hypervisor deployed within the fabric and
the associated details such as the name and status.
compHv REST :: https://172.16.96.2/api/node/class/compHv.json

fvRsVm
Name: fv:RsVm
Description: A relation to a virtual machine connected to a hypervisor. This is an internal object.
Usage: The fvRsVm class can be used to derive the relationship of the virtual machines connected to the
hypervisor.
vRsVm REST :: https://172.16.96.2/api/node/class/fvRsVm.json

fvRsHyper
Name: fv:RsHyper
Description: A relation to the hypervisor that controls and monitors the APIC VMs. This is an internal object.
Usage: The fvRsHyper class can be used to derive the relationship of the hypervisor that controls and monitors
the APIC VMs.
fvRsHyper REST :: https://172.16.96.2/api/node/class/fvRsHyper.json

vmmCtrlrP
Name: vmm:CtrlrP
Description: The VMM controller profile, which specifies how to connect to a single VM management
controller that is part of containing policy enforcement domain. For example, the VMM controller profile
could be a policy to connect a VMware vCenter that is part a VMM domain.
Usage: The vmmCtrlrP class can be used to derive the ip address and the datacenter name of the connected
VM domain.
vmmCtrlrP REST :: https://172.16.96.2/api/node/class/vmmCtrlrP.json

Layer 4 to Layer 7 Monitoring


vnsAbsGraph
Name: vnsAbsGraph

Operating Cisco Application Centric Infrastructure


249
Appendix
Appendix

Description: The abstract graph is made up of abstract nodes and used to define the traffic flow through a
service function such as load balancing, SSL offload, or firewall. Abstract nodes are comprised of service
nodes such as a service node balancer (SLB) or firewall (FW), abstract term nodes (the nodes that are connected
to endpoint groups), and connections.
Usage: The class vnsAbsGraph can be used to derive a list of service graph templates configured on the APIC,
along with their properties.
vnsAbsGraph REST :: https://172.16.96.2/api/node/class/vnsAbsGraph.json

vnsLDevVip
Name: vnsLDevVip
Description: An L4-L7 device cluster, which is represented by a single virtual IP (VIP). The configuration is
pushed down to the VIP address.
Usage: The class vnsLDevVip can be used to derive all the VIPs configured for the logical device clusters in
the fabric
vnsLDevVip REST :: https://172.16.96.2/api/node/class/vnsLDevVip.json

vnsCDev
Name: vnsCDev
Description: The individual service device, which is used to define a concrete l4-l7 service device.
Usage: The class vnsCDev can be used to derive a list of concrete devices configured as part of the L4-7
service integration
vnsCDev REST :: https://172.16.96.2/api/node/class/vnsCDev.json

vnsLif
Name: vnsLif
Description: The logical interface, which is associated with a set of concrete interfaces from the L4-L7 device
cluster.
Usage: The class vnsLif can be used to derive the connection between a service graph and device interfaces.
vnsLif REST :: https://172.16.96.2/api/node/class/vnsLIf.json

vnsLDevCtx
Name: vnsLDevCtx
Description: A device cluster context, which points to the device cluster used to pick a specific device based
on contract, subject, and function label or names. To specify a wild card, set the name to Any.
Usage: The class vnsLDevCtx can be used to derive the node and contract name.
nsLDevCtx REST :: https://172.16.96.2/api/node/class/vnsLDevCtx.json

vnsRsLDevCtxToLDev
Name: vnsRsLDevCtxToLDev
Description: A source relation to the abstraction of a service device cluster or of a proxy object for a logical
device cluster in the tenant.

Operating Cisco Application Centric Infrastructure


250
Appendix
Statistics

Usage: The class vnsRsLDevCtxToLDev can be used to derive the relationship between vnsLDevCtx and
vnsLDev.
vnsRsLDevCtxToLDev REST :: https://172.16.96.2/api/node/class/vnsRsLDevCtxToLDev.json

Statistics
compHostStats1h
Name: comp:HostStats1h
Description: A class that represents the most current statistics for host in a 1 hour sampling interval. This class
updates every 15 minutes.
Usage: The compHostStats1h class can be used to derive the statistics associated with the compute hypervisor.
compHostStats1h REST :: https://172.16.96.2/api/node/class/compHostStats1h.json

compRcvdErrPkts1h
Name: comp:RcvdErrPkts1h
Description: A class that represents the most current statistics for received error packets in a 1 hour sampling
interval. This class updates every 15 minutes.
Usage: The compRcvdErrPkts1h class can be used to derive the most current statistics for received error
packets.
compRcvdErrPkts1h REST :: https://172.16.96.2/api/node/class/compRcvdErrPkts1h.json

compTrnsmtdErrPkts1h
Name: comp:TrnsmtdErrPkts1h
Description: A class that represents the most current statistics for transmitted error packets in a 1 hour sampling
interval. This class updates every 15 minutes.
Usage: The compTrnsmtdErrPkts1h class can be used to derive the most current statistics for transmitted error
packets.
compTrnsmtdErrPkts1h REST :: https://172.16.96.2/api/node/class/compTrnsmtdErrPkts1h.json

Authentication, Authorization, and Accounting


aaaModLR
Name: aaa:ModLR
Description: The AAA audit log record. A log record is automatically generated whenever a user modifies
an object.
Usage: The aaaModLR class can be used to derive a fabric based audit log for all changes and events.
aaaModLR REST :: https://172.16.96.2/api/node/class/aaaModLR.json

Operating Cisco Application Centric Infrastructure


251
Appendix
Fabric Capacity

aaaUser
Name: aaa:User
Description: A locally-authenticated user account.
Usage: The aaaUser class can be used to derive a list of user accounts deployed within the fabric.
aaaUser REST :: https://172.16.96.2/api/node/class/aaaUser.json

aaaRemoteUser
Name: aaa:RemoteUser
Description: A remote user login account.
Usage: The aaaUser class can be used to derive a list of remote user accounts deployed within the fabric.
aaaRemoteUser REST :: https://172.16.96.2/api/node/class/aaaRemoteUser.json

Fabric Capacity
Policy TCAM
Name: eqptcapacityPolEntry5min
Description: Policy CAM entry statistics. A class that represents the most current statistics for policy entry
in a 5 minute sampling interval. This class updates every 10 seconds.
Usage: The eqptcapacityPolEntry5min class can be used to derive the current value associated with the Policy
TCAM usage.
eqptcapacityPolEntry5min REST :: https://172.16.96.2/api/class/eqptcapacityPolEntry5min.json

Prefix TCAM
Name: eqptcapacityL3Entry5min
Description: Layer3 entry statistics. A class that represents the most current statistics for layer3 entry in a 5
minute sampling interval. This class updates every 10 seconds.
Usage: The eqptcapacityL3Entry5min class can be used to derive the current value associated with the Prefix
TCAM usage.
eqptcapacityL3Entry5min REST :: https://172.16.96.2/api/class/eqptcapacityL3Entry5min.json

SNMP and Syslog


SNMP Trap Destination
Name: snmpTrapDest
Description: "background-color:rgb(255, 255, 255); color:rgb(51, 51, 51)">A destination to which traps and
informs are sent.
Usage: The snmpTrapDest class can be used to derive the current list of snmp trap destinations implemented
within the fabric.

Operating Cisco Application Centric Infrastructure


252
Appendix
Use Cases

snmpTrapDest REST :: https://172.16.96.2/api/node/class/snmpTrapDest.json

Syslog Remote Destination Host


Name: syslogRemoteDest
Description: The syslog remote destination host enables you to specify syslog servers to which messages from
the APIC and fabric nodes should be forwarded.
Usage: The syslogRemoteDest class can be used to derive the current list of syslog remote destinations
implemented within the fabric.
syslogRemoteDest REST :: https://172.16.96.2/api/node/class/syslogRemoteDest.json

Use Cases
The class faultInst used in Use Case #1 and Use Case #2 below can be replaced with any of the managed
object classses discussed above or specified within the APIC documentation. The Cisco APIC Command-Line
Interface User Guide may also be helpful for understanding the following sections.

Case 1: Creating an application script to retrieve the current list of faults in the fabric.
This use case may be typical for environments where an ACI administrator wishes to obtain the list of current
faults in the fabric. The user has the option of collecting the results via CLI, Visore, POSTMAN and/or Cobra.
Please refer to the section above for application specific access and explantions.
From a CLI perspective, use the following command to perform the query:
admin@apic1:~> moquery -c faultInst

From a Visore perspective, use the following parameters to perform the query.:

Class or DN :: faultInst
Property :: n/a
Op :: n/a
Value :: n/a

From a POSTMAN perspective, user the following REST GET to perform the query:
GET http://<your apic ip address>/api/node/class/faultInst.xml

From a Cobra perspective, use the following class query:

# Class Query
classQuery= ClassQuery(' faultInst')
for fault in md.query(classQuery):
print fault.name

Sample Cobra script to capture faults within the fabric:

#!/usr/bin/env python
import cobra.mit.access
import cobra.mit.session
from cobra.mit.session import LoginSession
from cobra.mit.request import ClassQuery
ls = cobra.mit.session.LoginSession('https://'<your apic ip address>, <username>,
<password>, secure=False)
md = cobra.mit.access.MoDirectory(ls)

Operating Cisco Application Centric Infrastructure


253
Appendix
Appendix

md.login()
# Class Query
classQuery= ClassQuery(' faultInst')
for fault in md.query(classQuery):
print fault.name

Case 2: Creating an application script to retrieve the current list of faults in the fabric that have been caused
by a failed configuration.
This use case may be typical for environments where an ACI administrator wishes to cobtain the list of current
faults in the fabric. The user has an option of collecting the results via CLI, Visore, POSTMAN and/or Cobra.
Please refer to the section above for application specific access and explantions.
From a CLI perspective, use the following command to perform the query:
admin@apic1:~> moquery -c faultInst -f 'fv.faultInst.cause=="config-failure"'

From a Visore perspective, use the following parameters to perform the query:

Class or DN :: faultInst
Property :: cause
Op :: ==
Value :: config-failure

From a POSTMAN perspective, use the following REST GET to perform the query:
GET http:// <your apic ip address>/api/node/class/faultInst.xml?
query-target-filter=and(eq(faultInst.cause,"config-failure"))

From a Cobra perspective, use the following class query:

# Class Query
classQuery= ClassQuery(' faultInst')
classQuery.propFilter = 'wcard(faultInst. cause, "{0}")'.format(' config-failure')
for fault in md.query(classQuery):
print fault.name

Cobra Script to capture faults casued by configuration failures.

#!/usr/bin/env python
import cobra.mit.access
import cobra.mit.session
from cobra.mit.session import LoginSession
from cobra.mit.request import ClassQuery
ls = cobra.mit.session.LoginSession('https://'<your apic ip address>, <username>,
<password>, secure=False)
md = cobra.mit.access.MoDirectory(ls)
md.login()
# Class Query
classQuery= ClassQuery(' faultInst')
for fault in md.query(classQuery):
print fault.name

Case 3: Creating an application script to retrieve the properties for a specific managed object, DN
This use case may be typical for environments where an ACI administrator wishes to obtain the properties of
the tenant name Common. The user has an option of collecting the results via CLI, Visore, POSTMAN and/or
Cobra. Please refer to the section above for application specific access and explantions.

Operating Cisco Application Centric Infrastructure


254
Appendix
Appendix

From a CLI perspective, use the following command to perform the query:
admin@apic1:~> moquery -d uni/tn-common

From a Visore perspective, use the following parameters to perform the query:

Class or DN :: uni/tn-common
Property :: n/a
Op :: n/a
Value :: n/a

From a POSTMAN perspective, use the following REST GET to perform the query:
GET http://<your apic ip address>/api/node/mo/uni/tn-common.xml?query-target=self

From a Cobra perspective, use the following class query:

# DN Query
dnQuery= DnQuery(' uni/tn-common')
for results in md.query(dnQuery):
print results.dn

Cobra Script to capture faults casued by configuration failures.

#!/usr/bin/env python
import cobra.mit.access
import cobra.mit.session
from cobra.mit.session import LoginSession
from cobra.mit.request import DnQuery
ls = cobra.mit.session.LoginSession('https://'<your apic ip address>, <username>,
<password>, secure=False)
md = cobra.mit.access.MoDirectory(ls)
md.login()
# DN Query
dnQuery= DnQuery('uni/tn-common')
for results in md.query(dnQuery):
print results.dn

Case 4: Creating an application script to retrieve the current list of endpoints (mac-addresses) attached to
the fabric
This use case may be typical for environments where an ACI administrator wishes to create an application
script to capture the list of current endpoints attached to the fabric along with the node details pertaining to
each endpoint.
Cobra Script to capture faults caused by configuration failures.

#!/usr/bin/env python
from cobra.mit.access import MoDirectory
from cobra.mit.session import LoginSession
from cobra.mit.request import ClassQuery
lls = cobra.mit.session.LoginSession('https://'<your apic ip address>, <username>,
<password>, secure=False)
md = MoDirectory(ls)
md.login()
q = ClassQuery('fvCEp')
q.subtree = 'children'
q.subtreeClassFilter = 'fvRsCEpToPathEp'
mos = md.query(q)
for mo in mos:

Operating Cisco Application Centric Infrastructure


255
Appendix
Package Decoder

for child in mo.rscEpToPathEp:


print child.dn

Package Decoder
There are several abbreviations used in the names of classes in the ACI object model. Here are some descriptions
of commonly used abbreviations, which may help when deciphering what class objects are when using them
with REST calls.
aaa: authentication, authorization, accounting
ac: atomic counters
actrl: access control
actrlcap: access control capability
adcom: appliance director communication
aib: adjacency information base
arp: address resolution protocol
bgp: border gateway protocol
callhome: Cisco smart call home services
cap: capability
cdp: Cisco discovery protocol
cnw: node cluster
comm: communication policy
comp: compute
compat: compatibility
condition: health policy
config: configuration policy
coop: Council of Oracles protocol
copp: control plane policing policy: contains set of rules describing policer rates
ctrlr: controller
ctx: context
datetime: date/time policy
dbg: debug
dbgac: debug atomic counters
dbgexp: debug export policy
dhcp: dynamic host configuration protocol
dhcptlv: dynamic host configuration protocol type length value
dhcptlvpol: dynamic host configuration protocol type length value policy

Operating Cisco Application Centric Infrastructure


256
Appendix
Appendix

dns: domain name service


draw: graph visualization for GUI
epm: endpoint manager
eqpt: equipment
eqptcap: equipment capability
eqptcapacity: equipment capacity
eqptdiag: equipment diagnostics
eqptdiagp: equipment diagnostics policy
ethpm: ethernet policy manager
event: event policy
extnw: external network
fabric: fabric
fault: fault policy, counters
file: file path, config import/export policy
firmware: firmware
fmcast: fabric multicast
fsm: finite state machine
fv: fabric virtualization
fvns: fabric virtualization namespace
fvtopo: fabric virtualization topology
geo: geolocation
glean: glean adjacency
ha: high availability
health: health score
hvs: hypervisors virtual switch
icmp: internet control protocol
icmpv4: internet control protocol version 4
icmpv6: internet control protocol version 6
ident: identity
igmp: internet group management protocol
igmpsnoop: internet group management protocol snooping
im: interface manager module
imginstall: image install
infra: infrastructure

Operating Cisco Application Centric Infrastructure


257
Appendix
Appendix

ip: internet protocol


ipv4: internet protocol version 4
ipv6: internet protocol version 6
isis: intermediate system to intermediate system
isistlv: intermediate system to intermediate system type length value
l1: layer 1
l1cap: layer 1 capability
l2: layer 2
l2cap: layer 2 capability
l2ext: layer 2 external
l3: layer 3
l3cap: layer 3 capability
l3ext: layer 3 external
l3vm: Layer 3 Virtual Machine
lacp: link aggregation protocol
lbp: load balancing policy
leqpt: loose equipment (unmanaged nodes, not in the fabric)
lldp: link layer discovery protocol
lldptlv: link layer discovery protocol type length value
lldptlvpol: link layer discovery protocol type length value policy
maint: maintenance
mcast: multicast
mcp: master control processor
memory: memory statistics
mgmt: management
mo: managed object
mock: mock (objects used on the simulator mostly for showing stats/faults/etc)
mon: monitoring
monitor: monitor (SPAN)
naming: abstract for objects with names
nd: neighbor discovery
nw: network
oam: ethernet operations, administrations and management
observer: observer for statistics, fault, state, health, logs/history

Operating Cisco Application Centric Infrastructure


258
Appendix
Appendix

opflex: OpFlex
os: operating system
ospf: open shortest path first
pc: port channel
pcons: **generated and used by internal processes**
phys: physical domain profile
ping: ping execution and results
pki: public key infrastructure
pol: policy definition
policer: traffic policing (rate limiting)
pool: object pool
pres: **generated and used by internal processes**
proc: system load, cpu, and memory utilization statistics
psu: power supply unit policy
qos: quality of service policy
qosm: qos statistics
qosp: qos/ 802.1p
rbqm: debugging
regress: regression
reln: **generated and used by internal processes**
repl: **generated and used by internal processes**
res: **generated and used by internal processes**
rib: routing information base
rmon: remote network monitoring/ interface stats/counters
rpm: route policy map
rtcom: route control community list
rtctrl: route control
rtextcom: router extended community
rtflt: route filter
rtleak: route leak
rtmap: RPM route map
rtpfx: route prefix list
rtregcom: route regular community list
rtsum: route summarization address/policy

Operating Cisco Application Centric Infrastructure


259
Appendix
Appendix

satm: satellite manager


snmp: simple network management protocol
span: switched port analyzer
stats: statistics collection policies
statstore: statistics data holders
stormctrl: storm control (traffic suppression) policy
stp: spanning tree protocol definitions and policy
sts: Service Tag Switching (used for services insertion)
svccore: core policy
svi: switched virtual interface/ routed VLAN interface
synthetic: synthetic objects (for testing)
sysdebug: system debug
sysfile: system files
syshist: system cards reset records/history
syslog: syslog policy
sysmgr: system manager (firmware, supervisor, system states, etc)
sysmgrp: container for cores policy & abstract class for all qos policy definitions
tag: alias (use descriptive name for dn), tags (group multiple objects by a descriptive name)
task: task execution, instance, and result
test: abstract class for test rule, subject, and result
testinfralab: test infrastructure
tlv: type, length, value system structures
top: system task manager for processor activity
topoctrl: topology control policy (sharding, fabric LB, fabric VxLan, etc)
traceroute: traceroute execution and results
traceroutep: traceroute end points
trig: triggering policy
tunnel: tunneling
uribv4: ipv4 unicast routing information base entity
vlan: vlan instances
vlanmgr: vlan manager control plane
vmm: virtual macine manager (controller, vmm policy and definitions)
vns: virtual network service (L4-L7 policy and definitions)
vpc: virtual port channel (vpc policy and definitions)

Operating Cisco Application Centric Infrastructure


260
Appendix
Acronyms and Definitions

vsvc: service labels (provider/consumer)


vtap: translated address of external node (NATed IP of service node)
vxlan: Virtually extensible LAN definitions
vz: virtual zones (former name of the policy controls) i.e. Contracts

Model Naming Schemes


Rs: Relationship source
Rt: Relationship target
Ag: Aggregated stats
BrCP: Binary Contract Profile

Acronyms and Definitions


This section is designed to provide a high level description of terms and concepts that get brought up in this
book. While ACI does not change how packets are transmitted on a wire, there are some new terms and
concepts employed, and understanding those new terms and concepts will help those working on ACI
communicate with one another about the constructs used in ACI to transmit those bits. Associated new
acronyms are also provided.
This is not meant to be an exhaustive list nor a completely detailed dictionary of all of the terms and concepts,
only the key ones that may not be a part of the common vernacular, or which would be relevant to the
troubleshooting exercises that were covered in the troubleshooting scenarios discussed.
AAA
Acronym for Authentication, Authorization, and Accounting.
Access Encapsulation
Since EPGs follows the "VLAN as an EPG" model, having multiple EPGs out a single port on a Leaf
switch creates issues. When selecting which encapsulation type will be operating on the port, you must
know if any other EPGs will be accessible through the port that your EPG is on. The port can have 3
different modes:
• Tagged (default)—Select this mode if the traffic from the host is tagged with a VLAN ID. This tags
all packets with an 802.1Q header leaving the port, including VLAN 0, and allows the user to add
multiple EPGs to connect to the port without deciding which EPG will be using a native (untagged)
VLAN.
• Untagged—Select this mode if the traffic from the host is untagged (without VLAN ID or 802.1Q
header). This requires that any endpoints in your EPG not come in on a port with any other endpoints
from another EPG.
• 802.1P—Select this mode if the traffic from the host is tagged with an 802.1P tag. This allows
multiple EPGs to come in on a single port while allowing a single EPG to not 802.1Q tag their
traffic.

Operating Cisco Application Centric Infrastructure


261
Appendix
Appendix

ACI External Connectivity


Any connectivity to and from the fabric that uses an external routed or switched intermediary system,
where endpoints fall outside of the managed scope of the fabric.
ACID transactions
ACID is an acronym for Atomicity, Consistency, Isolation, Durability - properties of transactions that
ensure consistency in database transactions. Transactions to APIC devices in an ACI cluster are considered
ACID, to ensure that database consistency is maintained. This means that if one part of a transaction
fails the entire transaction fails.
Action
Action to be taken on the filtered traffic. For example, Permit, Deny, Log, and Mark. The following
actions are supported:
• Permit the traffic [Regular Contracts Only]
• Mark the traffic (DSCP/CoS) [Regular Contract Only]
• Redirect the traffic [Regular Contract Only via Service Graph]
• Copy the traffic [Regular Contract Only via Service Graph, SPAN]
• Block the traffic [Taboo Contracts Only]

Log the traffic


[Taboo Contracts Only]
ALE
ACI Leaf Engine.
Anycast Gateway
Provides the same gateway IP address on each leaf switch where an endpoint resides if "Unicast Routing"
is checked. A pervasive SVI provides a distributed default gateway across all leaf switches. Allows all
off subnet packets to be routed directly from the originating leaf switch.
APIC
Application Policy Infrastructure Controller is a centralized policy management controller cluster. The
APIC configures the intended state of the policy to the fabric. Originally called the Insieme Fabric
Controller (IFC).
API
Application Programming Interface used for programmable extensibility.
Application-Centric Virtual Switch (AVS)
Originally a Nexus 1000 reprogrammed to work with ACI and VXLAN.
Application Profile
Term used to reference an application profile-managed object reference that models the logical components
of an application and how those components communicate. The application profile is the key object used
to represent an application and is also the anchor point for the automated infrastructure management in
an ACI fabric.

Operating Cisco Application Centric Infrastructure


262
Appendix
Appendix

In a simplified way, application profiles are a collection of different endpoint groups and the policies
needed to communicate between them. Each Application Profile may contain one or more Application
endpoint groups. At the application profile level, you set the QoS classification for the Applications
endpoint groups defined under it. At the Application endpoint group level, you define the bridge domain.
The bridge domain under Networks links to the VRF.
ASE
ACI Spine Engine.
Atomic Counters
Atomic counters detect drops and misrouting in the fabric, which enables quick debugging and isolation
of application connectivity issues. Use of atomic counters is not supported when the endpoints are in
different tenants or in different contexts (VRFs) within the same tenant.
Attachable Entity Profile (AEP)
This is a configuration profile of the interface that gets applied when an entity attaches to the fabric. An
AEP represents a group of external entities with similar infrastructure policy requirements. AEPs are
also the mechanism that ties the physical port to the domain (physical or virtual) to a switch policy. The
AEP links the domain (which links the VLAN from the VLAN pool) to the switch port policy group
(configuration) in the MIT. The second use of the AEP is it allows the tenant to access VMM policies
that were configured by the administrator without direct access.
AV
Appliance vector.
BD-VLAN
BD-VLAN is used to represent a bridge domain and can link multiple FD-VLANs (encap VLANs)
together with multiple hardware VLANs and internal VLANs. It is one forwarding aspect used by the
broadcom ASIC to determine if traffic should be locally switched or forwarded to the Northstar ASIC
for processing. The BD-VLAN connects different local FD-VLANs to a single bridge domain, and is
used on the Broadcom ASIC to determine the layer 2 broadcast domain which might contain multiple
subnets or ACCESS_ENC.
Bounce Entry
When an Endpoint moves to a different leaf switch, the leaf switch which previously had the endpoint
will install a bounce entry to ensure that any traffic in transit at the time the endpoint moved continues
on towards the endpoint in its new location. This occurs when a leaf forwards a packet directly to another
leaf but that EP has moved to another leaf. The middle leaf will bounce the packet to the new leaf where
the endpoint actually resides.
Bridge Domain (BD)
An ACI construct that defines Layer 2 forwarding behaviors (Broadcast, ARP flooding, etc.) for each
unique Layer 2 forwarding domain (flood domain). Bridge domains are also a container for IP subnets
and are where fabric Layer 3 gateway functionality is configured. Bridge domains can emulate the
behavior of a traditional VLAN but are not constrained by forwarding scale limitations. In the ACI object
model, a bridge domain is a child of a Private Layer 3 or context. Endpoint groups can only be a member
of a single bridge domain. MAC addresses MUST BE unique per bridge domain (across subnets).
CLOS fabric
A multi-tier nonblocking leaf-spine architecture network.

Operating Cisco Application Centric Infrastructure


263
Appendix
Appendix

Cluster
Set of devices that work together as a single system to provide an identical or similar set of functions. It
can be a set of APICs communicating to provide a scalable, distributed controller. The cluster size is
used in the sharing of the MIT database. A cluster is a set of appliances running controller applications
and communicating with each other forming a single logical view to the fabric.
Concrete Model
The concrete model is rendered by logic running on the APIC and the policy element running on the
switch. The concrete model is used by the switch's software to orchestrate programming of the switch
data plane for services. It contains configuration as well as operational managed objects. This model is
also user-visible, but is not configurable.
Consumer
The consumer is the "sender" of the traffic in the contract. When an EPG consumes a contact, all endpoints
in the consuming EPG may initiate communication with any endpoint in any EPG that is providing that
contract.
Context
A Layer 3 forwarding domain, equivalent to a VRF, and in ACI vernacular a Private Layer 3.
Contract
A logical container for the subjects which relate to the filters that govern the rules for communication
between endpoint groups. ACI works on a white list policy model. Without a contract, the default
forwarding policy is to not allow any communication between endpoint groups, but communication
within an endpoint group is allowed.
Contract Scope
The contract scope is the level of enforcement of the contract between two or more EPGs. The states
are:
• Application Profile—Endpoint groups can only communicate with other endpoint groups that are
located within the same application profile (AEP).
• Private Network (default)—Endpoint groups can only communicate with other endpoint groups
located within the same private network (VRF).
• Tenant—Endpoint groups can only communicate with other endpoint groups located within the
same tenant.
• Global—Endpoint groups can communicate with other endpoint groups located throughout the
fabric.

The contract scope essentially restricts which hosts can communicate with the EPG whether they are
within the same application profile, within the same VRF (Private Network), within the same Tenant,
or anywhere in the fabric.
Council of Oracles Protocol (COOP)
COOP is used to communicate the mapping information (location and identity) to the spine proxy. An
iLeaf will forward endpoint address information to spine 'Oracle' using ZeroMQ (Zero Message Queue).
COOP running on the spine nodes will ensure all spine nodes maintain a consistent copy of end point
address and location information and additional maintain the DHT repository of endpoint identity to
location mapping database.

Operating Cisco Application Centric Infrastructure


264
Appendix
Appendix

Data Management Engine (DME)


A service that runs on the APIC that manages data for the data model. DMEs communicate using message
entities called "stimulus", which usually have a request and response. Each service on the APIC or switch
is built over a library or framework called DME.
DLB
Dynamic Load Balancing - a network traffic load-balancing mechanism in the ACI fabric based on
flowlet switching.
dMIT
distributed Management Information Tree, a representation of the ACI object model with the root of the
tree at the top and the leaves of the tree at the bottom. The tree contains all aspects of the object model
that represent an ACI fabric.
Dn
Distinguished name - a unique fully qualified name that represents a specific managed object within the
ACI management information tree (MIT) as well as the specific location information in the tree. It is
made up of a concatenation of all of the relative names from itself back to the root of the tree. As an
example, if policy object of type Application Profile is created, named commerce workspace within a
Tenant named Prod, the dn would be expressed as uni/tn-Prod/ap-commerceworkspace.
Encap
The encapsulation (VLAN or VXLAN) of the virtual machine manager (VMM) for the associated
endpoint group. This is the VLAN assigned to the endpoint group that the attached endpoint is in.
Endpoint (EP)
Also called a host or Layer 2/Layer 3 addressable entity. Any logical or physical device connected directly
or indirectly to a port on a leaf switch that is not a fabric facing port. Endpoints have specific properties
such as an address or location, which is used to identify the endpoint. All addressable MAC entities
(virtual NIC interfaces, physical NIC interfaces, switch CPU interfaces, and so on) are considered
endpoints. Endpoints are grouped together into endpoint groups.
Endpoint Group (EPG)
A collection of endpoints that can be grouped based on common requirements for a common policy or
requiring the same policy treatment. Endpoint groups can be dynamic or static. The ACI fabric commonly
uses an 802.1Q VLAN tag to represent the endpoint group. This is often referred to as the "VLAN as an
EPG" model. The following types of endpoint groups are defined:
• Application endpoint group (fvAEPg)
• Layer 2 external outside network instance endpoint group (L2extinstP)
• Layer 3 external outside network instance endpoint group (L3extinstP)
• Management endpoint groups for out-of-band (mgmtOoB) or in-band (mgmtInB) access

Endpoint group membership is defined in the fabric by:


• Ingress physical port (leaf or FEX)
• Ingress logical port (VM port group)
• VLAN ID

Operating Cisco Application Centric Infrastructure


265
Appendix
Appendix

• VXLAN (VNID)
• IP address (only applicable to external/border leaf connectivity at FCS)
• IP prefix/subnet (only applicable to external/border leaf connectivity at FCS)

Policies only apply to endpoint groups, never to individual endpoints. An endpoint group can be statically
configured by an administrator in the APIC, or dynamically configured by an automated system such as
vCenter or OpenStack.
An endpoint group is associated with the following things:
• A single Layer 2 virtual network (bridge group) or a single Layer 3 virtual network (VRF or private
network)
• A single security group (contracts)

Error
Errors occur only on the APIC. They describe events where there are duplicate MOs or errors reaching
a radius server.
Ethertype
The EtherType of the filter entry. The current EtherTypes are:
• Unspecified [default] (all protocols)
• ipv4
• ipv6
• lldp
• 8021ad
• 8021q
• arp
• fcoe
• flow_control
• mac_ or VMMrity
• mpls_mcast
• mpls_ucast
• ptp
• qinq
• rarp
• slow_protocols
• trill
• wake_on_lan

Operating Cisco Application Centric Infrastructure


266
Appendix
Appendix

Event
Events are not errors nor faults. They indicate step-by-step information as something occurs. For example,
as an interface comes up, it provides events indicating what is occurring while the interface comes up.
Event records are never modified after creation and are deleted only when their number exceeds the
maximum value specified in the event retention policy.
Fault
When a failure occurs or an alarm is raised, the system creates a fault-managed object for the fault. A
fault contains the conditions, information about the operational state of the affected object and potential
resolutions for the problem. Faults are errors that are produced on the APIC, fabric, and hosts.
Fabric
The collective endpoints associated with an ACI solution (Leaf, Spine and Virtual Switches plus APICs).
The fabric decouples the tenant end-point address, it's "identifier", from the location of that end-point
which is defined by it's "locator" or VTEP address. Forwarding within the Fabric is between VTEPs
(ACI VXLAN tunnel endpoints) and leverages an extender VXLAN header format referred to as the
ACI VXLAN policy header. The mapping of the internal tenant MAC or IP address to location is
performed by the VTEP using a distributed mapping database. The fabric:
• Leverages IS-IS for infrastructure topology. IS-IS is responsible for identifying the TEPs and
announce the creation of tunnels from every leaf node to all other nodes in the fabric.
• Advertises loopback and VTEP addresses.
• Responsible for generating the multicast FTAG trees in the fabric using vendor TLVs.

All Tenant traffic within the fabric is tagged with an ACI VXLAN (VXLAN) header that identifies the
policy attributes of the application end point within the fabric.
• Policy Group (source group)
• Forwarding Group (Tenant, VRF, Bridge Domain)
• Load Balancing Policy
• Telemetry Policy

At the ingress port, the fabric translates an external identifier that can be used to distinguish different
application endpoints using the internal VXLAN tagging format
The fabric uses encapsulation where a Layer 2 ethernet packet is encapsulated to traverse the fabric. The
default MTU across the fabric is 9150 bytes.
FCAPS
The ISO model defines network management tasks. FCAPS is n acronym for fault, configuration,
accounting, performance, security, the management categories
FD_VLAN
Flood domain VLAN. The FD-VLAN is the forwarding VLAN used to forward traffic on the Broadcom
ASIC. The FD_VLAN is directly linked to the ACCESS_ENC and is also referred to as the internal
VLAN. The FD_VLAN is used to represent the ACCESS_ENC instead of linking it directly to the
BD_VLAN. The FD_VLAN allows the BD_VLAN to link to different ACCESS_ENCs and treat all of
them as if they were all in the same 802.1Q VLAN on a NX-OS switch. When a broadcast packet comes
into the leaf switch from the ACI fabric, the BD_VLAN can map to several FD_VLANs to allow the

Operating Cisco Application Centric Infrastructure


267
Appendix
Appendix

packet to be forwarded out different ports using different ACCESS_ENCs. The FD_VLAN is used to
learn Layer 2 MAC addresses.
Filters
Filters define the rules outlining the Layer 2 to layer 4 fields that will be matched by a contract. All
contracts consists of 1 or more subjects, where each subject contains 1 or more filters and each filter
contains 1 or more entries. Each entry is equivalent to a line in an ACL applied on the leaf switch that
the EP (within the EPG) is attached to. Filters do not define whether the entries are PERMIT or DENY
statements in contracts. The contract type the filters are associated with determines this.
Flowlet switching
An optimized, multipath, load-balancing methodology based on research from MIT in 2004. Flowlet
Switching is a way to use TCP's own bursty nature to more efficiently forward TCP flows by dynamically
splitting flows into flowlets, and splitting traffic across multiple parallel paths without requiring packet
reordering.
FNV
Fabric Node Vector.
GUI
Graphical User Interface.
Health Score
Health scores indicate if there are any faults within the different system views. ACI fabric health
information is available for the following views of the system:
• System—Aggregation of system-wide health, including pod health scores, tenant health scores,
system fault counts by domain and type, and the APIC cluster health state.
• Pod—Aggregation of health scores for a pod (a group of spine and leaf switches), and pod-wide
fault counts by domain and type.
• Tenant—Aggregation of health scores for a tenant, including performance data for objects such as
applications and EPGs that are specific to a tenant, and tenant-wide fault counts by domain and
type.
• Managed Object—Health score policies for managed objects (MOs), which includes their dependent
and related MOs. These policies can be customized by an administrator.

Health scores change color at different set point percentages.


• 66%—Health score displays in yellow when it drops below this percentage.
• 33%—Health score displays in red when it drops below this percentage.

HTML
HyperText Markup Language, a markup language that focuses on the formatting of web pages.
Hypervisor
Software that abstracts the hardware on a host machine and allows the host machine to run multiple
virtual machines.

Operating Cisco Application Centric Infrastructure


268
Appendix
Appendix

Hypervisor integration
Extension of ACI Fabric connectivity to a virtual machine manager to provide the APIC with a mechanism
for virtual machine visibility and policy enforcement.
Intra-Fabric Messages (IFM)
Used for communication between different devices on the ACI fabric. The software layer that tries to
deliver messages between the various DME addresses for each agent is called a "identity". An identity
has the following format:
system-type:system-id:service:slot

For example, the policy element in switch 119 is represented as follows:


1:119:5:0

IFM uses SSL over TCP for remote communication. It uses different ports for different processes:
eventmgr 12119 Alerts, Faults, Health Scores
nginx 12151
policyelem 12183
policymgr 12215 processes policy addition/deletion/modification events and
converts the policy into ppf representation and distributes
the
policies to policy clients using PPF library. It uses 2-pass
verify-commit model to get the policy programmed in the
hardware.
reader 12247
ae 12279
topomgr 12311
observer 12343 Roll up various HW faults
dbgr 12375 Atomic Counters
observerelem 12407
dbgrelem 12439
vmmmgr 12471 VM manager interactions
nxosmock 12503
bootmgr 12535
appliancedirector 12567 Clustering, Sharding, Syncing of replicas
dhcpd 12695 DHCP addressing
scripthandler 12727
idmgr 12759

Inband Management (INB)


Connectivity using an inband management configuration. This uses a front panel (data plane) port of a
leaf switch for external management connectivity for the fabric and APICs. Uses the fabric for management
connectivity. Applies a second VTEP address to the switch.
iPing
Fabric-aware ping. iPing is designed to work with:
• Pervasive fabric interfaces (Gateway IP addresses on each Leaf switch)
• Multi-Tenant and Overlay

The issue with normal ping is that with pervasive IP gateways on the fabric, the originating leaf may not
receive the ping reply since the gateway IP address is on multiple leaf switches. iPing allows the
originating leaf switch to receive the ping reply even if it is forwarded to another leaf switch by including
fabric information in the payload.

Operating Cisco Application Centric Infrastructure


269
Appendix
Appendix

IS-IS
Link local routing protocol leveraged by the fabric for infrastructure topology. Loopback and VTEP
addresses are internally advertised over IS-IS. IS-IS announces the creation of tunnels from leaf nodes
to all other nodes in fabric.
iTraceroute
Fabric-aware traceroute. iTraceroute has many unique features, including:
• Discovers and reports multiple paths
• Transits only a single probe packet per path
• Reports detailed node information
• Simulates tenant traffic, exploring paths under the applied policies

JSON
JavaScript Object Notation, a data encapsulation format that uses human readable text to encapsulate
data objects in attribute and value pairs.
Layer 2 Out (l2out)
Layer 2 connectivity to an external network that exists outside of the ACI fabric.
Layer 3 Out (l3out)
Layer 3 connectivity to an external network that exists outside of the ACI fabric.
L4-L7 Service Insertion
The insertion and stitching of VLANs/Layer 3 constructs of virtual or physical service appliances (Firewall,
IDS/IPS, Load Balancers, DLP, etc....) into the flow of traffic. Service nodes operate between Layers 4
and Layer 7 of the OSI model, where as networking elements (i.e. the fabric) operate at layers 1-3).
Label
Used for classifying which objects can and cannot communicate with each other.
Leaf
Network node in fabric providing host and border connectivity. Leafs connect only to hosts and spines.
Leafs never connect to each other. All devices are connected to the leaf switches including any external
routers or hosts.
Legacy Mode
When created under a bridge domain, contracts are not enforced for the bridge domain, and the encap
will be applied to all EPGs on this bridge domain. In this case, a bridge domain, endpoint group, and
VLAN all have a one to one mapping.
Life Cycle
Lifecycle describes a day in the life of a fault. It includes specific time intervals that must pass before
transitioning to the next state. The entire idea behind lifecycle is to allow the administrator to see transient
errors that do not last very long.
The lifecycle describes which time interval the fault MO is in: SOAKING, RAISED, or RETENTION.
The lifecycle also describes the severity: INITIAL, TARGET, or CLEAR.

Operating Cisco Application Centric Infrastructure


270
Appendix
Appendix

Link Layer Discovery Protocol (LLDP)


LLDP is used by the APIC to discover leaf switches and used by the leaf switches to discover spine
switches for fabric discovery.
Logical Model
Model configured by the user in the APIC using the GUI or XML/JSON API. The logical model is
located under /aci->/.aci/viewfs.
Managed Object (MO)
Every configurable component of the ACI policy model managed in the MIT is called a MO. A managed
object represents a configuration or state. Some managed objects and properties are read/writeable,
whereas others are read-only. In the case of policy resolution-based on named relations:
• If a target managed object with a matching name is not found in the current tenant, the ACI fabric
tries to resolve the name in the common tenant. For example, if the user tenant EPG contained a
relationship managed object targeted to a bridge domain that did not exist in the tenant, the system
tries to resolve the relationship in the common tenant.
• If a named relation cannot be resolved in either the current tenant or the common tenant, the ACI
fabric attempts to resolve to a default policy. If a default policy exists in the current tenant, it is
used.
• If it does not exist in the current tenant, the ACI fabric looks for a default policy in the common
tenant.

NOTE: Bridge domain, context, and contract (security policy) named relations do not resolve to a default.
Management Information Tree (MIT)
A hierarchical management information tree containing all of the managed objects of the fabric. Also
called the Management Information Model (MIM).
Match Type
Labels can be applied to a variety of provider and consumer managed objects, including EPGs, contracts,
bridge domains, DHCP relay policies, and DNS policies. When checking for a match of provider labels
and consumer labels, the setting is determined by the provider EPG. The types can be:
• AtleastOne (default)—At least 1 label matches on Provider and Consumer EPGs. Blank labels are
considered a match.
• AtmostOne—Matches only when all labels on the EPGs are exactly the same. Blank labels are
considered a match.
• None-None of the subject labels match.
• All—Only matches when both EPGs have all labels, excluding blank labels.

Model
A model is a concept which represents entities and the relationships that exist between them.
Multi-tier Application
Client-server architecture in which presentation, application logic, and database management functions
require physical or logical separation and require networking functions to communicate with the other
tiers for application functionality.

Operating Cisco Application Centric Infrastructure


271
Appendix
Appendix

NginX
NginX (pronounced "engine x") is an HTTP and reverse proxy server, a mail proxy server, and a generic
TCP proxy server, originally written by Igor Sysoev. All APIC input methods (REST API, Web GUI,
and CLI) send their input to NginX. The GUI in particular gets its status code from NginX and does not
validate any commands with the switch receiving the commands. Faults are sent back from the switches
if the commands cannot be applied. Always check the Faults tab after applying a configuration.
Northstar ASIC
Cisco ACI ASIC. 24x40G port wire-speed. Provides routing between VXLAN segments, larger buffers,
policy enforcement, advanced dynamic load-balancing, multicast forwarding and bridging between EPGs
within a bridge domain, QoS, atomic counters, and latency measurements. NorthStar also provides a
loopback path that will allow some of these value added features to be applied to local traffic as well as
the uplink. On egress from the fabric out the front ports, the NorthStar provides the following functions:
• VxLAN termination
• Station lookup
• Policy lookup
• Egress port selection

On ingress to the fabric from the front ports, the NorthStar provides the following functions:
• Derive EPG
• Station lookup
• Policy lookup
• Encap (proxy and non-proxy)
• Bounce

Object Model
A collection of objects and classes are used to examine and manipulate the configuration and running
state of the system that is exposing that object model. In ACI the object model is represented as a tree
known as the distributed management information tree (dMIT).
OpFlex
OpFlex is an open and extensible policy protocol for transferring abstract policy in XML or JavaScript
Object Notation (JSON) between a network policy controller such as the Cisco APIC and any device,
including hypervisor switches, physical switches, and Layer 4 through Layer 7 network services.
Out-of-Band management (OOB management)
External connectivity using a specific out-of-band management interface on every switch and APIC.
Overlay-1
The VRF (context) used by the fabric switches and APICs.
Physical Domain
Endpoint used for bare metal hosts or when the APIC does not have a VMM defined but it is connected

Operating Cisco Application Centric Infrastructure


272
Appendix
Appendix

Policy Control (PC) Tag


A policy control tag is assigned to the endpoint group to identify it numerically instead of by name. Also
called the "source ID" or "destination ID" in literature.
Port Channel
A Port link aggregation technology that binds multiple physical interfaces into a single logical interface
and provides more aggregate bandwidth and link failure recovery without a topology change.
Prefix
Prefixes control which external subnets are allowed into the fabric. When the fabric is peered with an
external router, the subnet prefix is considered to be the endpoint.
Private Network
Equivalent to a VRF, separates routing instances, can be used as an administrative separation. Used to
define a non-overlapping IP address space within the tenant. An endpoint group can only be associated
with a single private network.
Provider
The provider is the "receiver" of the traffic in the contract.
Privilege
Privileges determine what tasks a role is allowed to perform.
Policy
Named entity that contains generic specifications for controlling some aspect of system behavior. For
example, a Layer 3 Outside Network Policy would contain the BGP protocol to enable BGP routing
functions when connecting the fabric to an outside Layer 3 network.
Policy Group
A grouping of policies and profiles.
Raised
If the fault condition persists beyond the soaking time interval, the fault MO enters the Raised state.
Initial severity goes to target severity. One state might be RAISED-CLEARING indicating the fault was
active throughout the soaking interval and into the raised interval but is now clearing.
Resolved Model
The resolved model defines a mapping from the logical model to the concrete model where the logical
model contains the intended state and the concrete model contains the actual state. This occurs on the
APIC. This model is user-visible, but not configurable. The resolved model is implicitly configured by
the APIC under /mit ->/.aci/mitfs.
Retaining
When the fault condition is absent for the duration of the clearing interval in either the Raised-Clearing
or Soaking-Clearing state, the fault MO enters the Retaining state with the severity level cleared. A
retention interval begins, during which the fault MO is retained for a length of time specified in the fault
policy. This interval ensures that the fault reaches the attention of an administrator even if the condition
that caused the fault has been alleviated, and that the fault is not deleted prematurely.

Operating Cisco Application Centric Infrastructure


273
Appendix
Appendix

Role-Based Access Control (RBAC)


A method of managing secure access to infrastructure by assigning roles to users, then using those roles
in the process of granting or denying access to devices, objects and privilege levels. RBAC enables a
fabric-wide administrator to provide access across security domains (tenants) that would otherwise be
blocked. Use RBAC rules to expose physical resources or share services that otherwise are inaccessible
because they are in a different security domain (tenant). RBAC rules provide read access only to their
target resources.
Representational State Transfer (REST)
a stateless protocol usually run over HTTP that allows a client to access a server-side or cloud-based
API without having to write a local client for the host accessing the API. The location that the client
accesses usually defines the data the client is trying to access from the service. Data is usually accessed
and returned in either XML or JSON format. All ways of configuring ACI lead to the REST API. The
CLI, GUI, Python (cobra) API, as well as the XML API use the REST API for configuration.
RESTful
An API that uses REST, or Representational State Transfer.
Rn
Relative name, a name of a specific object within the ACI management information tree that is not fully
qualified. A Rn is significant to the individual object, but without context, it's not very useful in navigation.
A Rn would need to be concatenated with all the relative names from itself back up to the root to make
a distinguished name, which then becomes useful for navigation. As an example, if an Application Profile
object is created named "commerceworkspace", the Rn would be "ap-commerceworkspace" because
Application Profile relative names are all prefaced with the letters "ap-". See also the Dn definition.
Role
Each role has privileges assigned to it. The privileges allow the administrator to have finer granularity
within the tenant for restricting access.
RV
Replica Vector.
Security Domain
Security Domains restrict a user to a certain tenant or the MIT under that tenant or VMM.
Security Domain (per tenant or VMM)
|-------------------|------------------|
Role1 Role 2 role 3
priv1 priv3 priv1
priv2 priv4 priv4

Segment ID
Numerical representation of the private network name.
Service graph
A mechanism within ACI that automates redirection of traffic and VLAN stitching based on defined
parameters. Any services that are required are treated as a service graph that is instantiated on the ACI
fabric from the APIC. Service graphs identify the set of network or service functions that are needed by
the application, and represent each function as a node.

Operating Cisco Application Centric Infrastructure


274
Appendix
Appendix

Shard
A shard is a portion of a database. It allows for replication of the database across multiple physical
devices. Each shard has 3 replicas across the 3 APICs. Although each APIC has a complete copy of the
database, the APIC can only update its portion (or shard) of the database assigned to it. The other shards
stored on the APIC are read only until the APIC owning the shard sends a notification changing it. If the
APIC cluster loses an APIC, another APIC still active in the cluster will assume control of its shards in
the database.
Soaking
Soaking describes the first time interval created when a fault condition is detected. Its initial severity is
set. One state might be SOAKING-CLEARING, indicating that the fault cleared within the soaking
interval.
Spine
Network node in fabric carrying aggregate host traffic from leafs, connected only to leafs in the fabric
and no other device types.
Spine/Leaf topology
A CLOS-based fabric topology in which spine nodes connect to leaf nodes, leaf nodes connect to hosts
and external networks.
Static Binding Path
Under normal circumstances, ACI will automatically generate a VLAN on the leaf switch to put the EP
(in the EPG) traffic in. With a static path binding, you assign the VLAN that the port on the leaf switch
should configure for the EPG. When an EPG uses a static binding path, the encapsulation VLAN associated
with this EPG must be part of a defined static VLAN pool. This follows the "VLAN as an EPG" model.
This is a simple way to make the anycast gateway appear on the leaf switch for routing without having
an EP deployed on the switch or having the port up.
Subject
Contained by contracts and create the relationship between filters and contracts. Multiple subjects can
be in a single contract. The subjects are like templates when applied to the contracts and provide for a
certain service to be passed unidirectionally to the EPG. Subjects are a combination of a filter, an action,
and a (optional) label.
Filter Action Label
---------------- --------- -----------------
TCP Port 80 Permit Web Access
Any Permit common/default

If Apply Both Directions is selected, then both EPGs will be able to send traffic in one direction to the
other EPG. Any return traffic, including ACKs in TCP, is blocked unless Reverse Filter Ports is checked.
Reverse Filter Ports requires Apply Both Directions be checked first. Even with Reverse Filter Ports
checked, only the consumer of the contract may initiate traffic.
Subnet
Contained by a bridge domain or an endpoint group, a subnet defines the IP address range that can be
used within the bridge domain. Subnets are defined under the bridge domain, and are the same as "subnet"
in OpenStack. The different types of subnets are:
• Shared—Defines subnets under an endpoint group to route leak for shared services to endpoint
groups in a different VRF.

Operating Cisco Application Centric Infrastructure


275
Appendix
Appendix

• Public—Defines subnets under an endpoint group to route leak to other Tenants in the Fabric or
advertised externally outside of the fabric. For example, public subnets under a bridge domain
configuration are announced to external networks through routing protocols.
• Private—(Default) Defines subnets under a bridge domain to be used only in that tenant, meaning
that the subnets will not be leaked to other tenants.

Supervisor
Switch module that provides the control plane for the 95xx switches.
tDN
Target DN (Distinguished Name). An explicit reference defines a relationship between a source MO
(managed Object) and a specific instance of a target MO. The target instance is identified by a target DN
(tDn) property that is explicitly set in the relationship source (Rs) MO.
Tenant
The logical container to group all policies for application policies. Each tenant has a separate Layer 3
address space or VRF (private network). A tenant is similar to the "project/tenant" concept in OpenStack.
There are 3 pre-defined tenants in ACI:
• Common—Defines ACI structures that can be used by all tenants
• mgmt—Configures inband and out-of-band management of the APIC, leaf, and spine switches
• infra—Configures fabric policy between spines and leafs

A tenant is the highest level managed object in the Management Information Tree (MIT) model. The
primary elements that the tenant contains are contracts, bridge domains, private networks, and application
profiles that contain endpoint groups.
Virtual eXtensible LAN (VXLAN)
A Layer 2 overlay scheme over a Layer 3 network. A 24-bit VXLAN Segment ID or VXLAN Network
Identifier (VNI) is included in the encapsulation to provide up to 16M VXLAN segments for traffic
isolation/segmentation, in contrast to the 4K segments achievable with VLANs alone. Each of these
segments represents a unique Layer 2 broadcast domain, and can be administered in such a way that it
can uniquely identify a given tenant's address space or subnet. VXLAN is an extension of the Layer 2
LISP protocol (draft-smith-lisp-layer2-01) with the additional of policy group, load and path metric,
counter and ingress port and encapsulation information.
Virtual Network ID (VNID)
Used for forwarding the packets in different ways for different cases.
• Case 1: Layer 2, the VLAN dot1q or VXLAN VNID identifies the 'Bridge Domain'.
• Case 2: VRF-Lite, the VLAN dot1q tag identifies the VRF (Private Network).
• Case 3: mBGP EVPN, the VXLAN VNID identifies the VRF, or in the case of Layer 2, the Bridge
Domain.

In the case of ACI, the VLAN/VXLAN on the outside identifies the EPG (endpoint group). On the inside,
the S-Class in the VXLAN header identifies the EPG, VNID, and VRF/bridge domain.

Operating Cisco Application Centric Infrastructure


276
Appendix
Appendix

Virtual Routing and Forwarding (VRF)


A Layer 3 namespace isolation methodology to allow for multiple contexts to be deployed on a single
device or infrastructure.
Virtual Zone (vZ)
Contracts in the Management Information Tree start with vZ, such as the vzAny contract. vzAny means
any IP address in the VRF can reach this EPG and even includes unknown prefixes.
Virtualization
Technology used to abstract hardware resources into virtual representations and allowing software
configurability.
Visore
An application built into APIC to see the resolved model. Used to verify configuration in the MIT. To
access Visore, use the following URL:
https://your_apic/visore.html
VNI
VXLAN Network Identifier.
vPC
virtual Port Channel, in which a port channel is created for link aggregation, but is spread across no more
or less than 2 physical switches.
VXLAN Tunnel Endpoint (VTEP)
Each fabric switch and APIC is assigned a VTEP from the subnet given in the startup script.
XML
eXtensible Markup Language, a markup language that focuses on encoding data for documents rather
than the formatting of the data for those documents.
Zones and Zoning Rules
A contract for an EPG is pushed out to the switches in the form of rules within a zone or zoning rules.
Each zoning rule is equivalent to a single NX-OS ACL line. DME/PE (policy element) pushes the zoning
configuration to leaf switches based on contracts that are provided or consumed by the EPG that the EP
attached to the Leaf switch is associated to. Two EPGs that communicate with each other are grouped
together inside a single zone. An EPG can be associated with multiple zones, if it communicates with
multiple EPGs. For contracts and rules, the policy interaction and flow is:
1. Policy Manager on APIC communicates with Policy Element Manager on the switch.
2. Police Element Manager on switch programs the Object Store on switch
3. Policy Manager on switch communicates with ACLQOS client on the switch
4. ACLQOS client programs the hardware (TCAM)

Zoning Rules are specified in terms of contract:


• Scope (Application, Private Network, Tenant, Global)
• Source class ID or SRC EPG

Operating Cisco Application Centric Infrastructure


277
Appendix
Reference Material

• Destination class ID or DST EPG


• Filter

Rules are derived from contracts applied to the EPGs. There are 2 types of rules:
• actrlRules—Rules programmed by PE as EPGs/bridge domains get deployed on a leaf switch.
• MgmtRules—Rules for traffic which is destined to hit the Supervisor of the switch.

Zoning Rules can be seen on a leaf switch with the following command:
show zoning-rule [src-epg sclassID] [dst-epg dclassID]

A '0' in the classID is used to indicate 'any'.


The following command shows which rules in a zone are being hit by packets:
show logging ip access-list internal packet-log

Reference Material
Topics that are outside of the scope of this operations guide may be documented in other places. This section
includes links to other helpful reference documentation for further reading and viewing.

ACI Install and Upgrade Guides


http://www.cisco.com/c/en/us/support/cloud-systems-management/
application-policy-infrastructure-controller-apic/products-installation-guides-list.html
ACI Getting Started - Fabric Initialization
http://www.cisco.com/c/en/us/support/cloud-systems-management/
application-policy-infrastructure-controller-apic/products-installation-and-configuration-guides-list.html
ACI Design Guide
http://www.cisco.com/c/en/us/solutions/collateral/data-center-virtualization/application-centric-infrastructure/
white-paper-c11-731960.html#_Toc405844675
ACI Troubleshooting Guides
http://www.cisco.com/c/en/us/support/cloud-systems-management/
application-policy-infrastructure-controller-apic/products-troubleshooting-guides-list.html
https://datacenter.github.io/aci-troubleshooting-book/
ACI White Papers
http://www.cisco.com/c/en/us/solutions/data-center-virtualization/application-centric-infrastructure/
white-paper-listing.html
ACI Case Studies
http://www.cisco.com/c/en/us/solutions/data-center-virtualization/application-centric-infrastructure/
customer-case-study-listing.html
ACI Demos, Presentations and Trainings

Operating Cisco Application Centric Infrastructure


278
Appendix
Appendix

http://www.cisco.com/c/en/us/solutions/data-center-virtualization/application-centric-infrastructure/
sales-resources-list.html
ACI Ecosystem Compatability List
http://www.cisco.com/c/en/us/solutions/collateral/data-center-virtualization/application-centric-infrastructure/
solution-overview-c22-732445.html
ACI Partners and Customers Presentations
http://www.cisco.com/c/en/us/solutions/data-center-virtualization/application-centric-infrastructure/
presentations-listings.html
ACI with Microsoft SCVMM Workflow
http://www.cisco.com/c/en/us/td/docs/switches/datacenter/aci/apic/sw/1-x/virtualization/workflow/cisco_aci_
microsoft_scvmm_workflow.html
ACI Solutions Overview
http://www.cisco.com/c/en/us/solutions/data-center-virtualization/application-centric-infrastructure/
solution-overview-listing.html
ACI Toolkit
http://datacenter.github.io/acitoolkit/
ACI Compatibility Tool
http://www.cisco.com/web/techdoc/aci/acimatrix/matrix.html
AVS Configuration and Scalability Guides
http://www.cisco.com/c/en/us/support/switches/application-virtual-switch/
products-installation-and-configuration-guides-list.html
AVS Topologies and Solution Guide
http://www.cisco.com/c/en/us/support/switches/application-virtual-switch/products-technical-reference-list.html
APIC Command-Line Interface User Guide
http://www.cisco.com/c/en/us/support/cloud-systems-management/
application-policy-infrastructure-controller-apic/products-command-reference-list.html
APIC Layer 4 to Layer 7 Services Deployment Guide
http://www.cisco.com/c/en/us/td/docs/switches/datacenter/aci/apic/sw/1-x/L4-L7_Services_Deployment/
guide/b_L4L7_Deploy.html
Cobra Docs
http://cobra.readthedocs.org/en/latest/
Cobra GitHub
http://github.com/datacenter/cobra
Connecting ACI to Outside Layer 2 and 3 Networks
http://www.cisco.com/c/en/us/solutions/collateral/data-center-virtualization/application-centric-infrastructure/
white-paper-c07-732033.html
Fabric Connectivity Video

Operating Cisco Application Centric Infrastructure


279
Appendix
Appendix

https://www.youtube.com/watch?v=_iQvoC9zQ_A
Nexus CLI to Cisco APIC Mapping
http://www.cisco.com/c/en/us/support/cloud-systems-management/
application-policy-infrastructure-controller-apic/products-configuration-examples-list.html
POSTman
http://wwww.getpostman.com
Supported SNMP MIB List
http://www.cisco.com/c/en/us/td/docs/switches/datacenter/aci/apic/sw/1-x/mib/list/mib-support.html

Operating Cisco Application Centric Infrastructure


280

You might also like