<p dir="ltr">The current suggested way for DHCP agent fault tolerance is multiple agents per network. Is there a reason you don't want to use that option? </p>
<div class="gmail_quote">On Oct 20, 2014 5:13 PM, "Noel Burton-Krahn" <<a href="mailto:noel@pistoncloud.com">noel@pistoncloud.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Thanks, Robert.<div><br></div><div>So, ML2 needs the host attribute to match to bind the port.  My other requirement is that the dhcp agent must be able to migrate to a new host on failover.  The issue there is that if the dhcp service starts on a new host with a new host name, then it will not take over the networks that were served by the old host name.  I'm looking for a way to start the dhcp agent on a new host using the old host's config.</div><div><br></div><div>--</div><div>Noel</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Oct 20, 2014 at 11:10 AM, Robert Kukura <span dir="ltr"><<a href="mailto:kukura@noironetworks.com" target="_blank">kukura@noironetworks.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  
    
  
  <div bgcolor="#FFFFFF" text="#000000">
    Hi Noel,<br>
    <br>
    The ML2 plugin uses the binding:host_id attribute of port to control
    port binding. For compute ports, nova sets binding:host_id when
    creating/updating the neutron port, and ML2's openvswitch mechanism
    driver will look in agents_db to make sure the openvswitch L2 agent
    is running on that host, and that it has a bridge mapping for any
    needed physical network or has the appropriate tunnel type enabled.
    The binding:host_id attribute also gets set on DHCP, L3, and other
    agents' ports, and must match the host of the openvswitch-agent on
    that node or ML2 will not be able to bind the port. I suspect your
    configuration may be resulting in these not matching, and the DHCP
    port's binding:vif_type attribute being 'binding_failed'.<br>
    <br>
    I'd suggest running "neutron port-show" as admin on the DHCP port to
    see what the values of binding_vif_type and binding:host_id are, and
    running "neutron agent-list" as admin to make sure there is an L2
    agent on that node and maybe "neutron agent-show" as admin to get
    that agents config details.<br>
    <br>
    -Bob<div><div><br>
    <br>
    <br>
    <div>On 10/20/14 1:28 PM, Noel Burton-Krahn
      wrote:<br>
    </div>
    </div></div><blockquote type="cite"><div><div>
      <div dir="ltr">I'm running OpenStack Icehouse with Neutron
        ML2/OVS.  I've configured the ml2-ovs-plugin on all nodes with
        host = the IP of the host itself.  However, my dhcp-agent may
        float from host to host for failover, so I configured it with
        host="floating".  That doesn't work.  In this case, the
        ml2-ovs-plugin creates a namespace and a tap interface for the
        dhcp agent, but OVS doesn't route any traffic to the dhcp
        agent.  It *does* work if the dhcp agent's host is the same as
        the ovs plugin's host, but if my dhcp agent migrates to another
        host, it loses its configuration since it now has a different
        host name.  
        <div><br>
        </div>
        <div>So my question is, what does host mean for the ML2 dhcp
          agent and host can I get it to work if the dhcp agent's host
          != host for the ovs plugin?</div>
        <div><br>
        </div>
        <div>Case 1: fails: running with dhcp agent's host = "floating",
          ovs plugin's host = IP-of-server</div>
        <div>dhcp agent is running in netns created by ovs-plugin</div>
        <div>dhcp agent never receives network traffic</div>
        <div><br>
        </div>
        <div>Case 2: ok: running with dhcp agent's host = ovs plugin's
          host = IP-of-server</div>
        <div>
          <div>dhcp agent is running in netns created by ovs-plugin
            (different tap name than case 1)</div>
        </div>
        <div>dhcp agent works</div>
        <div><br>
        </div>
        <div>--</div>
        <div>Noel</div>
        <div><br>
        </div>
        <div><br>
        </div>
        <div><br>
        </div>
        <div> </div>
      </div>
      <br>
      <fieldset></fieldset>
      <br>
      </div></div><pre>_______________________________________________
OpenStack-dev mailing list
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.openstack.org</a>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a>
</pre>
    </blockquote>
    <br>
  </div>

<br>_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div><br></div>
<br>_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div>