<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:DengXian;
        panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:"\@DengXian";
        panose-1:2 1 6 0 3 1 1 1 1 1;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Dear folks, <o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I have setup a pretty simple OpenStack cluster in our lab based on devstack, couples of guest VM are running on one controller node (this doesn’t looks like a right behavior anyway),  the Neutron network is configured as OVS + vxlan, the
 bridge “br-ex” configured as below:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    Bridge br-ex<o:p></o:p></p>
<p class="MsoNormal">        Controller "tcp:127.0.0.1:6633"<o:p></o:p></p>
<p class="MsoNormal">            is_connected: true<o:p></o:p></p>
<p class="MsoNormal">        fail_mode: secure<o:p></o:p></p>
<p class="MsoNormal">        Port phy-br-ex<o:p></o:p></p>
<p class="MsoNormal">            Interface phy-br-ex<o:p></o:p></p>
<p class="MsoNormal">                type: patch<o:p></o:p></p>
<p class="MsoNormal">                options: {peer=int-br-ex}<o:p></o:p></p>
<p class="MsoNormal">        Port br-ex<o:p></o:p></p>
<p class="MsoNormal">            Interface br-ex<o:p></o:p></p>
<p class="MsoNormal">                type: internal<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt">ovs_version: "2.8.0"<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt"><o:p> </o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt"><o:p> </o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt"><o:p> </o:p></p>
<p class="MsoNormal">As you see, there is no external physical NIC bound to “br-ex”, so I guess the traffic from the VM to external will use the default route set on the controller node,  since there is a NIC (eno2) that can access external so I bind it to
 “br-ex” like this: ovs-vsctl add-port br-ex eno2. now the “br-ex” is configured as below:  <o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    Bridge br-ex<o:p></o:p></p>
<p class="MsoNormal">        Controller "tcp:127.0.0.1:6633"<o:p></o:p></p>
<p class="MsoNormal">            is_connected: true<o:p></o:p></p>
<p class="MsoNormal">        fail_mode: secure<o:p></o:p></p>
<p class="MsoNormal">        Port phy-br-ex<o:p></o:p></p>
<p class="MsoNormal">            Interface phy-br-ex<o:p></o:p></p>
<p class="MsoNormal">                type: patch<o:p></o:p></p>
<p class="MsoNormal">                options: {peer=int-br-ex}<o:p></o:p></p>
<p class="MsoNormal">        *<b>Port "eno2"</b>*<o:p></o:p></p>
<p class="MsoNormal">            Interface "eno2"<o:p></o:p></p>
<p class="MsoNormal">        Port br-ex<o:p></o:p></p>
<p class="MsoNormal">            Interface br-ex<o:p></o:p></p>
<p class="MsoNormal">                type: internal<o:p></o:p></p>
<p class="MsoNormal">    ovs_version: "2.8.0"<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Looks like this is how it should be configured according to lots of wiki/blog suggestion I have googled, but it doesn’t work as expected, ping from the VM, the tcpdump shows the traffic still go the “eno1” which is the default route on
 the controller node. <o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Inside of VM<o:p></o:p></p>
<p class="MsoNormal">ubuntu@test-br:~$ ping 8.8.8.8<o:p></o:p></p>
<p class="MsoNormal">PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.<o:p></o:p></p>
<p class="MsoNormal">64 bytes from 8.8.8.8: icmp_seq=1 ttl=38 time=168 ms<o:p></o:p></p>
<p class="MsoNormal">64 bytes from 8.8.8.8: icmp_seq=2 ttl=38 time=168 ms<o:p></o:p></p>
<p class="MsoNormal">…<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Dump the traffic on the “eno2”, got nothing<o:p></o:p></p>
<p class="MsoNormal">$ sudo tcpdump -nn -i eno2 icmp<o:p></o:p></p>
<p class="MsoNormal">tcpdump: verbose output suppressed, use -v or -vv for full protocol decode<o:p></o:p></p>
<p class="MsoNormal">listening on eno2, link-type EN10MB (Ethernet), capture size 262144 bytes<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt">…<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt"><o:p> </o:p></p>
<p class="MsoNormal">Dump the traffic on the “eno1” (internal NIC),  catch it!<o:p></o:p></p>
<p class="MsoNormal">$ sudo tcpdump -nn -i eno1 icmp<o:p></o:p></p>
<p class="MsoNormal">tcpdump: verbose output suppressed, use -v or -vv for full protocol decode<o:p></o:p></p>
<p class="MsoNormal">listening on eno1, link-type EN10MB (Ethernet), capture size 262144 bytes<o:p></o:p></p>
<p class="MsoNormal">16:08:59.609888 IP 192.168.20.132 > 8.8.8.8: ICMP echo request, id 1439, seq 1, length 64<o:p></o:p></p>
<p class="MsoNormal">16:08:59.781042 IP 8.8.8.8 > 192.168.20.132: ICMP echo reply, id 1439, seq 1, length 64<o:p></o:p></p>
<p class="MsoNormal">16:09:00.611453 IP 192.168.20.132 > 8.8.8.8: ICMP echo request, id 1439, seq 2, length 64<o:p></o:p></p>
<p class="MsoNormal">16:09:00.779550 IP 8.8.8.8 > 192.168.20.132: ICMP echo reply, id 1439, seq 2, length 64<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt"><o:p> </o:p></p>
<p class="MsoNormal" style="text-indent:9.75pt"><o:p> </o:p></p>
<p class="MsoNormal">$ sudo ip route<o:p></o:p></p>
<p class="MsoNormal">default via 192.168.18.1 dev eno1  proto static  metric 100<o:p></o:p></p>
<p class="MsoNormal">default via 192.168.8.1 dev eno2  proto static  metric 101<o:p></o:p></p>
<p class="MsoNormal">169.254.0.0/16 dev docker0  scope link  metric 1000 linkdown<o:p></o:p></p>
<p class="MsoNormal">172.17.0.0/16 dev docker0  proto kernel  scope link  src 172.17.0.1 linkdown<o:p></o:p></p>
<p class="MsoNormal">192.168.8.0/24 dev eno2  proto kernel  scope link  src 192.168.8.101  metric 100<o:p></o:p></p>
<p class="MsoNormal">192.168.16.0/21 dev eno1  proto kernel  scope link  src 192.168.20.132  metric 100<o:p></o:p></p>
<p class="MsoNormal">192.168.42.0/24 dev br-ex  proto kernel  scope link  src 192.168.42.1<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">What’s going wrong here? Do I miss something? Or some service need to be restarted?
<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Anyone could help me out?  This question made me sick for many days!  Huge thanks in the advance!<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Best Regards,<o:p></o:p></p>
<p class="MsoNormal">Dave <o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>