<div dir="ltr"><div>Hello Takashi and Neutrinos:</div><div><br></div><div>First of all, thank you for working on this.</div><div><br></div><div>Currently users have the ability to override the host name using "resource_provider_hypervisors". That means this parameter is always configurable; IMO we are safe on this.</div><div><br></div><div>The problem we have is how we should retrieve this host name if "resource_provider_hypervisors" is not provided. I think the solution could be a combination of:</div><div><ul><li>A first patch providing the ability to select the hypervisor type. The default one could be "libvirt". Each driver can have a particular host name retrieval implementation. The default one will be the implemented right now: "socket.gethostname()"</li><li><a href="https://review.opendev.org/c/openstack/neutron/+/788893">https://review.opendev.org/c/openstack/neutron/+/788893</a>, providing full compatibility for <span id="gmail-output">libvirt.<br></span></li></ul></div><div><span id="gmail-output"></span></div><div><span id="gmail-output">Those are my two cents.</span></div><div><span id="gmail-output"><br></span></div><div><span id="gmail-output">Regards.</span></div><div><span id="gmail-output"><br></span></div><div><span id="gmail-output"><br></span></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 10, 2021 at 4:12 PM Takashi Kajinami <<a href="mailto:tkajinam@redhat.com">tkajinam@redhat.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Hi All,<br><br><br><div>I've been working on bug 1926693[1], and am lost about the reasonable</div><div>solutions we expect. Ideally I'd need to bring this topic in the team meeting</div><div>but because of the timezone gap and complicated background, I'd like to</div><div>gather some feedback in ml first.<br></div><br>[1] <a href="https://bugs.launchpad.net/neutron/+bug/1926693" target="_blank">https://bugs.launchpad.net/neutron/+bug/1926693</a><br><br>TL;DR<br> Which one(or ones) would be reasonable solutions for this issue ?<br> (1) <a href="https://review.opendev.org/c/openstack/neutron/+/763563" target="_blank">https://review.opendev.org/c/openstack/neutron/+/763563</a><br> (2) <a href="https://review.opendev.org/c/openstack/neutron/+/788893" target="_blank">https://review.opendev.org/c/openstack/neutron/+/788893</a><br> (3) Implement something different<br><br><div>The issue I reported in the bug is that there is an inconsistency between</div><div>nova and neutron about the way to determine a hypervisor name.</div><div>Currently neutron uses socket.gethostname() (which always returns shortname)</div><div>to determine a hypervisor name to search the corresponding resource provider.<br></div><div>On the other hand, nova uses libvirt's getHostname function (if libvirt driver is used)</div><div>which returns a canonical name. Canonical name can be shortname or FQDN (*1)</div><div>and if FQDN is used then neutron and nova never agree.</div><div><br></div><div>(*1)</div><div><div>IMO this is likely to happen in real deployments. For example, TripelO uses</div><div>FQDN for canonical names.</div></div><br>Neutron already provides the resource_provider_defauly_hypervisors option<br>to override a hypervisor name used. However because this option accepts<br>a map between interface and hypervisor, setting this parameter requires<br>very redundant description especially when a compute node has multiple<br>interfaces/bridges. The following example shows how redundant the current<br>requirement is.<br>~~~<br>[OVS]<br>resource_provider_bandwidths=br-data1:1024:1024,br-data2:1024:1024,\<br>br-data3:1024,1024,br-data4,1024:1024<br>resource_provider_hypervisors=br-data1:compute0.mydomain,br-data2:\<br>compute0.mydomain,br-data3:compute0.mydomain,br-data4:compute0.mydomain<br>~~~<br><br>I've submitted a change to propose a new single parameter to override<br>the base hypervisor name but this is currently -2ed, mainly because<br>I lacked analysis about the root cause of mismatch when I proposed this.<br> (1) <a href="https://review.opendev.org/c/openstack/neutron/+/763563" target="_blank">https://review.opendev.org/c/openstack/neutron/+/763563</a><br><br><br>On the other hand, I submitted a different change to neutron which implements<br>the logic to get a hypervisor name which is fully compatible with libvirt.<br>While this would save users from even overriding hypervisor names, I'm aware<br>that this might break the other virt driver which depends on a different logic<br>to generate a hypervisor name. IMO the patch is still useful considering<br>the libvirt driver would be the most popular option now, but I'm not fully<br>aware of the impact on the other drivers, especially because I don't know<br>which virt driver would support the minimum QoS feature now.<br> (2) <a href="https://review.opendev.org/c/openstack/neutron/+/788893/" target="_blank">https://review.opendev.org/c/openstack/neutron/+/788893/</a><br><br><br>In the review of (2), Sean mentioned implementing a logic to determine<br>an appropriate resource provider(3) even if there is a mismatch about<br>host name format, but I'm not sure how I would implement that, tbh.<br><br><br><div>My current thought is to merge (1) as a quick solution first, and discuss whether</div><div>we should merge (2), but I'd like to ask for some feedback about this plan</div><div>(like we should NOT merge (2)).<br></div><br><div>I'd appreciate your thoughts about this $topic.</div><div><br></div><div>Thank you,</div><div>Takashi<br></div></div>
</blockquote></div>