Skip to main content

Multisite

Diagram

Classes

vxlan

NameTypeConstraintMandatoryDefault Value
multisiteClass[multisite]No

multisite (vxlan)

NameTypeConstraintMandatoryDefault Value
child_fabricsList[child_fabrics]No
overlayClass[overlay]No
anycast_gateway_macAnyString[Regex: ^[a-f0-9]{1}.[a-f0-9]{1}.[a-f0-9]{1}$] or String[Regex: ^[a-f0-9]{4}.[a-f0-9]{4}.[a-f0-9]{4}$] or String[Regex: ^[a-f0-9]{2}:[a-f0-9]{2}:[a-f0-9]{2}:[a-f0-9]{2}:[a-f0-9]{2}:[a-f0-9]{2}$] or String[Regex: ^[a-f0-9]{2}-[a-f0-9]{2}-[a-f0-9]{2}-[a-f0-9]{2}-[a-f0-9]{2}-[a-f0-9]{2}$]No20:20:00:00:00:aa
vtep_loopback_idIntegermin: 0, max: 1023No100
bgw_ip_tagStringNo54321
overlay_dciClass[overlay_dci]No
ipv4_vtep_loopback_rangeIPNo10.10.0.0/24
isnClass[isn]No

child_fabrics (vxlan.multisite)

NameTypeConstraintMandatoryDefault Value
nameStringYes
clusterStringNo

overlay (vxlan.multisite)

NameTypeConstraintMandatoryDefault Value
vrfsList[vrfs]No
networksList[networks]No
vrf_attach_groupsList[vrf_attach_groups]No
network_attach_groupsList[network_attach_groups]No

overlay_dci (vxlan.multisite)

NameTypeConstraintMandatoryDefault Value
deployment_methodChoiceManual, Centralized_To_Route_Server, Direct_To_BGWSNoDirect_To_BGWS
ipv4_dci_subnet_rangeIPNo10.10.1.0/24
ipv4_dci_subnet_maskIntegermin: 8, max: 31No30
route_serverClass[route_server]No
underlay_autoconfigBooleantrue, falseNotrue
enable_bgp_send_communityBooleantrue, falseNofalse
enable_bgp_log_neighbor_changeBooleantrue, falseNofalse
enable_bgp_bfdBooleantrue, falseNofalse
delay_restoreIntegermin: 30, max: 1000No300
enable_ebgp_passwordBooleantrue, falseNofalse
ebgp_passwordStringNo
ebgp_password_encryption_typeChoice3, 7No
enable_trmBooleantrue, falseNofalse

isn (vxlan.multisite)

NameTypeConstraintMandatoryDefault Value
bgp_asnStringRegex: ^(?:\d{1,10}|\d{1,5}\.\d{1,5})$Yes
sub_int_rangeStringNo2-511
enable_nxapi_httpBooleantrue, falseNo
nxapi_http_portIntegerNo
enable_nxapi_httpsBooleantrue, falseNo
nxapi_https_portIntegerNo
bootstrapClass[bootstrap]No

vrfs (vxlan.multisite.overlay)

NameTypeConstraintMandatoryDefault Value
nameStringYes
vrf_idIntegermin: 4096, max: 1677215No
vlan_idIntegermin: 1, max: 4094No
vrf_vlan_nameStringNo
vrf_intf_descStringNo
vrf_descriptionStringNo
vrf_int_mtuIntegermin: 1500, max: 9216No
loopback_route_tagIntegermin: 0, max: 4294967295No
max_bgp_pathsIntegermin: 1, max: 128No
max_ibgp_pathsIntegermin: 1, max: 128No
ipv6_linklocal_enableBooleantrue, falseNo
adv_host_routesBooleantrue, falseNo
adv_default_routesBooleantrue, falseNo
static_default_routeBooleantrue, falseNo
bgp_passwordStringNo
bgp_password_encryption_typeChoice3, 7No
disable_rt_autoBooleantrue, falseNo
export_evpn_rtStringNo
export_mvpn_rtStringNo
export_vpn_rtStringNo
import_evpn_rtStringNo
import_mvpn_rtStringNo
import_vpn_rtStringNo
netflow_enableBooleantrue, falseNo
netflow_monitorStringNo
no_rpBooleantrue, falseNo
overlay_multicast_groupStringNo
redist_direct_routemapStringNo
rp_addressIPNo
rp_externalBooleantrue, falseNo
rp_loopback_idIntegermin: 0, max: 1023No
trm_enableBooleantrue, falseNo
trm_bgw_msiteBooleantrue, falseNo
underlay_mcast_ipIPNo
vrf_attach_groupStringNo

