summaryrefslogtreecommitdiff
path: root/vtep/README.ovs-vtep.md
blob: 13d4e1d3644fbf63a7f9716132b527936a255cfc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
How to Use the VTEP Emulator
============================

This document explains how to use ovs-vtep, a VTEP emulator that uses
Open vSwitch for forwarding.

Requirements
------------

The VTEP emulator is a Python script that invokes calls to tools like
vtep-ctl and ovs-vsctl and is useful only when OVS daemons like ovsdb-server
and ovs-vswitchd are running. So those components should be installed. This
can be done by either of the following methods.

1. Follow the instructions in the INSTALL.md file of the Open vSwitch repository
(don't start any daemons yet).

2. Follow the instructions in INSTALL.Debian.md file and then install the
"openvswitch-vtep" package (if operating on a debian based machine). This
will automatically start the daemons.

Design
======

At the end of this process, you should have the following setup:


      +---------------------------------------------------+
      | Host Machine                                      |
      |                                                   |
      |                                                   |
      |       +---------+ +---------+                     |
      |       |         | |         |                     |
      |       |   VM1   | |   VM2   |                     |
      |       |         | |         |                     |
      |       +----o----+ +----o----+                     |
      |            |           |                          |
      | br0 +------o-----------o--------------------o--+  |
      |            p0          p1                  br0    |
      |                                                   |
      |                                                   |
      |                              +------+   +------+  |
      +------------------------------| eth0 |---| eth1 |--+
                                     +------+   +------+
                                     10.1.1.1   10.2.2.1
                        MANAGEMENT      |          |
                      +-----------------o----+     |
                                                   |
                                   DATA/TUNNEL     |
                                 +-----------------o---+

Notes:

1. We will use Open vSwitch to create our "physical" switch labeled br0

2. Our "physical" switch br0 will have one internal port also named br0
   and two "physical" ports, namely p0 and p1.

3. The host machine may have two external interfaces. We will use eth0
   for management traffic and eth1 for tunnel traffic (One can use
   a single interface to achieve both). Please take note of their IP
   addresses in the diagram. You do not have to use exactly
   the same IP addresses. Just know that the above will be used in the
   steps below.

4. You can optionally connect physical machines instead of virtual
   machines to switch br0. In that case:

   4.1. Make sure you have two extra physical interfaces in your host
        machine, eth2 and eth3.

   4.2. In the rest of this doc, replace p0 with eth2 and p1 with eth3.

5. In addition to implementing p0 and p1 as physical interfaces, you can
   also optionally implement them as standalone TAP devices, or VM
   interfaces for simulation.

6. Creating and attaching the VMs is outside the scope of this document
   and is included in the diagram for reference purposes only.

Startup
-------

These instructions describe how to run with a single ovsdb-server
instance that handles both the OVS and VTEP schema. You can skip
steps 1-3 if you installed using the debian packages as mentioned in
step 2 of the "Requirements" section.

1. Create the initial OVS and VTEP schemas:

      ```
ovsdb-tool create /etc/openvswitch/ovs.db vswitchd/vswitch.ovsschema
ovsdb-tool create /etc/openvswitch/vtep.db vtep/vtep.ovsschema
      ```

2. Start ovsdb-server and have it handle both databases:

      ```
ovsdb-server --pidfile --detach --log-file \
--remote punix:/var/run/openvswitch/db.sock \
--remote=db:hardware_vtep,Global,managers \
/etc/openvswitch/ovs.db /etc/openvswitch/vtep.db
      ```

3. Start OVS as normal:

      ```
ovs-vswitchd --log-file --detach --pidfile \
unix:/var/run/openvswitch/db.sock
      ```

4. Create a "physical" switch and its ports in OVS:

      ```
ovs-vsctl add-br br0
ovs-vsctl add-port br0 p0
ovs-vsctl add-port br0 p1
      ```

5. Configure the physical switch in the VTEP database:

      ```
vtep-ctl add-ps br0
vtep-ctl set Physical_Switch br0 tunnel_ips=10.2.2.1
      ```
      
6. Start the VTEP emulator. If you installed the components by reading the
   INSTALL.md file, run the following from the same directory as this
   README.md:

      ```
./ovs-vtep --log-file=/var/log/openvswitch/ovs-vtep.log \
--pidfile=/var/run/openvswitch/ovs-vtep.pid \
--detach br0
      ```

  If the installation was done by installing the openvswitch-vtep
  package, you can find ovs-vtep at /usr/share/openvswitch/scripts.

7. Configure the VTEP database's manager to point at an NVC:

      ```
vtep-ctl set-manager tcp:<CONTROLLER IP>:6640
      ```

   Where CONTROLLER IP is your controller's IP address that is accessible
   via the Host Machine's eth0 interface.

Simulating an NVC
-----------------

A VTEP implementation expects to be driven by a Network Virtualization
Controller (NVC), such as NSX.  If one does not exist, it's possible to
use vtep-ctl to simulate one:

1. Create a logical switch:

      ```
vtep-ctl add-ls ls0
      ```

2. Bind the logical switch to a port:

      ```
vtep-ctl bind-ls br0 p0 0 ls0
vtep-ctl set Logical_Switch ls0 tunnel_key=33
      ```

3. Direct unknown destinations out a tunnel.

   For handling L2 broadcast, multicast and unknown unicast traffic,
   packets can be sent to all members of a logical switch referenced by
   a physical switch.  The "unknown-dst" address below is used to
   represent these packets.  There are different modes to replicate the
   packets.  The default mode of replication is to send the traffic to a
   service node, which can be a hypervisor, server or appliance, and let
   the service node handle replication to other transport nodes
   (hypervisors or other VTEP physical switches).  This mode is called
   _service node_ replication.  An alternate mode of replication, called
   _source node_ replication, involves the source node sending to all
   other transport nodes.  Hypervisors are always responsible for doing
   their own replication for locally attached VMs in both modes.
   Service node mode is the default.  Service node replication mode is
   considered a basic requirement because it only requires sending the
   packet to a single transport node.  The following configuration is
   for service node replication mode as only a single transport node
   destination is specified for the unknown-dst address:

      ```
vtep-ctl add-mcast-remote ls0 unknown-dst 10.2.2.2
      ```

4. Optionally, change the replication mode from a default of
"service\_node" to "source\_node", which can be done at the logical
switch level:

      ```
vtep-ctl set-replication-mode ls0 source_node
      ```

5. Direct unicast destinations out a different tunnel:

      ```
vtep-ctl add-ucast-remote ls0 00:11:22:33:44:55 10.2.2.3
      ```