> For the complete documentation index, see [llms.txt](https://adavyshin.gitbook.io/networks/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://adavyshin.gitbook.io/networks/vxlan-evpn-fabric/cc-lab-3.-vxlan-na-baze-multicast.md).

# CC Lab 3. VXLAN на базе multicast

Первоначальный вариант работы VXLAN базировался на работе многоадресной маршрутизации, когда определённому `VNI` сопоставлялась multicast-группа (адрес рассылки). И BUM-трафик распространялся на многоадресную рассылку на все необходимые VTEP.&#x20;

{% hint style="info" %}
`BUM` - это аббревиатура для `Broadcast`, `Unknown Unicast` и `Multicast` трафика, то есть трафик, который распространяется широковещательно на канальном уровне.&#x20;
{% endhint %}

Для оптимизации использования multicast-рассылки будем использовать протокол `PIM` в режиме `Sparse-mode`. Для напоминания в режиме Sparse-mode должна определяться `Rendezvous Point` (`RP`), она же точка встречи - это узел, где встречаются multicast-клиенты и источники multicast-рассылки. В *сети Клоза* очень удобно назначить `RP` один из Spine-коммутаторов, но для High Availability точки `RP` будем использовать `Anycast RP`, где одинаковый адрес сконфигурирован сразу на обоих <kbd>Spine</kbd>-ах.

{% hint style="warning" icon="dna" %}
Данная лабораторная выполняется на базе образа Cisco Nexus 9000v, так Arista vEOS работает только на приём multicast-трафика, но не умеет рассылать его.&#x20;
{% endhint %}

При первоначальном запуске Cisco Nexus 9000v системы задаст несколько вопросов

> Abort Power On Auto Provisioning \[yes - continue with normal setup, no - continue with Power On Auto Provisioning] (yes/no)\[no]: `yes`&#x20;
>
> Do you want to enforce secure password standard (yes/no) \[y]: `no`&#x20;
>
> Enter the password for "admin": `Pa$$w0rd`> \
> Confirm the password for "admin": `Pa$$w0rd`&#x20;
>
> Would you like to enter the basic configuration dialog (yes/no): `no`

В ОС `NX-OS` не работает привычная всем команда `write memory` для сохранения конфигурации, поэтому создаём alias чтобы не писать `copy running-config startup-config` . Также среди особенностей `NX-OS`, что каждый функционал это отдельная служба в ОС.&#x20;

🔧 Начинаем первоначальную настройку <kbd>DC1-LEAF1</kbd>:

```
configure terminal
!
hostname DC1-LEAF1
ip domain-name specialist.lab
!
cli alias name wr copy running-config startup-config
!
feature ospf
feature pim
feature lacp
feature vpc
feature nv overlay
!
line console
  exec-timeout 0
  
```

🔧 Инициализируем коммутатор <kbd>DC1-LEAF2</kbd>:

```
configure terminal
!
hostname DC1-LEAF2
ip domain-name specialist.lab
!
cli alias name wr copy running-config startup-config
!
feature ospf
feature pim
feature lacp
feature vpc
feature nv overlay
!
line console
  exec-timeout 0
```

🔧 Включаем поддержку multicast на всех коммутаторах <kbd>Spine</kbd> и <kbd>Leaf</kbd>

```
router multicast
   ipv4
      routing
```

🔧  На всех <kbd>Leaf</kbd> коммутаторах включаем поддержку PIM в режиме `Sparse`

```
interface Ethernet1-2
   pim ipv4 sparse-mode
```

🔧 На <kbd>Spine</kbd> коммутатора выполняем аналогичную операцию

```
interface Ethernet1-6
   pim ipv4 sparse-mode
```

Так как у нас реализован ECMP-механизм прохождения трафика через фабрику, то если мы создадим на Spine-ах Loopback-интерфейс с одинаковым адресом, то у нас будет неоднозначность в выборе RP, поэтому мы должны поднять метрику на <kbd>dc1-spine2</kbd>.

🔧 На <kbd>dc1-spine1</kbd> коммутаторe создаём RP

```
interface Loopback252
  description {Rendezvous-Point}
  ip address 10.252.252.252/32
!
router ospf 1
  network 10.252.252.252/32 area 0
```

🔧 На <kbd>dc1-spine2</kbd> коммутаторe создаём RP

```
interface Loopback252
  description {Rendezvous-Point}
  ip address 10.252.252.252/32
  ip ospf cost 100
!
router ospf 1
  network 10.252.252.252/32 area 0
```

🔧 На <kbd>dc1-leaf1</kbd> создаём Loopback-адрес для VTEP и включаем его в PIM&#x20;

```
interface Loopback1
  description {VTEP Source Address}
  ip address 10.254.12.12/32
!
router pim sparse-mode
   ipv4
      rp address 10.252.252.252
!
router ospf 1
  network 10.254.12.12/32 area 0
```

🔧 На <kbd>dc1-leaf2</kbd> создаём Loopback-адрес для VTEP и включаем его в PIM

```
interface Loopback1
  description {VTEP Source Address}
  ip address 10.254.12.12/32
!
router pim sparse-mode
   ipv4
      rp address 10.252.252.252
!
router ospf 1
  network 10.254.12.12/32 area 0
```

🔧 На <kbd>dc1-leaf3</kbd> создаём Loopback-адрес для VTEP и включаем его в PIM&#x20;

```
interface Loopback1
  description {VTEP Source Address}
  ip address 10.254.34.34/32
!
router pim sparse-mode
   ipv4
      rp address 10.252.252.252
!
router ospf 1
  network 10.254.34.34/32 area 0
```

🔧 На <kbd>dc1-leaf4</kbd> создаём Loopback-адрес для VTEP и включаем его в PIM

```
interface Loopback1
  description {VTEP Source Address}
  ip address 10.254.34.34/32
!
router pim sparse-mode
   ipv4
      rp address 10.252.252.252
!
router ospf 1
  network 10.254.34.34/32 area 0
```

🔧 На <kbd>dc1-leaf5</kbd> создаём Loopback-адрес для VTEP и включаем его в PIM&#x20;

```
interface Loopback1
  description {VTEP Source Address}
  ip address 10.254.56.56/32
!
router pim sparse-mode
   ipv4
      rp address 10.252.252.252
!
router ospf 1
  network 10.254.56.56/32 area 0
```

🔧 На <kbd>dc1-leaf6</kbd> создаём Loopback-адрес для VTEP и включаем его в PIM

```
interface Loopback1
  description {VTEP Source Address}
  ip address 10.254.56.56/32
!
router pim sparse-mode
   ipv4
      rp address 10.252.252.252
!
router ospf 1
  network 10.254.56.56/32 area 0
```

🔧 На <kbd>dc1-leaf1</kbd>  создаём VxLAN-интерфейс&#x20;

```
interface Vxlan1
   vxlan source-interface Loopback1
   vxlan udp-port 4789
   vxlan vlan 10 vni 10010
   vxlan vlan 10 multicast group 239.1.1.10
```


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://adavyshin.gitbook.io/networks/vxlan-evpn-fabric/cc-lab-3.-vxlan-na-baze-multicast.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