networks (vxlan.multisite.overlay)

NameTypeConstraintMandatoryDefault Value
nameStringYes
is_l2_onlyBooleantrue, falseNo
vrf_nameStringNo
net_idIntegermin: 4096, max: 1677215No
vlan_idIntegermin: 1, max: 4094No
vlan_nameStringNo
gw_ip_addressIPNo
arp_suppressBooleantrue, falseNo
dhcp_loopback_idIntegermin: 0, max: 1023No
dhcp_serversList[dhcp_servers]No
gw_ipv6_addressStringNo
int_descStringNo
l3gw_on_borderBooleantrue, falseNo
mtu_l3intfIntegerNo
multicast_group_addressIPNo
netflow_enableBooleantrue, falseNo
route_target_bothBooleantrue, falseNo
route_tagIntegermin: 0, max: 4294967295No
secondary_ip_addressesList[secondary_ip_addresses]No
trm_enableBooleantrue, falseNo
vlan_netflow_monitorStringNo
network_attach_groupStringNo

vrf_attach_groups (vxlan.multisite.overlay)

NameTypeConstraintMandatoryDefault Value
nameStringYes
switchesList[switches]No

network_attach_groups (vxlan.multisite.overlay)

NameTypeConstraintMandatoryDefault Value
nameStringYes
switchesList[switches]No

route_server (vxlan.multisite.overlay_dci)

NameTypeConstraintMandatoryDefault Value
peersList[peers]No
redistribute_directBooleantrue, falseNofalse
ip_tagIntegermin: 0, max: 4294967295No54321

bootstrap (vxlan.multisite.isn)

NameTypeConstraintMandatoryDefault Value
enable_bootstrapBooleantrue, falseNo
enable_local_dhcp_serverBooleantrue, falseNo
dhcp_versionChoiceDHCPv4, DHCPv6No
dhcp_v4Class[dhcp_v4]No
dhcp_v6Class[dhcp_v6]No
enable_cdp_mgmtBooleantrue, falseNo

dhcp_servers (vxlan.multisite.overlay.networks)

NameTypeConstraintMandatoryDefault Value
ip_addressIPYes
vrfStringYes

secondary_ip_addresses (vxlan.multisite.overlay.networks)

NameTypeConstraintMandatoryDefault Value
ip_addressIPYes
route_tagIntegermin: 0, max: 4294967295No

switches (vxlan.multisite.overlay.vrf_attach_groups)

NameTypeConstraintMandatoryDefault Value
hostnameStringYes
loopback_idIntegermin: 0, max: 1023No
loopback_ipv4IPNo
loopback_ipv6IPNo

switches (vxlan.multisite.overlay.network_attach_groups)

NameTypeConstraintMandatoryDefault Value
hostnameStringYes
portsListString[Regex: ^(?:e|eth(?:ernet)?)\d(?:\/\d+){1,2}$]No
torsList[tors]No

peers (vxlan.multisite.overlay_dci.route_server)

NameTypeConstraintMandatoryDefault Value
ip_addressIPYes
bgp_asnStringRegex: ^(?:\d{1,10}|\d{1,5}\.\d{1,5})$Yes

dhcp_v4 (vxlan.multisite.isn.bootstrap)

NameTypeConstraintMandatoryDefault Value
scope_start_addressIPYes
scope_end_addressIPYes
switch_mgmt_default_gwIPYes
mgmt_prefixIntegermin: 8, max: 30Yes
multi_subnet_scopeStringNo
domain_nameStringNo

dhcp_v6 (vxlan.multisite.isn.bootstrap)

NameTypeConstraintMandatoryDefault Value
scope_start_addressIPYes
scope_end_addressIPYes
switch_mgmt_default_gwIPYes
mgmt_prefixIntegermin: 64, max: 126Yes
multi_subnet_scopeStringNo
domain_nameStringNo

tors (vxlan.multisite.overlay.network_attach_groups.switches)

NameTypeConstraintMandatoryDefault Value
hostnameStringYes
portsListString[Regex: ^(?:e|eth(?:ernet)?)\d(?:\/\d+){1,2}$]No

Workflow

To manage an MSD Fabric, you need to follow this process:

Step 1 - Create your child fabrics. In this example, we have four (4) childs fabrics:

  • nac-ndfc1
  • nac-ndfc2
  • nac-ndfc3
  • nac-isn

