Managing Deployment Workflows
Workflows are automation process algorithms. They describe the flow of the automation by determining which tasks will be executed and when. A task may be an operation (implemented by a plugin), or other actions including running arbitrary code. Workflows are written in Python, using a dedicated framework and APIs.
Workflows are deployment-specific. Each deployment has its own set of workflows, which are declared in the Blueprint. Executions of a workflow are in the context of that deployment.
Controlling workflows (i.e. executing, cancelling, etc.) is achieved using REST calls to the management server. In this guide, the examples use Conductor CLI commands, which in turn call the REST API calls.
Executing Workflows
Workflows can be executed directly. You can execute workflows from the CLI as follows:
cfy executions start my_workflow -d my_deployment
This executes the my_workflow
workflow on the my_deployment
deployment.
Workflows run on deployment-dedicated workers on the management server, on top of the Studio Conductor workflow engine.
When a workflow is executed, an execution object is created for the deployment, containing both static and dynamic information about the workflow’s execution run. The status
field in the Execution object is an important dynamic field that conveys the current state of the execution.
An execution is considered to be a running execution until it reaches one of the three final statuses: terminated
, failed
or cancelled
. For more information, see the Workflow Execution Statuses section on this page.
It is recommended that you have only one running execution per deployment at any time. By default, an attempt to execute a workflow while another execution is running for the same deployment triggers an error. To override this behavior and enable multiple executions to run in parallel, use the force
flag for each execute command. To view the syntax reference, see the CLI Commands Reference.
Queuing Executions
In general, executions run in parallel. There are a few exceptions:
- When a system-wide execution is running (e.g.
snapshots create
), no other execution will be allowed to start. - Two executions under the same deployment cannot run in parallel.
- System-wide executions (e.g.
snapshots create
) cannot start while an execution (e.g.install
workflow) is running.
If you start an execution and receive one of the following errors: “You cannot start an execution if there is a running system-wide execution” / “The following executions are currently running for this deployment…” / “You cannot start a system-wide execution if there are other executions running.”, you can add the execution to the executions queue:
cfy executions start -d deployment1 install --queue
cfy snapshots create --queue
Queued executions will begin automatically when possible.
- If an execution can start immediately it will, even when the
queue
flag is passed. - If the queue contains a system-wide execution waiting to start (e.g. snapshot create), Studio Conductor will not accept any
other execution request unless the
queue
flag is passed. This behavior ensures there is no starvation of blocking system operations. If thequeue
flag isn’t provided, an error will be returned.
Scheduling Executions
Conductor allows the user to create schedules for running executions at specified times, both single-use and recurring. Execution schedules, also known as deployment schedules, belong to a specific deployment and can be created in two ways:
- By using the dedicated CLI command:
cfy deployments schedule create
- By specifying under the
deployment_settings
section in a blueprint, the default schedules that should be created for any deployment based on this blueprint.
Each deployment schedule contains the following information, provided by the user:
* Which workflow to run (e.g. install
, uninstall
etc.)
* Execution arguments and additional parameters to be passed to the workflow
* since
: the earliest time at which the workflow can run
* until
: the latest time at which the workflow can run
* Scheduling parameters, either in human-readable format (recurrence frequency, on which weekdays to run, max. number of runs), or as an iCalendar RRULE
The schedules are then polled by the cloudify-execution-scheduler
service, which runs continuously in the background.
* Schedules are polled every 60 seconds, and those which have executions at the given time are run.
* When the manager is in maintenance mode, the scheduler won’t run any executions. Executions scheduled for this time are skipped.
* if polling and firing the scheduled executions to run takes more than 60 seconds, the scheduler will wait for the remainder of a whole minute to poll, so if an execution is scheduled to run every minute and takes e.g. 70 seconds to fire, it will actually run every 2 minutes.
As of version 6.4, The UI side of deployment schedules is not yet up to speed
with the new scheduling mechanism, so currently in order to see what’s
scheduled in the manager, use cfy deployments schedule list
, or cfy deployments
schedule get DEPLOYMENT_ID SCHEDULE_ID
for a more detailed view of a specific schedule.
Writing a Custom Workflow
If you are an advanced user, you might want to create custom workflows. For more information, see Creating Custom Workflows.