<div dir="ltr">The mechanism drivers populate the vif details that tell nova how it's supposed to setup the VM port. So the linux bridge driver tells it the port type is linux bridge[1] and the OVS tells it that the type is OVS.<div><br></div><div>So if you have both loaded and ovs is running on the compute node. The following steps will happen:</div><div><br></div><div>* nova sends a port update populating the host_id of the compute node the port will be on</div><div>* ML2 processes the update and starts the port binding operation and calls each driver</div><div>* The linux bridge mech driver will see that it has no active agents on that host so it will not bind the port</div><div>* The openvswitch mech driver will see that it does have an active agent, so it will bind the port and populate the details indicating it's an OVS port</div><div>* The updated port with the vif details indicating that it's an OVS port will be returned to Nova and nova will wire up the port for OVS</div><div><br></div><div><br></div><div><br></div><div><br></div><div>1. <a href="https://github.com/openstack/neutron/blob/bcd6fddb127f4fe3f7ce3415f5b5e0da910e0e0b/neutron/plugins/ml2/drivers/linuxbridge/mech_driver/mech_linuxbridge.py#L40-L43">https://github.com/openstack/neutron/blob/bcd6fddb127f4fe3f7ce3415f5b5e0da910e0e0b/neutron/plugins/ml2/drivers/linuxbridge/mech_driver/mech_linuxbridge.py#L40-L43</a></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jan 4, 2017 at 7:51 PM, zhi <span dir="ltr"><<a href="mailto:changzhi1990@gmail.com" target="_blank">changzhi1990@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi, Kevin. If I load openvswitch and linuxbridge mechanism drivers in neutron server, and running ovs-agent in compute nodes. What does openvsitch mechanism driver do? What does linuxbridge mechanism do? I think there must have some differences between the openvswitch and the linuxbridge mechanism driver. But I can't get the exact point about the two mechanism drivers when running ovs-agent in compute nodes now.</div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">2017-01-04 16:16 GMT+08:00 Kevin Benton <span dir="ltr"><<a href="mailto:kevin@benton.pub" target="_blank">kevin@benton.pub</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Note that with the openvswitch and linuxbridge mechanism drivers, it will be safe to have both loaded on the Neutron server at the same time since each driver will only bind a port if it has an agent of that type running on the host.</div><div class="m_6019808852010610844HOEnZb"><div class="m_6019808852010610844h5"><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Dec 30, 2016 at 1:24 PM, Sławek Kapłoński <span dir="ltr"><<a href="mailto:slawek@kaplonski.pl" target="_blank">slawek@kaplonski.pl</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hello,<br>
<br>
I don't know what is hierarchical port binding but about mechanism<br>
drivers, You should use this mechanism driver which L2 agent You are<br>
using on compute/network nodes. If You have OVS L2 agent then You should<br>
have enabled openvswitch mechanism driver.<br>
In general both of those drivers are doing similar work on<br>
neutron-server side because they are checking if proper agent type is<br>
working on host and if other conditions required to bind port are valid.<br>
Mechanism drivers can have also some additional informations about<br>
backend driver, e.g. there is info about supported QoS rule types for<br>
each backend driver (OVS, Linuxbridge and SR-IOV).<br>
<br>
BTW. IMHO You should send such questions to <a href="mailto:openstack@lists.openstack.org" target="_blank">openstack@lists.openstack.org</a><br>
<br>
--<br>
Best regards / Pozdrawiam<br>
Sławek Kapłoński<br>
<a href="mailto:slawek@kaplonski.pl" target="_blank">slawek@kaplonski.pl</a><br>
<div><div class="m_6019808852010610844m_-4164793526680075950h5"><br>
On Fri, 30 Dec 2016, zhi wrote:<br>
<br>
> Hi, all<br>
><br>
> First of all. Happy New year for everyone!<br>
><br>
> I have a question about mechanism drivers when using ML2 driver.<br>
><br>
> When should I use openvswitch mechanism driver ?<br>
><br>
> When should I use linuxbridge mechanism driver ?<br>
><br>
> And, when should I use openvswitch and linuxbridge mechanism drivers ?<br>
><br>
> In my opinion, ML2 driver has supported hierarchical port binding. By using<br>
> hierarchical port binding,<br>
> neutron will know every binding info in network topology, isn't it? If yes,<br>
> where I can found the every binding info. And what the relationship between<br>
> hierarchical port binding and mechanism drivers?<br>
><br>
><br>
> Hope for your reply.<br>
><br>
> Thanks<br>
> Zhi Chang<br>
<br>
</div></div>> ______________________________<wbr>______________________________<wbr>______________<br>
> OpenStack Development Mailing List (not for usage questions)<br>
> Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.op<wbr>enstack.org?subject:unsubscrib<wbr>e</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi<wbr>-bin/mailman/listinfo/openstac<wbr>k-dev</a><br>
<br>
<br>______________________________<wbr>______________________________<wbr>______________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.op<wbr>enstack.org?subject:unsubscrib<wbr>e</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi<wbr>-bin/mailman/listinfo/openstac<wbr>k-dev</a><br>
<br></blockquote></div><br></div>
</div></div><br>______________________________<wbr>______________________________<wbr>______________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.op<wbr>enstack.org?subject:unsubscrib<wbr>e</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi<wbr>-bin/mailman/listinfo/openstac<wbr>k-dev</a><br>
<br></blockquote></div><br></div>
</div></div><br>______________________________<wbr>______________________________<wbr>______________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.<wbr>openstack.org?subject:<wbr>unsubscribe</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/<wbr>cgi-bin/mailman/listinfo/<wbr>openstack-dev</a><br>
<br></blockquote></div><br></div>