1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
|
.. _ug_jobs:
Jobs
=====
.. index::
single: jobs
A :term:`job` is an instance of AWX launching an Ansible playbook against an inventory of hosts.
The **Jobs** link displays a list of jobs and their statuses--shown as completed successfully or failed, or as an active (running) job.
The default view is collapsed (**Compact**) with the job name, status, job type, and start/finish times, but you can expand to see more information. You can sort this list by various criteria, and perform a search to filter the jobs of interest.
|Jobs - home with example job|
.. |Jobs - home with example job| image:: ../common/images/jobs-home-with-example-job.png
:alt: Jobs List with Example Jobs
.. image:: ../common/images/jobs-list-all-expanded.png
:alt: Expanded Jobs List
Actions you can take from this screen include viewing the details and standard output of a particular job, relaunching (|launch|) jobs, or removing selected jobs.The relaunch operation only applies to relaunches of playbook runs and does not apply to project/inventory updates, system jobs, workflow jobs, etc.
.. _ug_job_results:
.. index::
single: jobs; results
single: job results
When a job relaunches, you are directed the Jobs Output screen as the job runs. Clicking on any type of job also takes you to the Job Output View for that job, where you can filter jobs by various criteria:
.. image:: ../common/images/job-details-view-filters.png
:alt: Filter options in the Jobs Output window
- The **Stdout** option is the default display that shows the job processes and output
- The **Event** option allows you to filter by the event(s) of interest, such as errors, host failures, host retries, items skipped, etc. You can include as many events in the filter as necessary.
.. image:: ../common/images/job-details-view-filters-examples.png
:alt: Selected filter examples from the Jobs Output window
- The **Advanced** option is a refined search that allows you a combination of including or excluding criteria, searching by key, or by lookup type. For details about using Search, refer to the :ref:`ug_search` chapter.
Inventory Sync Jobs
----------------------
.. index::
pair: job results; inventory sync
.. to reproduce: create a custom script and use it when adding a custom inventory source for an inventory.
When an inventory sync is executed, the full results automatically display in the Output tab. This shows the same information you would see if you ran it through the Ansible command line, and can be useful for debugging. The ``ANSIBLE_DISPLAY_ARGS_TO_STDOUT`` is set to ``False`` by default for all playbook runs. This matches Ansible's default behavior. This does not display task arguments in task headers in the Job Detail interface to avoid leaking certain sensitive module parameters to stdout. If you wish to restore the prior behavior (despite the security implications), you can set ``ANSIBLE_DISPLAY_ARGS_TO_STDOUT`` to ``True`` via the ``AWX_TASK_ENV`` configuration setting. For more details, refer to the `ANSIBLE_DISPLAY_ARGS_TO_STDOUT`_.
.. _`ANSIBLE_DISPLAY_ARGS_TO_STDOUT`: https://docs.ansible.com/ansible/latest/reference_appendices/config.html#envvar-ANSIBLE_DISPLAY_ARGS_TO_STDOUT
The icons at the top right corner of the Output tab allow you to relaunch (|launch|), download (|download|) the job output, or delete (|delete|) the job.
.. |launch| image:: ../common/images/launch-button.png
:alt: Launch Action Button
.. |delete| image:: ../common/images/delete-button.png
:alt: Delete Action Button
.. |cancel| image:: ../common/images/job-cancel-button.png
:alt: Cancel Action Button
.. |download| image:: ../common/images/download.png
:alt: Download Action Button
|job details example of inventory sync|
.. |job details example of inventory sync| image:: ../common/images/jobs-show-job-results-for-inv-sync.png
:alt: Example output for a successful Inventory Sync job
.. note:: An inventory update can be performed while a related job is running. In cases where you have a big project (around 10 GB), disk space on ``/tmp`` may be an issue.
Inventory sync details
~~~~~~~~~~~~~~~~~~~~~~~
Access the **Details** tab to provide details about the job execution.
.. image:: ../common/images/jobs-show-job-details-for-inv-sync.png
:alt: Example details for an Inventory Sync job
Notable details of the job executed are:
- **Status**: Can be any of the following:
- **Pending** - The inventory sync has been created, but not queued or started yet. Any job, not just inventory source syncs, will stay in pending until it’s actually ready to be run by the system. Reasons for inventory source syncs not being ready include dependencies that are currently running (all dependencies must be completed before the next step can execute), or there is not enough capacity to run in the locations it is configured to.
- **Waiting** - The inventory sync is in the queue waiting to be executed.
- **Running** - The inventory sync is currently in progress.
- **Successful** - The inventory sync job succeeded.
- **Failed** - The inventory sync job failed.
- **Inventory**: The name of the associated inventory group.
- **Source**: The type of cloud inventory.
- **Inventory Source Project**: The project used as the source of this inventory sync job.
- **Execution Environment**: The |ee| used.
- **Execution node**: The node used to execute the job.
- **Instance Group**: The name of the instance group used with this job (AWX is the default instance group).
By clicking on these items, where appropriate, you can view the corresponding job templates, projects, and other objects.
SCM Inventory Jobs
--------------------
.. index::
pair: job results; SCM inventory
When an inventory sourced from an SCM is executed, the full results automatically display in the Output tab. This shows the same information you would see if you ran it through the Ansible command line, and can be useful for debugging. The icons at the top right corner of the Output tab allow you to relaunch (|launch|), download (|download|) the job output, or delete (|delete|) the job.
.. image:: ../common/images/jobs-show-job-results-for-scm-job.png
:alt: Example output for a successful SCM job
SCM inventory details
~~~~~~~~~~~~~~~~~~~~~~
Access the **Details** tab to provide details about the job execution and its associated project.
.. image:: ../common/images/jobs-show-job-details-for-scm-job.png
:alt: Example details for an SCM job
Notable details of the job executed are:
- **Status**: Can be any of the following:
- **Pending** - The SCM job has been created, but not queued or started yet. Any job, not just SCM jobs, will stay in pending until it’s actually ready to be run by the system. Reasons for SCM jobs not being ready include dependencies that are currently running (all dependencies must be completed before the next step can execute), or there is not enough capacity to run in the locations it is configured to.
- **Waiting** - The SCM job is in the queue waiting to be executed.
- **Running** - The SCM job is currently in progress.
- **Successful** - The last SCM job succeeded.
- **Failed** - The last SCM job failed.
- **Job Type**: SCM jobs display Source Control Update.
- **Project**: The name of the project.
- **Project Status**: Indicates whether the associated project was successfully updated.
- **Revision**: Indicates the revision number of the sourced project that was used in this job.
- **Execution Environment**: Specifies the |ee| used to run this job.
- **Execution Node**: Indicates the node on which the job ran.
- **Instance Group**: Indicates the instance group on which the job ran, if specified.
- **Job Tags**: Tags show the various job operations executed.
By clicking on these items, where appropriate, you can view the corresponding job templates, projects, and other objects.
Playbook Run Jobs
-------------------
.. index::
pair: jobs results; playbook run
When a playbook is executed, the full results automatically display in the Output tab. This shows the same information you would see if you ran it through the Ansible command line, and can be useful for debugging.
.. image:: ../common/images/jobs-show-job-results-for-example-job.png
:alt: Example output for a successful playbook run
The events summary captures a tally of events that were run as part of this playbook:
- the number of times this playbook has ran in the **Plays** field
- the number of tasks associated with this playbook in the **Tasks** field
- the number of hosts associated with this playbook in the **Hosts** field
- the amount of time it took to complete the playbook run in the **Elapsed** field
.. image:: ../common/images/jobs-events-summary.png
:alt: Example summary details for a playbook
The icons next to the events summary allow you to relaunch (|launch|), download (|download|) the job output, or delete (|delete|) the job.
The host status bar runs across the top of the Output view. Hover over a section of the host status bar and the number of hosts associated with that particular status displays.
|Job - All Host Events|
.. |Job - All Host Events| image:: ../common/images/job-all-host-events.png
:alt: Show All Host Events
The output for a Playbook job is also accessible after launching a job from the **Jobs** tab of its Job Templates page.
Clicking on the various line item tasks in the output, you can view its host details.
Search
~~~~~~~
Use Search to look up specific events, hostnames, and their statuses. To filter only certain hosts with a particular status, specify one of the following valid statuses:
- **OK**: the playbook task returned "Ok".
- **Changed**: the playbook task actually executed. Since Ansible tasks should be written to be idempotent, tasks may exit successfully without executing anything on the host. In these cases, the task would return Ok, but not Changed.
- **Failed**: the task failed. Further playbook execution was stopped for this host.
- **Unreachable**: the host was unreachable from the network or had another fatal error associated with it.
- **Skipped**: the playbook task was skipped because no change was necessary for the host to reach the target state.
- **Rescued**: introduced in Ansible 2.8, this shows the tasks that failed and then executes a rescue section.
- **Ignored**: introduced in Ansible 2.8, this shows the tasks that failed and have ``ignore_errors: yes`` configured.
These statuses also display at bottom of each Stdout pane, in a group of "stats" called the Host Summary fields.
.. image:: ../common/images/job-std-out-host-summary-rescued-ignored.png
:alt: Example summary details in standard output
The example below shows a search with only unreachable hosts.
.. image:: ../common/images/job-std-out-filter-failed.png
:alt: Example of errored jobs filtered by unreachable hosts
For more details about using the Search, refer to the :ref:`ug_search` chapter.
The standard output view displays all the events that occur on a particular job. By default, all rows are expanded so that all the details are displayed. Use the collapse-all button (|collapse-all|) to switch to a view that only contains the headers for plays and tasks. Click the (|expand-all|) button to view all lines of the standard output.
.. |collapse-all| image:: ../common/images/job-details-view-std-out-collapse-all-icon.png
:alt: Collapse All Icon
.. |expand-all| image:: ../common/images/job-details-view-std-out-expand-all-icon.png
:alt: Expand All Icon
Alternatively, you can display all the details of a specific play or task by clicking on the arrow icons next to them. Click an arrow from sideways to downward to expand the lines associated with that play or task. Click the arrow back to the sideways position to collapse and hide the lines.
.. image:: ../common/images/job-details-view-std-out-expand-collapse-icons.png
:alt: Expand and Collapse Icons
Things to note when viewing details in the expand/collapse mode:
- Each displayed line that is not collapsed has a corresponding line number and start time.
- An expand/collapse icon is at the start of any play or task after the play or task has completed.
- If querying for a particular play or task, it will appear collapsed at the end of its completed process.
- In some cases, an error message will appear, stating that the output may be too large to display. This occurs when there are more than 4000 events. Use the search and filter for specific events to bypass the error.
Click on a line of an event from the **Standard Out** pane and a **Host Events** dialog displays in a separate window. This window shows the host that was affected by that particular event.
.. note:: Upgrading to the latest versions of AWX involves progressively migrating all historical playbook output and events. This migration process is gradual, and happens automatically in the background after installation is complete. Installations with very large amounts of historical job output (tens, or hundreds of GB of output) may notice missing job output until migration is complete. Most recent data will show up at the top of the output, followed by older events. Migrating jobs with a large amount of events may take longer than jobs with a smaller amount.
Host Details
~~~~~~~~~~~~~~
.. index::
single: jobs; host events
The **Host Details** dialog shows information about the host affected by the selected event and its associated play and task:
- the **Host**
- the **Status**
- the type of run in the **Play** field
- the type of **Task**
- if applicable, the Ansible **Module** for the task, and any *arguments* for that module
.. image:: ../common/images/job-details-host-hostevent.png
:alt: Host Events Details
To view the results in JSON format, click on the **JSON** tab. To view the output of the task, click the **Standard Out**. To view errors from the output, click **Standard Error**.
Playbook run details
~~~~~~~~~~~~~~~~~~~~~~
Access the **Details** tab to provide details about the job execution.
.. image:: ../common/images/jobs-show-job-details-for-example-job.png
:alt: Example Job details for a playbook run
Notable details of the job executed are:
- **Status**: Can be any of the following:
- **Pending** - The playbook run has been created, but not queued or started yet. Any job, not just playbook runs, will stay in pending until it is actually ready to be run by the system. Reasons for playbook runs not being ready include dependencies that are currently running (all dependencies must be completed before the next step can execute), or there is not enough capacity to run in the locations it is configured to.
- **Waiting** - The playbook run is in the queue waiting to be executed.
- **Running** - The playbook run is currently in progress.
- **Successful** - The last playbook run succeeded.
- **Failed** - The last playbook run failed.
- **Job Template**: The name of the job template from which this job was launched.
- **Inventory**: The inventory selected to run this job against.
- **Project**: The name of the project associated with the launched job.
- **Project Status**: The status of the project associated with the launched job.
- **Playbook**: The playbook used to launch this job.
- **Execution Environment**: The name of the |ee| used in this job.
- **Container Group**: The name of the container group used in this job.
- **Credentials**: The credential(s) used in this job.
- **Extra Variables**: Any extra variables passed when creating the job template are displayed here.
By clicking on these items, where appropriate, you can view the corresponding job templates, projects, and other objects.
.. _ug_job_concurrency:
AWX Capacity Determination and Job Impact
-------------------------------------------
.. index::
pair: jobs; capacity
pair: jobs; forks
.. include:: job_capacity.rst
Job branch overriding
----------------------
.. index::
pair: job branch; overriding
.. include:: job_branching.rst
|