Introduction to Jobs¶
A job in Zuar Runner represents a unit of work. There are a variety of different types of jobs, most of which can be found on the Add Jobs page within the UI.
Each job performs a specific function or set of functions. Jobs can be run, scheduled, sequenced, tagged, and searched for.
data:image/s3,"s3://crabby-images/b289d/b289dbd51a9117a7fde3710534c45d065d738e16" alt="../_images/intro-jobs-1.png"
The most common job types are IO, which handle the input and output of data, and Sequences which organize, order, and run jobs in series.
Timeouts¶
A timeout can be set for your job/sequence which will cause the job to be killed if it exceeds a certain length of time. This can be useful for any job type once an average runtime has been established. Setting the timeout around or shortly after the average runtime can help safeguard the job from issues that may cause increased runtime. Pairing this with a failure notification can help monitor the health of jobs.
data:image/s3,"s3://crabby-images/727eb/727eb55835141f589f2c4183235a9a0e00e06887" alt="../_images/jobs__timeouts.png"
To set a timeout, simply click the pencil in the TIMEOUT section of the job/sequence page. Click the carat on the modal which appears and select a time from the dropdown. Available times include Never, which is the default, and Custom, which allows a time to be entered in minutes.
data:image/s3,"s3://crabby-images/ec7c2/ec7c2c2250301b2870d28e6f46f86f569e5df4f7" alt="../_images/jobs__timeouts_modal.png"
Notifications¶
Zuar Runner can send notifications on the status of a job/sequence.
Navigate to Settings on the left hand panel. Learn more about the Settings page.
Click on Configure.
The Messaging section is where you set your notifications.
State: This is where you can either enable or disable notifications.
Recipient(s): Enter in the email address of the person(s) that will be receiving these notifications. Separate different email addresses with a comma. Any email listed in here will receive a notification.
Default level: Choose either None, All, or Errors Only for when you will be notified. With None, you will not be notified at all for any status of your job. All is the exact opposite. Choosing this will notify you of any status. Errors Only will notify you when there is an error in your job run. This is turned off by default so you only get notifications when you specify it on jobs.
Templates: Shows how your notification message is encoded. This is an advanced feature. Do not modify this unless specified.
The section below the Messaging section is the Navigation section. Learn more about custom navigation.
Webhooks¶
Zuar Runner webhooks come in two flavors: Incoming Webhooks and Outgoing Webhooks. Incoming Webhooks are new as of Runner version 3.3.0 and can serve as endpoints to be used by a webhook initiated from an external system to start, stop. Outgoing webhooks have been around for a while and can be used to send data to any URL when a job starts, completes, succeeds, or fails. Outgoing webhooks can also be used to start a job when any of these things occur.
Both types of Webhooks can be added to any individual job or sequence in Zuar Runner.
Add an Incoming Webhook to a Job¶
Click the plus button in the Incoming Webhooks section of any job. The Runner will create an incoming webhook which is valid for that Runner. This is an example from stage-mitto3.zuarbases.net.
data:image/s3,"s3://crabby-images/39c93/39c93c09253ef6ee12f28fc81d598fcf85943421" alt="../_images/jobs__incoming_webhooks.png"
Once the incoming webhook has been created, simply click the copy button to the right of the URL and use that URL in your remote webhook or CURL.
Add an Outgoing Webhook to a Job¶
Click the edit button in the Outoing Webhooks section of any job.
data:image/s3,"s3://crabby-images/fd93e/fd93e69372e241d37ab346e7d7e8bbb4bbe57c1f" alt="../_images/jobs__outgoing_webhooks.png"
Fill in the form.
data:image/s3,"s3://crabby-images/b0feb/b0feb9f2db2801f6daba7da6c76cf23c8f82c13d" alt="../_images/jobs__outgoing_webhooks_form.png"
URL¶
The URL to send the GET or POST request to.
Event¶
Outgoing webhooks can be initiated from four different job event types:
JOB_START - initiate the webhook when the job starts
JOB_COMPLETE - initiate the webhook when the job completes
JOB_SUCCESS - initiate the webhook if the job succeeds
JOB_FAILURE - initiate the webhook if the job fails
Method¶
GET - request data from the URL
POST - send data to the URL
Typically, you want to send data to another application via a POST.
Content Type¶
This is the format of the body of the request.
application/json
application/x-www-form-urlencoded
text/plain
The choice here depends on the data format the URL is expecting.
Enable¶
Check to enable this outgoing webhook or uncheck to disable it. The webhook will be enabled by default.
Test¶
You can test whether the webhook is functional by clicking Test.
Editing an Existing Outgoing Webhook¶
Click the edit icon next to any existing outgoing webhook to edit the webhook.
Multiple Outgoing Webhooks on the Same Job¶
Multiple outgoing webhooks can be added to any job in Zuar Runner, enabling complex use cases and conditional logic.
Outgoing Webhooks Data¶
Data from the Zuar Runner API can be sent in the body of a webhook.
You can see the available data in the Zuar Runner API endpoints:
Endpoint: {runner_url}/api/job/{job_id}
data:image/s3,"s3://crabby-images/c70e6/c70e671edae438a422facfbf5597e0f25d90f6db" alt="../_images/jobs__webhooks_api_payload.png"
Endpoint: {runner_url}/api/system
data:image/s3,"s3://crabby-images/ab70c/ab70c353c36d33a797a64c7c983aba99a6fe27d1" alt="../_images/jobs__webhooks_api_system_payload.png"
Simple Examples:¶
${job['title']}
translates to “Webhooks!”${system['fqdn']}
translates to “stage-mitto3.zuarbase.net”
Complete Example:¶
This example sends text to a Slack channel.
{
"text": "Job Complete!: ${system['fqdn']} - ${job['title']}\nhttps://${system['fqdn']}/#!/job/${job['id']}"
}
This outgoing webhook body translates to:
Job Complete!: stage-mitto3.zuarbase.net - Webhooks!
https://stage-mitto3.zuarbase.net/#!/job/12984
Outgoing Webhooks that Interact with Zuar Runner¶
You can create outgoing webhooks that interact directly with Zuar Runner itself.
For example, one job’s outgoing webhook can start another job:
data:image/s3,"s3://crabby-images/de6c2/de6c2af028d5d7bfe1e33d6342972e187755e889" alt="../_images/jobs__webhooks_action.png"
Notice the URL:
http://webapp:7127/v2/jobs/<job_id>/:actions
And the body:
{
"action": "START"
}
Outgoing Webhooks that Interact with Microsoft Teams¶
The previous examples have utilized Slack as the receiving application. Outgoing webhooks can be sent to most chat application. You can create outgoing webhooks that interact directly with Microsoft Teams .
The URL will be the outgoing webhook URL obtained from the Teams Channel configuration.
data:image/s3,"s3://crabby-images/ab9d7/ab9d7f41e782859329511f613e566ce6a67d24f1" alt="image"
Use that URL in the Zuar Runner outgoing webhook config:
data:image/s3,"s3://crabby-images/34204/3420486c1b775cd89906c4bda462b6f2a72725ba" alt="image"
The body of the notification should be structured like the following example in order for Microsoft Teams to accept the alert:
{
"text": "Job Failed!: ${system['fqdn']} - ${job['title']}\nhttps://${system['fqdn']}/#!/job/${job['id']}"
}
Scheduling¶
Every Zuar Runner job can be scheduled to run at specific times.
data:image/s3,"s3://crabby-images/10334/1033463e5026f160ceb097fe22a5fd526d8413da" alt="../_images/jobs__set_schedule.png"
On any individual job page, click on the edit button under SCHEDULE to open a modal and set a schedule.
data:image/s3,"s3://crabby-images/7cef9/7cef954d1759af354a17c2d9706e739e09f828ce" alt="../_images/jobs__schedule.png"
Jobs can be scheduled to to run daily at the specified time, hourly on the specified minute (00, 15, 30, 45), end of a specific time (week, month, quarter), as soon as it finishes (on the next minute) AKA continuously, or to run on any custom schedule using CRON logic. To test different CRON schedules, use this helpful tool: https://crontab.guru/
For example, run the job at 12:00 AM every Tuesday.
data:image/s3,"s3://crabby-images/a777c/a777c470e94ff8a2e344eccb9ebc3c6b72839c10" alt="../_images/jobs__schedule_cron.png"
Zuar Runner will attempt to translate your custom schedule on the job page.
data:image/s3,"s3://crabby-images/10d92/10d9251be816b178d2d2f9696f6e8364a0d981af" alt="../_images/jobs__schedule_cron_display.png"
Jobs are not scheduled by default when they are created.
After you have made your selection, click Save. Congratulations! You have just scheduled your job.
Zuar Runner Scheduling Best Practices¶
Set job schedules that make sense both from a source system perspective (e.g. consider API limits, etc.) and end user needs (e.g. do your users really need data refreshed continuously?).
Sequences¶
Generally speaking, you should schedule sequences of jobs instead of individual jobs. This helps you to ensure that your jobs run in the correct order and to see the whole sequence more clearly.
Once a job/sequence is added to a sequence, it will appear in the Parent Sequences section on the job/sequence page.
data:image/s3,"s3://crabby-images/ef9ae/ef9ae18024e39e679753b17220fc8c6c8c6b0b90" alt="../_images/jobs__parent_sequence.png"