<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Mar 19, 2014 at 9:18 PM, Zane Bitter <span dir="ltr"><<a href="mailto:zbitter@redhat.com" target="_blank">zbitter@redhat.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div>On 19/03/14 05:00, Stan Lagun wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Steven,<br>
<br>
Agree with your opinion on HOT expansion. I see that inclusion of<br>
imperative workflows and ALM would require major Heat redesign and<br>
probably would be impossible without loosing compatibility with previous<br>
HOT syntax. It would blur Heat mission, confuse current users and rise a<br>
lot of questions what should and what should not be in Heat. Thats why<br>
we chose to built a system on top of Heat rather then expending HOT.<br>
</blockquote>
<br></div>
+1, I agree (as we have discussed before) that it would be a mistake to shoehorn workflow stuff into Heat. I do think we should implement the hooks I mentioned at the start of this thread to allow tighter integration between Heat and a workflow engine (i.e. Mistral).<br>
<br>
So building a system on top of Heat is good. Building it on top of Mistral as well would also be good, and that was part of the feedback from the TC.<br>
<br>
To me, building on top means building on top of the languages (which users will have to invest a lot of work in learning) as well, rather than having a completely different language and only using the underlying implementation(s).<div>
</div></blockquote><div> <br></div><div>1. Murano application developers (publishers) are using Heat directly. It is not the case that Murano executes some HOT templates under the hood but HOT templates are essential part of application definition. Developers still write HOT templates in HOT syntax<br>
<br></div><div>2. Please get me right here. It is not that we wanted to develop another language just for fun or to stand out from community. It is not that we wrote DSL and then started to think how we gonna use it and prove to others that is needed. We completely understand all concerns regarding new language. The only reason is that we had very concrete list of problems and use cases that we wanted to address in Murano. We did investigate on using HOT, Mistral, JavaScript, Lua and BPEL and we found overwhelming obstacles with each of those approaches. It don't pretend that having own DSL is good. Just that not having it is much worse. I'm also not a HOT expert as you are and thus can be (partially) wrong about HOT and not aware of some of its power features. If so as a technical guys we would quickly come to consensus.<br>
</div><div><br><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>
<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Now I would like to clarify why have we chosen imperative approach with DSL.<br>
<br>
You see a DSL as an alternative to HOT but it is not. DSL is alternative<br>
to Python-encoded resources in Heat (heat/engine/resources/*.py).<br>
Imagine how Heat would look like if you let untrusted users to upload<br>
Python plugins to Heat engine and load them on the fly. Heat resources<br>
are written in Python which is imperative language. So that MuranoPL for<br>
the same reason.<br>
</blockquote>
<br></div>
We had this exact problem in Heat, and we decided to solve it with... HOT: <a href="http://lists.openstack.org/pipermail/openstack-dev/2013-April/007989.html" target="_blank">http://lists.openstack.org/<u></u>pipermail/openstack-dev/2013-<u></u>April/007989.html</a><br>
<br>
If I may be so bold as to quote myself:<br>
<br>
"...no cloud operator in the world - not even your friendly local IT department - is going to let users upload Python code to run in-memory in their orchestration engine along with all of the other users' code.<br>
<br>
"If only there were some sort of language for defining OpenStack services that could be safely executed by users...<br>
<br>
"Of course that's exactly what we're all about on this project :). So my proposal is to allow users to define their own resource types using a Heat template."<br></blockquote><div><br><br></div><div>Excellent quotes! I can sign under each of them. No one would ever allow to upload Python code so we haven't used Python (and it is not the only reason not to use it)<br>
<br>"If only there were some sort of language for defining OpenStack services that could be safely executed by users..." - we created such language. It is exactly what you wanted to have then and now when it exists you say it is useless. How this ironic. It may be conceitedly to assume that MuranoPL is 100% is safe for all kind of attacks exists. It is not. But I know how to make it, I know it is doable because it was designed to be such. MuranoPL code is completely isolated from underlying operating system and its resources (sockets, files etc.). It is not translated to Python or any other language and thus cannot be a subject to code injection attacks. It is 100% interpreted and absolutely everything about the interpreter can be customized and controlled. You can meter everything, have ACL for every single aspect, you can limit MuranoPL execution time, number of executed instructions. Almost anything is possible. With Python even if you make it somehow 100% secure it would be hard to convince people it is. But there is no such problem with YAML DSL :)<br>
<br></div><div>The only thing I cannot agree with (but I hope you prove me wrong) is that HOT is a solution for the problem. Surely you can do a lot of things in HOT. But there is even a bigger list of things that you can't. Otherwise why not Heat resources are written in Python and not in HOT? Can you implement auto-scaling or load-balancer using HOT alone without Python code? And what if application author (the guy that has absolutely no control over the cloud where it going to be deployed. Even not aware of its existence) needs his app to be autoscaled using Microsoft stack technologies? What if cloud operator wants to have additional control on scaling strategy so that it can be bound to his billing system? What if he wants that auto-scaling would be based on input from his existing Nagios infrastructure rather then Ceilometer? One can imagine any number of use cases that just cannot be addressed by HOT without HOT becoming another MuranoPL. So the only option you left with for such cases is writing custom Python plugin. Now I don't want to reimplement in Python the whole auto-scaling logic just because I need some customization. But if I just patch existing Heat code then I would have to maintain my custom Heat fork and have all sorts of problems when next version of OpenStack arrives.There is a risk of introducing security breaches with my new code that would be executed with root account permissions. The changes you would make to Heat would affect all tenants and may break existing resources. And making application depend on presence of some custom plugin makes it not portable across different clouds.<br>
</div><div>My point here is that HOT is not sufficient for coding new resource types that are not superposition of existing resources. How can you do that with a language that cannot even do the simplest arithmetics operations?<br>
</div><div><br><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
Which we did:<br>
<a href="https://blueprints.launchpad.net/heat/+spec/provider-resource" target="_blank">https://blueprints.launchpad.<u></u>net/heat/+spec/provider-<u></u>resource</a><div><br>
<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
We want application authors to be able to express application deployment<br>
and maintenance logic of any complexity. This may involve communication<br>
with 3rd party REST services (APIs of applications being deployed,<br>
external services like DNS server API, application licensing server API,<br>
billing systems, some hardware component APIs etc) and internal<br>
OpenStack services like Trove, Sahara, Marconi and others including<br>
those that are not incubated yet and those to come in the future. You<br>
cannot have such things in HOT and when you required to you need to<br>
develop custom resource in Python. Independence on custom plugins is<br>
not good for Murano because they cannot be uploaded by end users and<br>
thus he cannot write application definition that can be imported to/run<br>
on any cloud and need to convince cloud administrator to install his<br>
Python plugin (something that is unimaginable in real life).<br>
</blockquote>
<br></div>
Shouldn't Mistral be able to do all of those same things too?<br></blockquote><div><br></div><div>Yes it should. In ideal world. Assembly language can do everything Python can do but you do not expect people to use assembly unless they have to. The same is true for Mistral - although it can possibly improved to do all above but you need to be real genius to write something like auto-scaling in Mistral DSL. <br>
We are working closely with Mistral team and maybe once we would be able to lay all MuranoPL tasks on Mistral shoulders and consume Mistral DSL instead of our own, but this is not going to happen soon. Mistral DSL is good for another use cases and its developers may not like the idea of having Turing-complete language in Mistral. <br>
</div><div><br> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
Talking to existing OpenStack services doesn't seem hard - you could write plugins for those, or save time (and save the user learning another language) by using python-openstackclient and its syntax.<br>
<br>
For everything else you have a small number of generic operations - e.g. post to a Marconi queue (ReST API calls to untrusted services are problematic from a security perspective) - and allow the user to handle them in their own code in a language of their choice running either on their own machine or on a sandboxed, metered Compute server, rather than in a custom Turing-complete DSL running unmetered on the Murano server.</blockquote>
<div><br></div><div>This is usually true. Usually, not alway. I can easily see how workflow may need to talk to some cloud operator proprietary services that are not accessible from VMs for security reasons. Workflow may need to acquire some licenses before instantiating VMs. It may require to talk to cloud operator's billing system or quotas management system or identity management system. There are many things that cannot be done from VMs or need to be done before VM is spawned.<br>
<br></div><div>Calling external REST APIs is secure as long as you control the process (can limit amount of traffic, request rate, timeouts, ACLs etc). This is possible with MuranoPL. <br></div><div>And once again - everything that is done on server-side can be metered and constrained.<br>
</div><div><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>
<br>
<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Because DSL is a way to write custom resources (in Heats terminology) it<br>
has to be Turing-complete and have all the characteristics of<br>
general-purpose language. It also has to have domain-specific features<br>
because we cannot expect that DSL users would be as skilled as Heat<br>
developers and could write such resources without knowledge on hosting<br>
engine architecture and internals.<br>
<br>
HOT DSL is declarative because all the imperative stuff is hardcoded<br>
into Heat engine. Thus all is left for HOT is to define "state of the<br>
world" - desired outcome. That is analogous to Object Model in Murano<br>
(see [1]). It is Object Model that can be compared to HOT, not DSL. As<br>
you can see it not more complex than HOT. Object Model is what end-user<br>
produces in Murano. And he event don't need to write it cause it can be<br>
composed in UI.<br>
<br>
Now because DSL provides not only a way to write sandboxed isolated code<br>
but also a lot of declarations (classes, properties, parameters,<br>
inheritance and contracts) that are mostly not present in Python we<br>
don't need Parameters or Output sections in Object Model because all of<br>
this can be inferred from resource (classes) DSL declaration. Another<br>
consequence is that most of the things that can be written wrong in HOT<br>
can be verified on client side by validating classes' contracts without<br>
trying to deploy the stack and then go through error log debugging.<br>
</blockquote>
<br></div>
This is being worked on:<br>
<a href="https://blueprints.launchpad.net/heat/+spec/param-constraints" target="_blank">https://blueprints.launchpad.<u></u>net/heat/+spec/param-<u></u>constraints</a></blockquote><div><br></div><div>I agree that contracts can become part of HOT. Note that MuranoPL contracts are orders of magnitude more powerful than parameter constraints. This don't necessary mean that HOT needs that powerful capabilities. I'll be happy to collaborate on this in another thread/place<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><br>
<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Because all resources' attributes types their constraints are known in<br>
advance (note that resource attribute may be a reference to another<br>
resource with constraints on that reference like "I want any (regular,<br>
Galera etc) MySQL implementation") UI knows how to correctly compose the<br>
environment and can point out your mistakes at design time. This is<br>
similar to how statically typed languages like C++/Java can do a lot of<br>
validation at compile time rather then in runtime as in Python.<br>
<br>
Personally I would love to see many of this features in HOT. What is<br>
your vision on this? What of the mentioned above can be contributed to<br>
Heat? We definitely would like to integrate more with HOT and eliminate<br>
all duplications between projects. I think that Murano and Heat are<br>
complimentary products that can effectively coexist. Murano provides<br>
access to all HOT features and relies on Heat for most of its<br>
activities. I believe that we need to find an optimal way to integrate<br>
Heat, Murano, Mistral, Solum, Heater, TOSCA, do some integration between<br>
ex-Thermal and Murano Dashboard, be united regarding Glance usage for<br>
metadata and so on.<br>
</blockquote>
<br></div>
+1<br>
<br>
To me that implies that Murano should be a relatively thin wrapper that ties together HOT and Mistral's DSL.<br>
<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div>
We are okay with throwing MuranoPL out if the issues<br>
it solves would be addressed by HOT.<br>
<br>
If you have a vision on how HOT can address the same domain MuranoPL<br>
does or any plans for such features in upcoming Heat releases I would<br>
ask you to share it.<br>
<br>
[1] <a href="https://wiki.openstack.org/wiki/Murano/DSL/Blueprint#Object_model" target="_blank">https://wiki.openstack.org/<u></u>wiki/Murano/DSL/Blueprint#<u></u>Object_model</a><br>
<br>
<br>
<br>
On Wed, Mar 19, 2014 at 8:06 AM, Steven Dake <<a href="mailto:sdake@redhat.com" target="_blank">sdake@redhat.com</a><br></div><div><div>
<mailto:<a href="mailto:sdake@redhat.com" target="_blank">sdake@redhat.com</a>>> wrote:<br>
<br>
Ruslan,<br>
<br>
Some of my thoughts on the evolution of the HOT DSL to date.<br>
<br>
<br>
On 03/18/2014 05:32 PM, Ruslan Kamaldinov wrote:<br>
<br>
Here is my 2 cents:<br>
<br>
I personally think that evolving Heat/HOT to what Murano needs<br>
for it's use<br>
cases is the best way to make PaaS layer of OpenStack to look<br>
and feel as a<br>
complete and fully integrated solution.<br>
<br>
Standardising these things in a project like TOSCA is another<br>
direction we all<br>
should follow. I think that TOSCA is the place where developers<br>
(like us),<br>
application developers and enterprises can collaborate to<br>
produce a common<br>
standard for application lifecycle management in the clouds.<br>
<br>
<br>
But before Murano contributors jump into direction of extending<br>
HOT to the goal<br>
of application (or system) lifecycle management, we need an<br>
agreement that this<br>
is the right direction for Heat/HOT/DSL and the Orchestration<br>
program. There are<br>
a lot of use cases that current HOT doesn't seem to be the right<br>
tool to solve.<br>
As it was said before, it's not a problem to collaborate on<br>
extending it those<br>
use cases. I'm just unsure if Heat team would like these use<br>
cases to be solved<br>
with Heat/HOT/DSL. For instance:<br>
- definition of an application which is already exposed via REST<br>
API. Think of<br>
something like Sahara (ex. Savanna) or Trove developed<br>
in-house for internal<br>
company needs. app publishers wouldn't be happy if they'll<br>
be forced to<br>
develop a new resource for Heat<br>
- definition of billing rules for an application<br>
<br>
<br>
If everyone agrees that this is the direction we all should<br>
follow, that we<br>
should expand HOT/DSL to that scope, that HOT should be the<br>
answer on "can you<br>
express it?", then awesome - we can start speaking about<br>
implementation details.<br>
<br>
If it's not the direction these projects should follow then at<br>
least finding<br>
where Heat ends and Murano starts to avoid any functionality<br>
duplication would<br>
be great.<br>
<br>
<br>
The HOT DSL for the most part, either by design or subconscious<br>
development choices, enables the application of Miller's Law[1] in a<br>
positive way. HOT as a DSL takes less then a few hours to learn and<br>
use effectively. Its relative simplicity is its *key* advantage as<br>
a DSL. DSL's by their very nature declare a desired state. It is<br>
the responsibility of the DSL processor to convert that desired<br>
state into reality. On a fundamental level, this is precisely what<br>
Heat does.<br>
<br>
A DSL by its very definition is meant to express a desired outcome<br>
without specifying the intermediate steps. To express the<br>
intermediate steps would require recording state in variables and<br>
offering conditional operations on those variables. This implies<br>
individual steps in the processing of the input to the language. If<br>
HOT were to add these sorts of features, it would no longer be a<br>
DSL, but a general purpose language (perhaps less general purpose<br>
then python or C). A DSL is by definition a declarative language. I<br>
don't like the idea of expanding the scope of HOT to add an<br>
imperative model of operation.<br>
<br>
Learning imperative languages takes inordinately more time and<br>
brainpower then learning declarative languages, especially those<br>
which generally follow the advantages provided by languages<br>
operating inside the constraints of Miller's Law. We want Heat to<br>
be dead simple to explain and learn. Realistically I'd like folks<br>
to be able to write a template in under an hour with 15 minutes of<br>
explanation, and I think we have hit that mark.<br>
<br>
The idea of expanding the scope of the Heat APIs and engine to<br>
include ALM and Workflow don't make sense to me from an engineering<br>
perspective. It over-complicates the code base. I know we have<br>
already covered those thoughts in detail on the mailing list<br>
previously and the Murano folks agree that is a bad idea.<br>
<br>
I see a parallel between expanding the scope of HOT to support ALM<br>
and Workflow and expanding the scope of the heat-engine in the same<br>
fashion that is not appealing. What would make more sense is to<br>
follow the general laws of Unix (do one thing, do it well) and layer<br>
these other possibly imperative languages on top of Heat using HOT<br>
and the Heat APIs to implement such imperative programming models.<br>
Then if someone really wanted to invest in the complexity of ALM or<br>
Workflow, they may be more willing to invest in learning the<br>
complexity of a new imperative programming language.<br>
<br>
My personal opinion is expanding the scope of HOT to include<br>
imperative programming models is not desirable for Heat in<br>
isolation. I understand such an outcome may be appealing as a<br>
holistic approach to handling the entire orchestration space, but<br>
feel the costs of learning an imperative model for HOT do not pay<br>
for the advantages of having only one language to program all the<br>
things.<br>
<br>
I see no issue with HOT remaining simple and tidy focused entirely<br>
on orchestration (taking a desired state and converting that into<br>
reality) with some other imperative language layered on top to<br>
handle workflow and ALM. I believe this separation of concerns is<br>
best for OpenStack and should be the preferred development path.<br>
<br>
Regards,<br>
-steve<br>
<br>
[1]<br></div></div>
<a href="http://en.wikipedia.org/wiki/__The_Magical_Number_Seven,___Plus_or_Minus_Two" target="_blank">http://en.wikipedia.org/wiki/_<u></u>_The_Magical_Number_Seven,___<u></u>Plus_or_Minus_Two</a><div><br>
<<a href="http://en.wikipedia.org/wiki/The_Magical_Number_Seven,_Plus_or_Minus_Two" target="_blank">http://en.wikipedia.org/wiki/<u></u>The_Magical_Number_Seven,_<u></u>Plus_or_Minus_Two</a>><br>
<br>
<br>
Thanks,<br>
Ruslan<br>
<br>
On Wed, Mar 19, 2014 at 2:07 AM, Keith Bray<br></div><div><div>
<<a href="mailto:keith.bray@rackspace.com" target="_blank">keith.bray@rackspace.com</a> <mailto:<a href="mailto:keith.bray@rackspace.com" target="_blank">keith.bray@rackspace.<u></u>com</a>>> wrote:<br>
<br>
Georgy,<br>
<br>
In consideration of the "can you express it" instead of the<br>
"who will<br>
generate it," I see Heat's HOT evolving to support the<br>
expression of complex<br>
multi-tier architectures and applications (I would argue you<br>
can already do<br>
this today, perhaps with some additional features desired,<br>
e.g. Ability to<br>
define cloud workflows and workflow execution rules which<br>
could come when we<br>
have a workflow service like Mistral). Therefore, I would<br>
encourage Murano<br>
contributors to consider whether they can help make Heat<br>
sufficiently cover<br>
desired use cases. I have never viewed Heat templates as<br>
isolated<br>
components of a multi-tier architecture. Instead, a single<br>
template or a<br>
combination of master/subordinate templates together (using<br>
references,<br>
nesting, or inclusion) could express the complete<br>
architecture, both<br>
infrastructure and applications.<br>
<br>
If I've read your previous comments and threads correctly,<br>
you desire a way<br>
to express System Lifecycle Management across multiple<br>
related applications<br>
or components, whereby you view the System as a grouping of<br>
independently<br>
developed and/or deployed (but systematically related)<br>
"components," whereby<br>
you view Components as individual disconnected Heat<br>
templates that<br>
independently describe different application stacks of the<br>
System. Did I<br>
get that correct? If so, perhaps the discussion here is<br>
one of "scope" of<br>
what can or should be expressed in a Heat template. Is it<br>
correct to state<br>
that your argument is that a separate system (such as<br>
Murano) should be used<br>
to express System Lifecycle Management as I've defined it<br>
here? If so, why<br>
could we not use the Heat DSL to also define the System?<br>
The System<br>
definition could be logically separated out into its own<br>
text file... But,<br>
we'd have a common DSL syntax and semantics for both lower<br>
level and higher<br>
level component interaction (a building block effect of sorts).<br>
<br>
As for "who will generate it," ( with "it" being the Heat<br>
multi-tier<br>
application/infrastructure definition) I think that question<br>
will go through<br>
a lot more evolution and could be any number of sources:<br>
e.g. Solum, Murano,<br>
Horizon, Template Author with a text editor, etc.<br>
<br>
Basically, I'm a +1 for as few DSLs as possible. I support<br>
the position that<br>
we should evolve HOT if needed vs. having two separate DSLs<br>
that are both<br>
related to expressing application and infrastructure semantics.<br>
<br>
Workflow is quite interesting ... Should we be able to<br>
express imperative<br>
workflow semantics in HOT? Or, should we only be able to<br>
declare workflow<br>
configurations that get configured in a service like Mistral<br>
whereby<br>
Mistral's execution of a workflow may need to invoke Heat<br>
hooks or Stack<br>
Updates? Or, some other solution?<br>
<br>
I look forward to a design discussion on all this at the<br>
summit... This is<br>
fun stuff to think about!<br>
<br>
-Keith<br>
<br>
From: Georgy Okrokvertskhov <<a href="mailto:gokrokvertskhov@mirantis.com" target="_blank">gokrokvertskhov@mirantis.com</a><br></div></div>
<mailto:<a href="mailto:gokrokvertskhov@mirantis.com" target="_blank">gokrokvertskhov@<u></u>mirantis.com</a>>><div><br>
<br>
Reply-To: "OpenStack Development Mailing List (not for usage<br>
questions)"<br></div>
<openstack-dev@lists.__<a href="http://openstack.org" target="_blank">opensta<u></u>ck.org</a><br>
<mailto:<a href="mailto:openstack-dev@lists.openstack.org" target="_blank">openstack-dev@lists.<u></u>openstack.org</a>>><div><br>
Date: Tuesday, March 18, 2014 1:49 PM<br>
<br>
To: "OpenStack Development Mailing List (not for usage<br>
questions)"<br></div>
<openstack-dev@lists.__<a href="http://openstack.org" target="_blank">opensta<u></u>ck.org</a><br>
<mailto:<a href="mailto:openstack-dev@lists.openstack.org" target="_blank">openstack-dev@lists.<u></u>openstack.org</a>>><div><br>
Subject: Re: [openstack-dev] [Murano][Heat] MuranoPL questions?<br>
<br>
I see this in the following way - who will generate HOT<br>
template for my<br>
complex multi-tier applications when I have only templates<br>
for components?<br>
<br>
<br></div>
______________________________<u></u>___________________<br>
OpenStack-dev mailing list<br>
OpenStack-dev@lists.openstack.<u></u>__org<br>
<mailto:<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.<u></u>openstack.org</a>><br>
<a href="http://lists.openstack.org/__cgi-bin/mailman/listinfo/__openstack-dev" target="_blank">http://lists.openstack.org/__<u></u>cgi-bin/mailman/listinfo/__<u></u>openstack-dev</a><br>
<<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/<u></u>cgi-bin/mailman/listinfo/<u></u>openstack-dev</a>><br>
<br>
______________________________<u></u>___________________<br>
OpenStack-dev mailing list<br>
OpenStack-dev@lists.openstack.<u></u>__org<br>
<mailto:<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.<u></u>openstack.org</a>><br>
<a href="http://lists.openstack.org/__cgi-bin/mailman/listinfo/__openstack-dev" target="_blank">http://lists.openstack.org/__<u></u>cgi-bin/mailman/listinfo/__<u></u>openstack-dev</a><br>
<<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/<u></u>cgi-bin/mailman/listinfo/<u></u>openstack-dev</a>><br>
<br>
<br>
<br>
______________________________<u></u>___________________<br>
OpenStack-dev mailing list<br>
OpenStack-dev@lists.openstack.<u></u>__org<br>
<mailto:<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.<u></u>openstack.org</a>><br>
<a href="http://lists.openstack.org/__cgi-bin/mailman/listinfo/__openstack-dev" target="_blank">http://lists.openstack.org/__<u></u>cgi-bin/mailman/listinfo/__<u></u>openstack-dev</a> <<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/<u></u>cgi-bin/mailman/listinfo/<u></u>openstack-dev</a>><div>
<br>
<br>
<br>
<br>
<br>
--<br>
Sincerely yours<br>
Stanislav (Stan) Lagun<br>
Senior Developer<br>
Mirantis<br>
35b/3, Vorontsovskaya St.<br>
Moscow, Russia<br>
Skype: stanlagun<br>
</div><div><a href="http://www.mirantis.com" target="_blank">www.mirantis.com</a> <<a href="http://www.mirantis.com/" target="_blank">http://www.mirantis.com/</a>><br>
<a href="mailto:slagun@mirantis.com" target="_blank">slagun@mirantis.com</a> <mailto:<a href="mailto:slagun@mirantis.com" target="_blank">slagun@mirantis.com</a>><br>
<br>
<br></div><div>
______________________________<u></u>_________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.openstack.<u></u>org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/<u></u>cgi-bin/mailman/listinfo/<u></u>openstack-dev</a><br>
<br>
</div></blockquote><div><div>
<br>
<br>
______________________________<u></u>_________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.openstack.<u></u>org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/<u></u>cgi-bin/mailman/listinfo/<u></u>openstack-dev</a><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br><div dir="ltr"><span style="text-indent:0px;letter-spacing:normal;font-variant:normal;font-style:normal;font-weight:normal;line-height:normal;border-collapse:separate;text-transform:none;font-size:medium;white-space:normal;font-family:'Times New Roman';word-spacing:0px"><span style="font-family:arial;font-size:small">Sincerely yours<br>
Stanislav (Stan) Lagun<br>Senior Developer<br>Mirantis</span></span><br><span style="text-indent:0px;letter-spacing:normal;font-variant:normal;font-style:normal;font-weight:normal;line-height:normal;border-collapse:separate;text-transform:none;font-size:medium;white-space:normal;font-family:'Times New Roman';word-spacing:0px"><span style="font-family:arial;font-size:small"><span style="font-size:10pt;font-family:"Arial","sans-serif"" lang="EN-US">35b/3, Vorontsovskaya
St.</span><br>Moscow, Russia<br>Skype: stanlagun<br><a href="http://www.mirantis.com/" target="_blank">www.mirantis.com</a><br><a href="mailto:slagun@mirantis.com" target="_blank">slagun@mirantis.com</a></span></span></div>
</div></div>