<div dir="ltr"><div>Hi Matt!</div><div><br></div><div>This should be discussed, for sure, but there is a lot of potential. In general, it depends on how far we are willing to go. In the minimum approximation we can seamlessly replace Glance with Glare and operators simply get additional features for versioning, validation (and conversion, if necessary) of their uploaded images on the fly, as well as support for storing files in different stores.</div><div><br></div><div>If we dig a little deeper, then Glare allows you to store multiple files in a single artifact, so we can create a new type (ec2_image) and define three blobs inside: ami, ari, aki, and upload all three as a single object. This will get rid of a large amount of legacy code and simplify the architecture of Nova. Plus Glare will control the integrity of such artifact.</div><div><br></div><div>The next step could be full support for OVF and other formats that require a large number of files. Here we can use artifact folders and put all the files there.</div><div>"<span style="color:rgb(51,51,51);font-family:"open sans",helvetica,arial,sans-serif;font-size:14px">OpenStack Compute does not currently have support for OVF packages, so you will need to extract the image file(s) from an OVF package if you wish to use it with OpenStack." </span><font color="#333333" face="open sans, helvetica, arial, sans-serif"><span style="font-size:14px"><a href="http://docs.openstack.org/image-guide/introduction.html">http://docs.openstack.org/image-guide/introduction.html</a></span></font><br></div><div><br></div><div>Finally, I notice that there are a few nasty bugs in Glance (you know what I mean), which make it extremely inconvenient for a number of deployments.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jan 18, 2017 at 8:26 PM, 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"><div class="HOEnZb"><div class="h5">On 1/18/2017 10:54 AM, Mikhail Fedosin wrote:<br>
</div></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div class="h5">
Hello!<br>
<br>
In this letter I want to tell you the current status of Glare project<br>
and discuss its future development within the entire OpenStack community.<br>
<br>
In the beginning I have to say a few words about myself - my name is<br>
Mike and I am the PTL of Glare. Currently I work as a consultant at<br>
Nokia, where we're developing the service as a universal catalog of<br>
binary data. As I understand it right, Nokia has big plans for this<br>
service, Moshe Elisha can tell you more about them.<br>
<br>
And here I want to ask the community - how exactly Glare may be useful<br>
in OpenStack? Glare was developed as a repository for all possible data<br>
types, and it has many possible applications. For example, it's a<br>
storage of vm images for Nova. Currently Glance is used for this, but<br>
Glare has much more features and this transition is easy to implement.<br>
Then it's a storage of Tosca templates. We were discussing integration<br>
with Heat and storing templates and environments in Glare, also it may<br>
be interesting for TripleO project. Mistral will store its workflows in<br>
Glare, it has already been decided. I'm not sure if Murano project is<br>
still alive, but they already use Glare 0.1 from Glance repo and it will<br>
be removed soon (in Pike afaik), so they have no other options except to<br>
start using Glare v1. Finally there were rumors about storing torrent<br>
files from Ironic.<br>
<br>
Now let me briefly describe Glare features:<br>
<br>
* Versioning of artifacts - each artifact has a version in SemVer<br>
format and you can sort and filter by this field.<br>
* Multiblob support - there can be several files and folders per one<br>
artifact.<br>
* The ease of creating new artifact types with oslo_versionedobjects<br>
framework.<br>
* Fair immutability - no one can change artifact when it's active.<br>
* Multistore support - each artifact type data may be stored in<br>
different storages: images may go to Swift; heat templates may be stored<br>
directly in sql-database; for Docker Contatiners you can use Ceph, if<br>
you want.<br>
* Advanced sorting and filtering with various operators.<br>
* Uploaded data validation and conversion with hooks - for example,<br>
Glare may check if uploaded file was a valid Tosca template and return<br>
Bad Request if it's not.<br>
<br>
If you're interested, I recorded several demos in asciinema, that<br>
describe how Glare works and present the most useful features. Another<br>
demo about uploading hooks will be recorded and published this week.<br>
<br>
So, please tell me what you think and recommend in what direction we<br>
should develop the project. Thanks in advance!<br>
<br>
Best,<br>
Mike<br>
<br>
Useful links:<br>
[1] Api documentation in rst format:<br>
<a href="https://etherpad.openstack.org/p/glare-api" rel="noreferrer" target="_blank">https://etherpad.openstack.org<wbr>/p/glare-api</a><br>
[2] Basic artifact workflow on devstack: <a href="https://asciinema.org/a/97985" rel="noreferrer" target="_blank">https://asciinema.org/a/97985</a><br>
[3] Listing of artifacts: <a href="https://asciinema.org/a/97986" rel="noreferrer" target="_blank">https://asciinema.org/a/97986</a><br>
[4] Creating your own artifact type with oslo_vo:<br>
<a href="https://asciinema.org/a/97987" rel="noreferrer" target="_blank">https://asciinema.org/a/97987</a><br>
[5] Locations, Tags, Links and Folders in Glare:<br>
<a href="https://asciinema.org/a/99771" rel="noreferrer" target="_blank">https://asciinema.org/a/99771</a><br>
<br>
<br></div></div>
______________________________<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>
</blockquote>
<br>
What use cases does Glare make available to Nova that Nova doesn't already get from Glance? In other words, what problems/missing features are there in Nova that can't be solved by Glance but can by Glare?<span class="HOEnZb"><font color="#888888"><br>
<br>
-- <br>
<br>
Thanks,<br>
<br>
Matt Riedemann<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>
</font></span></blockquote></div><br></div>