<div dir="ltr">Comments inline.<div><br></div><div>Salvatore<br><div class="gmail_extra"><br><div class="gmail_quote">On 10 October 2014 11:02, Wuhongning <span dir="ltr"><<a href="mailto:wuhongning@huawei.com" target="_blank">wuhongning@huawei.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div>
<div style="direction:ltr;font-family:Tahoma;color:rgb(0,0,0);font-size:10pt">Hi,
<div><br>
</div>
<div>In the Juno cycle there is proposal of ModularL2Agent [1,2], which is very useful to develop agent for new backend with much less redundant code. Without that, we have to either fork a new agent by copying large amount of existing l2agent code, or patch
existing l2agent. However in the K pad [3] it seems that this feature disappeared?</div></div></div></blockquote><div><br></div><div>The fact that the topic is not present in the Kilo summit discussion does not mean that the related work item has been tabled.</div><div>It just means that it's not something we'll probably discuss at the summit, mostly because the discussion can happen on the mailing list - as you're doing now.</div><div>I think a summit session should be granted if the community still needs to achieve consensus on the technical direction or if the topic is of such a paramount importance that awareness needs to be raised.</div><div><br></div><div>The blueprint and spec for this topic are available ad [1] and [2], and afaict are still active.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div style="direction:ltr;font-family:Tahoma;color:rgb(0,0,0);font-size:10pt">
<div><br>
</div>
<div>Now there are some interest on hybrid backend (e.g. Hierachical Binding), and some BPs are proposed to patch OVS agent. But it has two drawbacks: 1) tightly coupled with OVS; 2) OVS agent became unnecessarily heavier. With ML2agent we only need to add
separated driver modules in the common L2agent framework, but not to patch the monolithic ovs agent.</div></div></div></blockquote><div><br></div><div>The point of a modular L2 agent is to have a very efficient RPC interface with the neutron server and a framework for detecting data plane transitions, such as new ports, and apply the corresponding configurations. And then have driver which will apply such configurations to different backends.</div><div><br></div><div>I reckon the blueprints you are referring to are probably assuming the OVS agent becomes modular - because otherwise it will be hardy able to target backends which are not ovs.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div style="direction:ltr;font-family:Tahoma;color:rgb(0,0,0);font-size:10pt">
<div><br>
</div>
<div>Also if it is convenient to write only modules but not the whole agent, backend providers may prefer to move out most of the logic from MD to agent side driver, for better stability for Neutron controller node and easier co-existing with other backend.
Ofagent shows good compatibility of l2pop to build vxlan/gre tunnel network between itself and other ovs/linuxbridge agent.</div>
<div><br>
</div>
<div>Or are there any general consideration about Neutron agent side consolidation, either L2/L3/L4-7?</div></div></div></blockquote><div><br></div><div>As far as I know there is no plan for a consolidate neutron agent which does L2/L7 operations. Frankly I do not even think there is any need for it.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div style="direction:ltr;font-family:Tahoma;color:rgb(0,0,0);font-size:10pt">
<div><br>
</div>
<div>1. <a href="https://wiki.openstack.org/wiki/Neutron/ModularL2Agent#Possible_Directions" style="font-size:10pt" target="_blank">https://wiki.openstack.org/wiki/Neutron/ModularL2Agent#Possible_Directions</a></div>
<div>2. <a href="https://etherpad.openstack.org/p/juno-neutron-modular-l2-agent" style="font-size:10pt" target="_blank">https://etherpad.openstack.org/p/juno-neutron-modular-l2-agent</a></div>
<div>3. <a href="https://etherpad.openstack.org/p/kilo-neutron-summit-topics" style="font-size:10pt" target="_blank">https://etherpad.openstack.org/p/kilo-neutron-summit-topics</a></div>
<div><br>
</div>
<div>Best Regards</div>
<div>Wu</div>
</div>
</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></blockquote><div><br></div><div>[1] <a href="https://blueprints.launchpad.net/neutron/+spec/modular-l2-agent">https://blueprints.launchpad.net/neutron/+spec/modular-l2-agent</a></div><div>[2] <a href="https://review.openstack.org/#/q/project:openstack/neutron-specs+branch:master+topic:bp/modular-L2-agent,n,z">https://review.openstack.org/#/q/project:openstack/neutron-specs+branch:master+topic:bp/modular-L2-agent,n,z</a></div></div><br></div></div></div>