<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><br><div><div>On 12 нояб. 2013 г., at 19:04, Thomas Spatzier <<a href="mailto:thomas.spatzier@de.ibm.com">thomas.spatzier@de.ibm.com</a>> wrote:</div><br><blockquote type="cite">If yes, is there a way for passing data around - e.g. output produced by<br>one software config step is input for another software config step?<br></blockquote><div><br></div><div>Thomas, yes, we’re planning to have a data flow mechanism similar to what you described here. In conjunction with using HA transport (such as RabbitMQ) it will be very useful feature. We’ll share our design on that soon. For now you can take a look at the slides prepared for HK summit at <a href="http://www.slideshare.net/RenatAkhmerov/mistral-hong-kong-unconference-track">http://www.slideshare.net/RenatAkhmerov/mistral-hong-kong-unconference-track</a> and particularly at slide 14 about data flow. Please also feel free to ask any questions about the project and share your thoughts with us.</div><br><blockquote type="cite">Regards,<br>Thomas<br><br>Angus Salkeld <<a href="mailto:asalkeld@redhat.com">asalkeld@redhat.com</a>> wrote on 12.11.2013 02:15:15:<br><blockquote type="cite">From: Angus Salkeld <<a href="mailto:asalkeld@redhat.com">asalkeld@redhat.com</a>><br>To: <a href="mailto:openstack-dev@lists.openstack.org">openstack-dev@lists.openstack.org</a>,<br>Date: 12.11.2013 02:18<br>Subject: [openstack-dev] [Mistral] really simple workflow for Heat<br>configuration tasks<br><br>Hi all<br><br>I think some of you were at the Software Config session at summit,<br>but I'll link the ideas that were discussed:<br><a href="https://wiki.openstack.org/wiki/Heat/Blueprints/hot-software-config-WIP">https://wiki.openstack.org/wiki/Heat/Blueprints/hot-software-config-WIP</a><br>https://wiki.openstack.org/wiki/Heat/Blueprints/hot-software-config<br><br>To me the basics of it are:<br>1. we need an entity/resource to place the configuration (in Heat)<br>2. we need a resource to install the configuration<br>    (basically a task in Mistral)<br><br><br>A big issue to me is the conflict between heat's taskflow and the new<br>external one. What I mean by conflict is that it will become tricky<br>to manage two parallel taskflow instances in one stack.<br><br>This could be solved by:<br>1: totally using mistral (only use mistral workflow)<br>2: use a very simple model of just asking mistral to run tasks (no<br>    workflow) this allows us to use heat's workflow<br>    but mistral's task runner.<br><br>Given that mistral has no real implementation yet, "2" would seem<br>reasonable to me. (I think Heat developers are open to "1" when<br>Mistral is more mature.)<br><br>How could we use Mistral for config installation?<br>-------------------------------------------------<br>1. We have a resource type in Heat that creates tasks in a Mistral<br>    workflow (manual workflow).<br>2. Heat pre-configures the server to have a Mistral worker<br>    installed.<br>3. the Mistral worker pulls tasks from the workflow and passes them<br>    to an agent that can run it. (the normal security issues jump up<br>    here - giving access to the taskflow from a guest).<br><br>To do this we need an api that can add tasks to a workflow dynamically.<br>like this:<br>- create a simple workflow<br>- create and run task A [run on server X]<br>- create and run task B [run on server Y]<br>- create and run task C [run on server X]<br><br>(note: the task is run and completes before the next is added if there<br>        is a dependancy, if tasks can be run in parallel then we add<br></blockquote>multiple<br><blockquote type="cite">        tasks)<br><br>The api could be something like:<br>CRUD <mistral>/workflows/<br>CRUD <mistral>/workflows/<wf>/tasks<br><br><br>One thing that I am not sure of is how a server(worker) would know if a<br></blockquote>task<br><blockquote type="cite">was for it or not.<br>- perhaps we have a capability property of the task that we can use<br>   (capablitiy[server] = <server-id>) or actually specify the worker we<br>   want.<br><br>I think this would be a good starting point for Mistral as it is a<br>very simple but concrete starting point. Also if this is not done in<br>Mistral we will have to add this in Heat (lets rather have it where<br>it should be). This will also give us a chance to have confidence<br>with Mistral before trying to do more complex workflows.<br><br>If you (Heat and Mistral developers) are open to this we can discuss<br>what needs to be done. I am willing to help with implementation.<br><br>Thanks<br>-Angus<br><br><br><br><br>_______________________________________________<br>OpenStack-dev mailing list<br><a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev<br><br></blockquote><br><br>_______________________________________________<br>OpenStack-dev mailing list<br><a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev<br></blockquote></div><br></body></html>