Each fabric has their own data source under host_vars.

host_vars directories
❯ tree -L1  host_vars
host_vars
├── nac-isn
├── nac-msd
├── nac-ndfc1
├── nac-ndfc2
└── nac-ndfc3
inventory.yaml
❯ cat inventory.yaml
---
all:
children:
ndfc:
hosts:
nac-isn:
ansible_host: 10.x.x.x
nac-msd:
ansible_host: 10.x.x.x
nac-ndfc1:
ansible_host: 10.x.x.x
nac-ndfc2:
ansible_host: 10.x.x.x
nac-ndfc3:
ansible_host: 10.x.x.x
tip

If your fabric uses a different controller, you can provide a different IP address. Each folder will contain their own YAML data files to describe each respective fabric.

Step 2 - Create the MSD fabric, which includes child fabrics.

MSD Example

Figure: MultiSite topology overview

In this example, we have a fabric named MSD. In this MSD fabric, all fabrics use the same anycast gateway mac: DE:AD:BE:EF:FE:ED. The loopback ID used for the Anycast IP configured on each Border Gateway is: 100 and the subnet used to allocate an IP is: 10.10.0.0/24.

This configuration uses external ISN devices as the Route Server. In this configuration there are four (4) IP addresses:

  • 100.64.0.1
  • 100.64.0.2
  • 100.64.0.3
  • 100.64.0.4

Each IP will be associated to an Autonomous System (ASN), which can be different for each Route Server. In this example, all Route Servers will use the ASN 65000.100. When underlay_autoconfig is true, you need to provide a subnet for the DCI point-to-point (p2p) connection(s). Here we used the subnet 10.10.1.0/24. Each p2p will used CIDR /30.

warning

The value in bgp_asn should between double quotes. Example:

global:
bgp_asn: "6512"
global:
bgp_asn: "65000.1"
global.nac.yaml
---
vxlan:
fabric:
name: MSD
type: MSD
multisite:
child_fabrics:
- name: nac-ndfc1
- name: nac-ndfc2
- name: nac-ndfc3
- name: nac-isn
anycast_gateway_mac: de:ad:be:ef:fe:ed
bgw_ip_tag: "54321" # Use quotes
vtep_loopback_id: 100
ipv4_vtep_loopback_range: 10.10.0.0/24
overlay_dci:
underlay_autoconfig: true
deployment_method: 'Centralized_To_Route_Server'
ipv4_dci_subnet_range: 10.10.1.0/24
ipv4_dci_subnet_mask: 30
route_server:
peers:
- ip_address: 100.64.0.1
bgp_asn: "65000.100" # Use quotes
- ip_address: 100.64.0.2
bgp_asn: "65000.100" # Use quotes
- ip_address: 100.64.0.3
bgp_asn: "65000.100" # Use quotes
- ip_address: 100.64.0.4
bgp_asn: "65000.100" # Use quotes
redistribute_direct: false
ip_tag: 54321
enable_bgp_bfd: false
enable_bgp_log_neighbor_change: true
enable_bgp_send_community: true
enable_ebgp_password: false
enable_trm: false
delay_restore: 300

ISN Example

This fabric named nac-isn, uses a fabric type: ISN. Here, we must configure an ASN. In addition we can add a range of vlan for sub-interface.

global.nac.yaml
---
vxlan:
fabric:
name: nac-isn
type: ISN
multisite:
isn:
bgp_asn: "65000.100" # Use quotes
sub_int_range: 2-511
note

With MSD, VRFs and Networks should be configured under the multisite section of the data model. In MSD, we have a new key: multisite for the overlay.

Examples:

vrfs.nac.yaml
vxlan:
multisite:
overlay:
vrfs:
# simple example
- vrf_name: NetAsCodeVrf1
vrf_id: 150001
vlan_id: 2001
attach_group: NetAsCodeVrf1_AttachGroup
vrf_attach_groups:
- name: NetAsCodeVrf1_AttachGroup
switches:
- hostname: dc1-leaf1
- hostname: dc1-leaf2
networks.nac.yaml
vxlan:
multisite:
overlay:
networks:
# simple example
- name: NetworkDMZ
is_l2_only: true
net_id: 33100
vlan_id: 3100
attach_group: dmz
network_attach_groups:
- name: dmz
switches:
- hostname: dc1-leaf1
ports:
- e1/23
- e1/24
- hostname: dc1-leaf2
ports:
- e1/23
- e1/24