<div dir="ltr"><div><div><div>Hi Zhenyu and all,<br><br></div>If you look at the problem from a different angle, for example, treating local disks on hypervisors same resource like GPU/NIC, your requirement doesn't necessarily need to involve Cinder. Local disks become a resource type associated with certain group of hypervisors, scheduling becomes easier and provisioning is also simpler because it doesn't have to talk to another service (Cinder) and do coordination between Nova and Cinder anymore.<br><br></div>In eBay, we did some inhouse change to Nova so that our big data type of use case can have physical disks as ephemeral disk for this type of flavors. It works well so far. My 2 cents.<br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Sep 26, 2016 at 9:35 AM, Zhenyu Zheng <span dir="ltr"><<a href="mailto:zhengzhenyulixi@gmail.com" target="_blank">zhengzhenyulixi@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 Matt,<div><br></div><div>Yes, we can only do this using 1:1 AZs mapped for each compute node in the deployment, which is not very <span style="font-size:12.8px">feasible in commercial deployment,</span></div><div><span style="font-size:12.8px">we can either pass some hints to Cinder(for current code, cinder "</span><span style="font-size:12.8px">InstanceLocalityFilter" uses instance uuid as parameter so it will be impossible for</span></div><div><span style="font-size:12.8px">user to pass it while booting instances)/ add filters or something else to Nova when doing Nova scheduling. And maybe we will have new solutions</span></div><div><span style="font-size:12.8px">after "Generic-resource-pool" is reached?</span></div><div><span style="font-size:12.8px"><br></span></div><div><span style="font-size:12.8px">The implementations may varies, but this could be a reasonable demands? right?</span></div><div><span style="font-size:12.8px"><br></span></div><div><span style="font-size:12.8px">Thanks</span></div></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Sun, Sep 25, 2016 at 1:02 AM, Matt Riedemann <span dir="ltr"><<a href="mailto:mriedem@linux.vnet.ibm.com" target="_blank">mriedem@linux.vnet.ibm.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>On 9/23/2016 8:19 PM, Zhenyu Zheng wrote:<br>
</span><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>
Hi,<br>
<br>
Thanks all for the information, as for the filter<br>
Erlon(InstanceLocalityFilter) mentioned, this only solves a part of the<br>
problem,<br>
we can create new volumes for existing instances using this filter and<br>
then attach to it, but the root volume still cannot<br>
be guranteed to be on the same host as the compute resource, right?<br>
<br>
The idea here is that all the volumes uses local disks.<br>
I was wondering if we already have such a plan after the Resource<br>
Provider structure has accomplished?<br>
<br>
Thanks<br>
<br>
On Sat, Sep 24, 2016 at 2:05 AM, Erlon Cruz <<a href="mailto:sombrafam@gmail.com" target="_blank">sombrafam@gmail.com</a><br></span><span>
<mailto:<a href="mailto:sombrafam@gmail.com" target="_blank">sombrafam@gmail.com</a>>> wrote:<br>
<br>
Not sure exactly what you mean, but in Cinder using the<br>
InstanceLocalityFilter[1], you can schedule a volume to the same<br>
compute node the instance is located. Is this what you need?<br>
<br>
[1] <a href="http://docs.openstack.org/developer/cinder/scheduler-filters.html#instancelocalityfilter" rel="noreferrer" target="_blank">http://docs.openstack.org/deve<wbr>loper/cinder/scheduler-filters<wbr>.html#instancelocalityfilter</a><br>
<<a href="http://docs.openstack.org/developer/cinder/scheduler-filters.html#instancelocalityfilter" rel="noreferrer" target="_blank">http://docs.openstack.org/dev<wbr>eloper/cinder/scheduler-filter<wbr>s.html#instancelocalityfilter</a>><br>
<br>
On Fri, Sep 23, 2016 at 12:19 PM, Jay S. Bryant<br>
<<a href="mailto:jsbryant@electronicjungle.net" target="_blank">jsbryant@electronicjungle.net</a><br></span><div><div>
<mailto:<a href="mailto:jsbryant@electronicjungle.net" target="_blank">jsbryant@electronicjun<wbr>gle.net</a>>> wrote:<br>
<br>
Kevin,<br>
<br>
This is functionality that has been requested in the past but<br>
has never been implemented.<br>
<br>
The best way to proceed would likely be to propose a<br>
blueprint/spec for this and start working this through that.<br>
<br>
-Jay<br>
<br>
<br>
On 09/23/2016 02:51 AM, Zhenyu Zheng wrote:<br>
</div></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div>
Hi Novaers and Cinders:<br>
<br>
Quite often application requirements would demand using<br>
locally attached disks (or direct attached disks) for<br>
OpenStack compute instances. One such example is running<br>
virtual hadoop clusters via OpenStack.<br>
<br>
We can now achieve this by using BlockDeviceDriver as Cinder<br>
driver and using AZ in Nova and Cinder, illustrated in[1],<br>
which is not very feasible in large scale production deployment.<br>
<br>
Now that Nova is working on resource provider trying to build<br>
an generic-resource-pool, is it possible to perform<br>
"volume-based-scheduling" to build instances according to<br>
volume? As this could be much easier to build instances like<br>
mentioned above.<br>
<br>
Or do we have any other ways of doing this?<br>
<br>
References:<br>
[1] <a href="http://cloudgeekz.com/71/how-to-setup-openstack-to-use-local-disks-for-instances.html" rel="noreferrer" target="_blank">http://cloudgeekz.com/71/how-t<wbr>o-setup-openstack-to-use-local<wbr>-disks-for-instances.html</a><br>
<<a href="http://cloudgeekz.com/71/how-to-setup-openstack-to-use-local-disks-for-instances.html" rel="noreferrer" target="_blank">http://cloudgeekz.com/71/how-<wbr>to-setup-openstack-to-use-loca<wbr>l-disks-for-instances.html</a>><br>
<br>
Thanks,<br>
<br>
Kevin Zheng<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></div></div>
<mailto:<a href="mailto:OpenStack-dev-request@lists.openstack.org" target="_blank">OpenStack-dev-request@<wbr>lists.openstack.org</a>?subject:un<wbr>subscribe><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>
<<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cg<wbr>i-bin/mailman/listinfo/opensta<wbr>ck-dev</a>><br>
</blockquote><span>
<br>
<br>
______________________________<wbr>______________________________<wbr>______________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe:<br>
<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></span>
<<a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">http://OpenStack-dev-request@<wbr>lists.openstack.org?subject:un<wbr>subscribe</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> <<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cg<wbr>i-bin/mailman/listinfo/opensta<wbr>ck-dev</a>><span><br>
<br>
<br>
<br>
______________________________<wbr>______________________________<wbr>______________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe:<br>
<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></span>
<<a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">http://OpenStack-dev-request@<wbr>lists.openstack.org?subject:un<wbr>subscribe</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><span><br>
<<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cg<wbr>i-bin/mailman/listinfo/opensta<wbr>ck-dev</a>><br>
<br>
<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>
</span></blockquote>
<br>
Are you asking about the scenario where you are creating a server with a source_type=blank/image/snapsh<wbr>ot bdm and nova creates the volume to attach to the server? In that case nova doesn't pass enough information to cinder to build the volume on the same host that the server is building on. Nova passes an AZ but that would mean you'd need to have 1:1 AZs mapped for each compute node in the deployment (I think?).<br>
<br>
Maybe you're thinking of like nova passing a scheduler hint to cinder telling it where to build the volume?<span><font color="#888888"><br>
<br>
-- <br>
<br>
Thanks,<br>
<br>
Matt Riedemann</font></span><div><div><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>
</div></div></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><br clear="all"><br>-- <br><div class="gmail_signature" data-smartmail="gmail_signature">Regards<br>Huang Zhiteng</div>
</div>