<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Hi OpenStackers,<div><br></div><div>There’s been recently a lot of questions in OpenStack community about the particular real life use cases that the new Mistral project addresses.</div><div><br></div><div>So I’d like to present the description of one of the interesting Mistral use cases so that we could discuss it together. You can also find a wiki version with pictures at <a href="https://wiki.openstack.org/wiki/Mistral#Tasks_Scheduling_-_Cloud_Cron">https://wiki.openstack.org/wiki/Mistral#Tasks_Scheduling_-_Cloud_Cron</a> as well as other useful information about the project.</div><div><br></div><div>More use cases are on their way.</div><div><br></div><div>—————</div><div><br></div><div><span id="docs-internal-guid-29c347db-f0ce-e5b8-8278-80f652d3d5a2"><span style="font-size: 21px; font-family: 'Trebuchet MS'; vertical-align: baseline; white-space: pre-wrap;">Mistral Use Cases: Tasks Scheduling - Cloud Cron</span></span></div><div><span id="docs-internal-guid-6399326d-f0c9-6baf-be9d-06940a1a005c"><h2 dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;"><span style="font-size: 17px; font-family: 'Trebuchet MS'; vertical-align: baseline; white-space: pre-wrap;">Problem Statement</span></h2><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">Pretty often while administering a network of computers there’s a need to establish periodic on-schedule execution of </span><span style="font-size: 15px; font-family: Arial; color: rgb(17, 17, 17); background-color: rgb(255, 255, 255); vertical-align: baseline; white-space: pre-wrap;">maintenance</span><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;"> jobs for doing various kinds of work that otherwise would have to be started manually by a system administrator. The set of such jobs ranges widely from cleaning up needless log files to health monitoring and reporting. One of the most commonly known tools in Unix world to set up and manage those periodic jobs is </span><span style="font-size: 15px; font-family: Arial; font-weight: bold; vertical-align: baseline; white-space: pre-wrap;">Cron</span><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">. It perfectly fits the uses cases mentioned above. For example, using Cron we can easily schedule any system process for running every even day of week at 2.00 am. For a single machine it’s fairly straightforward how to administer jobs using Cron and the approach itself has been adopted by millions of IT folks all over the world.</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">Now what if we want to be able to set up and manage on-schedule jobs for multiple machines? It would be very convenient to have a single point of control over their schedule and themselves (i.e. “when” and “what”). Furthermore, when it comes to a cloud environment the cloud provides additional RESTful services (and not only RESTful) that we may also want to call in on-schedule manner along with operating system local processes.</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 17px; font-family: 'Trebuchet MS'; font-weight: bold; vertical-align: baseline; white-space: pre-wrap;">Solution</span><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;"></span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">Mistral service for OpenStack cloud addresses this demand naturally. Its capabilities allow configuring any number of tasks to be run according to a specified schedule in a scale of a cloud. Here’s the list of some typical jobs we can choose from:</span></p><ul style="margin-top:0pt;margin-bottom:0pt;"><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">Run a shell script on specified virtual instances (e.g. VM1, VM3 and VM27).</span></p></li><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">Run an arbitrary system process on specified instances.</span></p></li><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">Start/Reboot/Shutdown instances.</span></p></li><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">Call an accessible cloud services (e.g. Trove).</span></p></li><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">Add instances to a load balancer.</span></p></li><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">Deploy an application on specified instances.</span></p></li></ul><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">This list is not full and any other user meaningful jobs can be added. To make it possible Mistral provides a plugin mechanism so that it’s pretty easy to add new functionality via supplying new Mistral plugins.</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">Basically, Mistral acts as a mediator between a user, virtual instances and cloud services in a sense that it brings capabilities over them like task management (start, stop etc.), task state and execution monitoring (success, failure, in progress etc.) and task scheduling.</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">Since Mistral is a distributed workflow engine those types of jobs listed above can be combined in a single logical unit, a workflow. For example, we can tell Mistral to take care of the following workflow for us:</span></p><ul style="margin-top:0pt;margin-bottom:0pt;"><li dir="ltr" style="list-style-type: disc; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="vertical-align: baseline; white-space: pre-wrap;">On every Monday at 1.00 am start grepping phrase “Hello, Mistral!” from log files located at /var/log/myapp.log on instances VM1, VM30, VM54 and put the results in Swift.</span></p></li><ul style="margin-top:0pt;margin-bottom:0pt;"><li dir="ltr" style="list-style-type: circle; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-style: italic; vertical-align: baseline; white-space: pre-wrap;">On success</span><span style="vertical-align: baseline; white-space: pre-wrap;">: Generate the report based on the data in Swift.</span></p></li><ul style="margin-top:0pt;margin-bottom:0pt;"><li dir="ltr" style="list-style-type: square; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-style: italic; vertical-align: baseline; white-space: pre-wrap;">On success</span><span style="vertical-align: baseline; white-space: pre-wrap;">: Send the generated report to an email address.</span></p></li><li dir="ltr" style="list-style-type: square; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-style: italic; vertical-align: baseline; white-space: pre-wrap;">On failure</span><span style="vertical-align: baseline; white-space: pre-wrap;">: Send an SMS with error details to a system administrator.</span></p></li></ul><li dir="ltr" style="list-style-type: circle; font-size: 15px; font-family: Arial; vertical-align: baseline;"><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-style: italic; vertical-align: baseline; white-space: pre-wrap;">On failure</span><span style="vertical-align: baseline; white-space: pre-wrap;">: Send an SMS with error details to a system administrator.</span></p></li></ul></ul><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">A workflow similar to the one described above may be of any complexity but still considered a single task from a user perspective. However, Mistral is smart enough to analyze the workflow and identify individual sequences that can be run in parallel thereby taking advantage of distribution and load balancing under the hood.</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">It is worth noting that Mistral is nearly linearly scalable and hence is capable to schedule and process virtually any number of tasks simultaneously.</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 17px; font-family: 'Trebuchet MS'; font-weight: bold; vertical-align: baseline; white-space: pre-wrap;">Notes</span></p><p dir="ltr" style="line-height:1.15;margin-top:10pt;margin-bottom:0pt;text-align: justify;"><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;">So in this use case description we tried to show how Mistral capabilities can be used for scheduling different user tasks in a cloud scale. Semantically it would be correct to call this use case Distributed Con or Cloud Cron. One of the advantages of using a service like Mistral in case like this is that along with base functionality to schedule and execute tasks it provides additional capabilities like navigating over task execution status and history (using web UI or REST API), replaying already finished tasks, on-demand task suspension and resumption and many other things that are useful for both system administrators and application developers.</span><span style="font-size: 17px; font-family: 'Trebuchet MS'; vertical-align: baseline; white-space: pre-wrap;"></span></p><div><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;"><br></span></div><div><span style="font-size: 15px; font-family: Arial; vertical-align: baseline; white-space: pre-wrap;"><br></span></div><div>Renat Akhmerov</div><div>@ Mirantis Inc.</div><div><font face="Arial"><span style="font-size: 15px; white-space: pre-wrap;"><br></span></font></div></span></div></body></html>