<div dir="ltr">Hi Zane,<div><br></div><div>Thank you for the deep analysis. I agree that doing these deep technical debates around languages hides the real problem we should focus on. Thank you for bringing back to the light.</div>
<div><br></div><div>You are right, TC highlighted that Murano did a huge step forward up to stack probably passing some important areas which should be covered in OpenStack before that. Workflows area is one of them. I think we need bring Mistral team here to find out how to align this workflows stuff with all three project Heat, Murano and Mistral. As Heat also wants to have a hooks mechanism to work with external workflow system and Murano uses Heat and workflows I think it will a lot of sense to design this properly together. It makes sense to bring TOSCA guys too as they have similar concepts in standard and Heat eventually will support TOSCA format. Having this aligned I see a Murano package as an archive with all necessary definitions and resources and Murano service will just properly pass them to related services like Heat and Mistral. I think then Murano DSL will be much more simple and probably will be closer to declarative format with some specific data operations.</div>
<div><br></div><div>What will be the best way to do this? I know that Heat team is pretty busy now with Icehouse release which will happen pretty soon. </div><div><br></div><div>I would like to have some draft before summit in Atlanta. We can polish them on the summit sessions but before some home work it will be hard.</div>
<div><br></div><div>Thanks</div><div>Georgy</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Mar 20, 2014 at 5:28 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:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">On 19/03/14 17:13, Stan Lagun wrote:<br>
</div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">
<br>
<br>
<br>
On Wed, Mar 19, 2014 at 9:18 PM, Zane Bitter <<a href="mailto:zbitter@redhat.com" target="_blank">zbitter@redhat.com</a><br></div><div><div class="h5">
<mailto:<a href="mailto:zbitter@redhat.com" target="_blank">zbitter@redhat.com</a>>> wrote:<br>
<br>
On 19/03/14 05:00, Stan Lagun wrote:<br>
<br>
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<br>
previous<br>
HOT syntax. It would blur Heat mission, confuse current users<br>
and rise a<br>
lot of questions what should and what should not be in Heat.<br>
Thats why<br>
we chose to built a system on top of Heat rather then expending HOT.<br>
<br>
<br>
+1, I agree (as we have discussed before) that it would be a mistake<br>
to shoehorn workflow stuff into Heat. I do think we should implement<br>
the hooks I mentioned at the start of this thread to allow tighter<br>
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<br>
Mistral as well would also be good, and that was part of the<br>
feedback from the TC.<br>
<br>
To me, building on top means building on top of the languages (which<br>
users will have to invest a lot of work in learning) as well, rather<br>
than having a completely different language and only using the<br>
underlying implementation(s).<br>
<br>
<br>
1. Murano application developers (publishers) are using Heat directly.<br>
It is not the case that Murano executes some HOT templates under the<br>
hood but HOT templates are essential part of application definition.<br>
Developers still write HOT templates in HOT syntax<br>
<br>
2. Please get me right here. It is not that we wanted to develop another<br>
language just for fun or to stand out from community. It is not that we<br>
wrote DSL and then started to think how we gonna use it and prove to<br>
others that is needed. We completely understand all concerns regarding<br>
new language. The only reason is that we had very concrete list of<br>
problems and use cases that we wanted to address in Murano. We did<br>
investigate on using HOT, Mistral, JavaScript, Lua and BPEL and we found<br>
overwhelming obstacles with each of those approaches. It don't pretend<br>
that having own DSL is good. Just that not having it is much worse. I'm<br>
also not a HOT expert as you are and thus can be (partially) wrong about<br>
HOT and not aware of some of its power features. If so as a technical<br>
guys we would quickly come to consensus.<br>
<br>
<br>
<br>
Now I would like to clarify why have we chosen imperative<br>
approach with DSL.<br>
<br>
You see a DSL as an alternative to HOT but it is not. DSL is<br>
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<br>
upload<br>
Python plugins to Heat engine and load them on the fly. Heat<br>
resources<br>
are written in Python which is imperative language. So that<br>
MuranoPL for<br>
the same reason.<br>
<br>
<br>
We had this exact problem in Heat, and we decided to solve it<br>
with... HOT:<br></div></div>
<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><div class=""><br>
<<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<br>
department - is going to let users upload Python code to run<br>
in-memory in their orchestration engine along with all of the other<br>
users' code.<br>
<br>
"If only there were some sort of language for defining OpenStack<br>
services that could be safely executed by users...<br>
<br>
"Of course that's exactly what we're all about on this project :).<br>
So my proposal is to allow users to define their own resource types<br>
using a Heat template."<br>
<br>
<br>
<br>
Excellent quotes! I can sign under each of them. No one would ever allow<br>
to upload Python code so we haven't used Python (and it is not the only<br>
reason not to use it)<br>
</div></blockquote>
<br>
There's a fine line between a domain-specific programming language (as opposed to a domain-specific modelling language like HOT) and a general-purpose programming language. The reason no-one would run untrusted Python code is that Python is a programming language, not that it is general-purpose.<div class="">
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
"If only there were some sort of language for defining OpenStack<br>
services that could be safely executed by users..." - we created such<br>
language.<br>
</blockquote>
<br></div>
And we found we already had one, that we successfully re-used for the purpose :)<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
It is exactly what you wanted to have then and now when it<br>
exists you say it is useless. How this ironic.<br>
</blockquote>
<br></div>
I'm not saying it's useless; I'm saying that it's *too* powerful for the job. It's clear that you guys have done amazing work and I don't want to criticise it, especially after having become aware of it only very late, but I also have serious reservations as to whether this is the right solution for OpenStack.<div class="">
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
It may be conceitedly to<br>
assume that MuranoPL is 100% is safe for all kind of attacks exists. It<br>
is not. But I know how to make it, I know it is doable because it was<br>
designed to be such. MuranoPL code is completely isolated from<br>
underlying operating system and its resources (sockets, files etc.). It<br>
is not translated to Python or any other language and thus cannot be a<br>
subject to code injection attacks. It is 100% interpreted and absolutely<br>
everything about the interpreter can be customized and controlled. You<br>
can meter everything, have ACL for every single aspect, you can limit<br>
MuranoPL execution time, number of executed instructions. Almost<br>
anything is possible. With Python even if you make it somehow 100%<br>
secure it would be hard to convince people it is. But there is no such<br>
problem with YAML DSL :)<br>
</blockquote>
<br></div>
This is all good news. I still worry that you have a very large footprint to secure.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
The only thing I cannot agree with (but I hope you prove me wrong) is<br>
that HOT is a solution for the problem. Surely you can do a lot of<br>
things in HOT. But there is even a bigger list of things that you can't.<br>
Otherwise why not Heat resources are written in Python and not in HOT?<br>
</blockquote>
<br></div>
Because there have to be some base types that you can use as building blocks. In the case of Heat, those base types are the set of things that you can create by talking to OpenStack APIs authenticated with the user's token. In the case of Mistral, I would expect it to be the set of actions that you can take by talking to OpenStack APIs authenticated with the user's token. And in the case of Murano, I would expect it to be the union of those two.<div class="">
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Can you implement auto-scaling or load-balancer using HOT alone without<br>
Python code?<br>
</blockquote>
<br></div>
We can and do implement the load-balancer using a Heat template :)<br>
<br>
You could certainly implement autoscaling yourself, but you'd have to spin up a Compute server to run it on as part of the template. Which is sort of my point.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
And what if application author (the guy that has absolutely<br>
no control over the cloud where it going to be deployed. Even not aware<br>
of its existence) needs his app to be autoscaled using Microsoft stack<br>
technologies?<br>
</blockquote>
<br></div>
I'm not sure what this means, and I feel like we're getting off-topic.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
What if cloud operator wants to have additional control<br>
on scaling strategy so that it can be bound to his billing system?<br>
</blockquote>
<br></div>
The operator can install whatever plugins they want.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
What<br>
if he wants that auto-scaling would be based on input from his existing<br>
Nagios infrastructure rather then Ceilometer?<br>
</blockquote>
<br></div>
This is supported already in autoscaling. Ceilometer just hits a URL for an alarm, but you don't have to configure it this way. Anything can hit the URL.<br>
<br>
And this is a good example for our general approach - we provide a way that works using built-in OpenStack services and a hook that allows you to customise it with your own service, running on your own machine (whether that be an actual machine or an OpenStack Compute server). What we *don't* do is provide a way to upload your own code that we then execute for you as some sort of secondary Compute service.<div class="">
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
One can imagine any number<br>
of use cases that just cannot be addressed by HOT without HOT becoming<br>
another MuranoPL. So the only option you left with for such cases is<br>
writing custom Python plugin. Now I don't want to reimplement in Python<br>
the whole auto-scaling logic just because I need some customization. But<br>
if I just patch existing Heat code then I would have to maintain my<br>
custom Heat fork and have all sorts of problems when next version of<br>
OpenStack arrives.There is a risk of introducing security breaches with<br>
my new code that would be executed with root account permissions.<br>
</blockquote>
<br></div>
I certainly hope *nobody* is running as root.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
The<br>
changes you would make to Heat would affect all tenants and may break<br>
existing resources. And making application depend on presence of some<br>
custom plugin makes it not portable across different clouds.<br>
My point here is that HOT is not sufficient for coding new resource<br>
types that are not superposition of existing resources. How can you do<br>
that with a language that cannot even do the simplest arithmetics<br>
operations?<br>
</blockquote>
<br></div>
Everything is a combination of existing resources, because the set of existing resources is the set of things which the operator provides as-a-Service. The set of things that the operator provides as a service plus the set of things that you can implement yourself on your own server (virtual or not) covers the entire universe of things. What you appear to be suggesting is that OpenStack must provide *Everything*-as-a-Service by allowing users to write their own services and have the operator execute them as-a-Service. This would be a breathtakingly ambitious undertaking, and I don't mean that in a good way.<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Which we did:<br>
<a href="https://blueprints.launchpad." target="_blank">https://blueprints.launchpad.</a>_<u></u>_net/heat/+spec/provider-__<u></u>resource<div><div class="h5"><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>><br>
<br>
<br>
We want application authors to be able to express application<br>
deployment<br>
and maintenance logic of any complexity. This may involve<br>
communication<br>
with 3rd party REST services (APIs of applications being deployed,<br>
external services like DNS server API, application licensing<br>
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<br>
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<br>
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<br>
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>
<br>
<br>
Shouldn't Mistral be able to do all of those same things too?<br>
<br>
<br>
Yes it should. In ideal world. Assembly language can do everything<br>
Python can do but you do not expect people to use assembly unless they<br>
have to. The same is true for Mistral - although it can possibly<br>
improved to do all above but you need to be real genius to write<br>
something like auto-scaling in Mistral DSL.<br>
</div></div></blockquote>
<br>
I'm still confused by this autoscaling example. We can all agree that clearly you would be insane to write your own autoscaling implementation (whatever this means) in any language when your cloud provider already has a highly-customisable one like Heat. But if you were to write your own the way to do it would be in a programming language of your choice running on a server you control. I still don't see how this has anything to do with Mistral.<br>
<br>
You listed above a list of features that, I submit, are required for both Mistral and Murano. You are proposing to implement them twice, rather than once.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
We are working closely with Mistral team and maybe once we would be able<br>
to lay all MuranoPL tasks on Mistral shoulders and consume Mistral DSL<br>
instead of our own, but this is not going to happen soon.<br>
</blockquote>
<br></div>
When the TC said "Murano is slightly too far up the stack at this point to meet the "measured progression of openstack as a whole" requirement", IMO one of the major things they meant was that you're inventing your own workflow thing, leading to duplication of effort between this and Workflow as a Service. (And Mistral folks are in turn doing the same thing by not using the same workflow library, taskflow, as the rest of OpenStack.) Candidly, I'm surprised that this is not the #1 thing on your priority list because IMO it's the #1 thing that will delay getting the project incubated.<div class="">
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Mistral DSL is<br>
good for another use cases and its developers may not like the idea of<br>
having Turing-complete language in Mistral.<br>
</blockquote>
<br></div>
They sound very wise ;)<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Talking to existing OpenStack services doesn't seem hard - you could<br>
write plugins for those, or save time (and save the user learning<br>
another language) by using python-openstackclient and its syntax.<br>
<br>
For everything else you have a small number of generic operations -<br>
e.g. post to a Marconi queue (ReST API calls to untrusted services<br>
are problematic from a security perspective) - and allow the user to<br>
handle them in their own code in a language of their choice running<br>
either on their own machine or on a sandboxed, metered Compute<br>
server, rather than in a custom Turing-complete DSL running<br>
unmetered on the Murano server.<br>
<br>
<br>
This is usually true. Usually, not alway. I can easily see how workflow<br>
may need to talk to some cloud operator proprietary services that are<br>
not accessible from VMs for security reasons. Workflow may need to<br>
</blockquote>
<br></div>
I said for everything *else*. For things the operator specifically wants you to have access to (e.g. some proprietary service they run), they would have the option of installing a native command plugin to handle it. For everything *else* you drop a message in a Marconi queue and let the user handle it.<div class="">
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
acquire some licenses before instantiating VMs. It may require to talk<br>
</blockquote>
<br></div>
Where is the license server running? Can you stick a process on it to listen for Marconi messages and generate license requests to the actual server?<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
to cloud operator's billing system or quotas management system or<br>
identity management system. There are many things that cannot be done<br>
from VMs or need to be done before VM is spawned.<br>
<br>
Calling external REST APIs is secure as long as you control the process<br>
(can limit amount of traffic, request rate, timeouts, ACLs etc). This is<br>
possible with MuranoPL.<br>
And once again - everything that is done on server-side can be metered<br>
and constrained.<br>
</blockquote>
<br></div>
It's only secure in a very narrow sense. You're effectively allowing people to use your servers to make any request they like, and that's going to be highly prone to confused-deputy-type problems. The only completely safe URLs to fetch are ones that are in the Keystone catalog, passing the token obtained from the user. (We break this rule in Heat BTW, and we should stop. It's hard once you have users though, and even harder when we can't depend on Marconi yet.)<br>
<br>
cheers,<br>
Zane.<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div class="h5">
Because DSL is a way to write custom resources (in Heats<br>
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<br>
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<br>
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<br>
of the<br>
world" - desired outcome. That is analogous to Object Model in<br>
Murano<br>
(see [1]). It is Object Model that can be compared to HOT, not<br>
DSL. As<br>
you can see it not more complex than HOT. Object Model is what<br>
end-user<br>
produces in Murano. And he event don't need to write it cause it<br>
can be<br>
composed in UI.<br>
<br>
Now because DSL provides not only a way to write sandboxed<br>
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<br>
all of<br>
this can be inferred from resource (classes) DSL declaration.<br>
Another<br>
consequence is that most of the things that can be written wrong<br>
in HOT<br>
can be verified on client side by validating classes' contracts<br>
without<br>
trying to deploy the stack and then go through error log debugging.<br>
<br>
<br>
This is being worked on:<br></div></div>
<a href="https://blueprints.launchpad." target="_blank">https://blueprints.launchpad.</a>_<u></u>_net/heat/+spec/param-__<u></u>constraints<div><div class="h5"><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>><br>
<br>
<br>
I agree that contracts can become part of HOT. Note that MuranoPL<br>
contracts are orders of magnitude more powerful than parameter<br>
constraints. This don't necessary mean that HOT needs that powerful<br>
capabilities. I'll be happy to collaborate on this in another thread/place<br>
<br>
<br>
<br>
Because all resources' attributes types their constraints are<br>
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<br>
(regular,<br>
Galera etc) MySQL implementation") UI knows how to correctly<br>
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<br>
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<br>
contributed to<br>
Heat? We definitely would like to integrate more with HOT and<br>
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<br>
integrate<br>
Heat, Murano, Mistral, Solum, Heater, TOSCA, do some integration<br>
between<br>
ex-Thermal and Murano Dashboard, be united regarding Glance<br>
usage for<br>
metadata and so on.<br>
<br>
<br>
+1<br>
<br>
To me that implies that Murano should be a relatively thin wrapper<br>
that ties together HOT and Mistral's DSL.<br>
<br>
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<br>
would<br>
ask you to share it.<br>
<br>
[1]<br></div></div>
<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>
<<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>
</blockquote><div class="HOEnZb"><div class="h5">
<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"><div><br></div>-- <br><div dir="ltr"><font color="#999999"><span style="background-color:rgb(255,255,255)">Georgy Okrokvertskhov<br>
Architect,<br><span style="font-family:arial;font-size:small">OpenStack Platform Products,</span><br>
Mirantis</span><br>
<a href="http://www.mirantis.com/" target="_blank">http://www.mirantis.com</a><br>
Tel. +1 650 963 9828<br>
Mob. +1 650 996 3284</font><br></div>
</div>