<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman","serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p
        {mso-style-priority:99;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:12.0pt;
        font-family:"Times New Roman","serif";}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Courier New";
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri","sans-serif";}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link=blue vlink=purple><div class=WordSection1><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>Speaking as a ‘database guy’ and a ‘Trove guy’, I’ll say this; “Metadata” is a very generic term and the meaning of “metadata” in a database context is very different from the meaning of “metadata” in the context that Glance is providing. <o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>Furthermore the usage and access pattern for this metadata, the frequency of change, and above all the frequency of access are fundamentally different between Trove and what Glance appears to be offering, and we should probably not get too caught up in the project “title”.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>We would not be “reinventing the wheel” if we implemented an independent metadata scheme for Trove; we would be implementing the right kind of when for the vehicle that we are operating. Therefore I do not agree with your characterization that concludes that:<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>>> given goals at [1] are out of scope of Database program, etc</span><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>Just to be clear, when you write:<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>>> Unfortunately, we’re(Trove devs) are on half way to metadata …<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>it is vital to understand that our view of “metadata” is very different from (for example, a file system’s view of metadata, or potentially Glance’s view of metadata). For that reason, I believe that your comments on <a href="https://review.openstack.org/#/c/82123/16">https://review.openstack.org/#/c/82123/16</a> are also somewhat extreme.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>Before postulating a solution (or “delegating development to Glance devs”), it would be more useful to fully describe the problem being solved by Glance and the problem(s) we are looking to solve in Trove, and then we could have a meaningful discussion about the right solution. <o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>I submit to you that we will come away concluding that there is a round peg, and a square hole. Yes, one will fit in the other but the final product will leave neither party particularly happy with the end result.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'>-amrith<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Courier New";color:#1F497D'><o:p> </o:p></span></p><div style='border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt'><div><div style='border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal><b><span style='font-size:11.0pt;font-family:"Calibri","sans-serif"'>From:</span></b><span style='font-size:11.0pt;font-family:"Calibri","sans-serif"'> Denis Makogon [mailto:dmakogon@mirantis.com] <br><b>Sent:</b> Thursday, July 24, 2014 9:33 AM<br><b>To:</b> OpenStack Development Mailing List<br><b>Subject:</b> [openstack-dev] [Glance][Trove] Metadata Catalog<o:p></o:p></span></p></div></div><p class=MsoNormal><o:p> </o:p></p><div><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>Hello, Stackers.</span><o:p></o:p></p><p class=MsoNormal><br><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>     I’d like to discuss the future of Trove metadata API. But first small history info (mostly taken for Trove medata spec, see [1]):</span><o:p></o:p></p><div style='margin-left:30.0pt'><p class=MsoNormal style='margin-bottom:12.0pt'><i><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>Instance metadata is a feature that has been requested frequently by our users. They need a way to store critical information for their instances and have that be associated with the instance so that it is displayed whenever that instance is listed via the API. This also becomes very usable from a testing perspective when doing integration/ci. We can utilize the metadata to store things like what process created the instance, what the instance is being used for, etc... The design for this feature is modeled heavily on the Nova metadata API with a few tweaks in how it works internally.</span></i><o:p></o:p></p></div><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>    And here comes conflict. Glance devs are working on “Glance Metadata Catalog” feature (see [2]). And as for me, we don’t have to<i> “reinvent the wheel” for Trove. </i>It seems that we would be able </span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>to use Glance API to interact with   Metadata Catalog. And it seems to be redundant to write our own API for metadata CRUD operations.</span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>    </span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>    From Trove perspective, we need to define a list concrete use cases for metadata usage (eg given goals at [1] are out of scope of Database program, etc.). </span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>From development and cross-project integration perspective, we need to delegate all development to Glance devs. But we still able to help Glance devs with this feature by taking active part in polishing proposed spec (see [2]).</span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>    </span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>    Unfortunately, we’re(Trove devs) are on half way to metadata - patch for python-troveclient already merged. So, we need to consider deprecation/reverting of merged and block </span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>merging of proposed ( see [3]) patchsets in favor of Glance Metadata Catalog.</span><o:p></o:p></p><p class=MsoNormal style='margin-bottom:12.0pt'><br><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'><br>    Thoughts?</span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>[1] </span><a href="https://wiki.openstack.org/wiki/Trove-Instance-Metadata"><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:#1155CC'>https://wiki.openstack.org/wiki/Trove-Instance-Metadata</span></a><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>[2] </span><a href="https://review.openstack.org/#/c/98554/11"><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:#1155CC'>https://review.openstack.org/#/c/98554/11</span></a><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>[3] </span><a href="https://review.openstack.org/#/c/82123/"><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:#1155CC'>https://review.openstack.org/#/c/82123/</span></a><o:p></o:p></p><p class=MsoNormal style='margin-bottom:12.0pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>Best regards,</span><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt;text-align:justify'><span style='font-size:11.5pt;font-family:"Arial","sans-serif";color:black'>Denis Makogon</span><o:p></o:p></p></div></div></div></body></html>