AutoSys Tutorial
AutoSys Tutorial
This document is for schedulers and operators who define, schedule, monitor, and
control workload using Autosys. The concepts in this document can
also help application programmers or developers who create custom applications to
work with Autosys.
This User Guide is a supplement to the Reference Guide and provides overview topics
and concepts. It also contains step-by-step procedures to help you define basic jobs.
The Reference Guide provides detailed information about commands, attributes, and JIL
(Job Information Language) syntax.
To use this document, you must be familiar with the operating system(s) where the jobs
run and any third-party products or software technology that the jobs use.
A job is any single command, executable, script, or batch file. These jobs can reside on
any configured machine that is attached to a network. Corresponding job definitions
contain attributes that define the job properties, including the conditions specifying
when and where a job should run.
As with most control systems, there are many ways to correctly define and implement
jobs. It is likely that the way you use Autosys to address your
distributed computing needs will evolve over time. As you become more familiar with
the product features and the characteristics of your jobs, you can refine your use of Autosys.
agentparm.txt File :
The agent is installed with a configuration file named agentparm.txt. Some of the
parameters in this file control the properties and behavior of job types. Your agent
administrator can add and modify the parameters as required.
The CA Workload Automation Agent for UNIX, Linux, or Windows replaces the Remote
Agent (auto_remote) that was provided with Unicenter AutoSys JM 4.5.1 and r11. The
Release 11.3.6 documentation refers to auto_remote as the legacy agent.
The new agent provides additional job types, including monitoring and FTP jobs. The
agent is automatically installed on the computer where CA Workload Automation AE is
installed. You can also install the agent on remote computers to run jobs on those
computers.
Jobs :
In the Autosys environment, a job is a single action that can be
performed on a valid agent computer. For example, on UNIX, you can run a script, issue
a command, transfer files using FTP, and monitor file activity and processes on the agent
computer. Similarly, on Windows, you can run an executable or batch file, issue a
command, transfer files using FTP, and monitor files or processes. To run a job, you
must create a job definition that specifies what the job does, when it runs, and where it
runs.
Events :
Autosys is event-driven. An event instructs the scheduler to initiate
a specific action. The scheduler completes the action unless doing so violates internal
rules or the event is not applicable. Autosys server components
internally generate certain events in certain circumstances, but you can also manually
generate events using the sendevent command.
Alarms :
Alarms are special events that notify operators of situations requiring their attention.
The system issues alarms by internally generating an event, but these events are
informational only. To resolve the issue that triggers an alarm, initiate the required
action using the sendevent command.
Some problems do not trigger the scheduler to generate an alarm. For example, when a
problem quickly resolves itself without manual intervention. Sometimes, you need to
notify someone to follow up on such problems so that they do not recur. In these cases,
use the sendevent command to generate an alarm manually.
The scheduler records alarms in the ujo_alarm table. The ujo_alarm table uses numeric
codes to represent alarms. The numeric codes are resolved using the ujo_intcodes table.
For information about alarms and other events.
Utilities :
Autosys uses its own specification language (JIL) and client utilities
to help you define, control, and report on jobs. The JIL language is processed by the JIL
client executable, which reads and interprets the JIL statements that you enter and then
performs the appropriate actions.
Autosys also provides client programs for controlling and reporting
on jobs. For example, the autorep command lets you generate a variety of reports about
job execution, and the sendevent command lets you manually control job processing.
Additional utilities are provided to help you troubleshoot, run monitors and reports, and
start and stop Autosys and its components. Autosys also provides a database maintenance utility that
runs daily by default.
Commands :
CA Workload Automation AE(Autosys) commands let you define, monitor, and manage workload,
and configure and control the system.
The following commands start CA Workload Automation AE:
■ as_server—Runs the application server.
■ event_demon—Represents the binary (the scheduler) that runs CA Workload
Automation AE.
■ eventor—Starts the scheduler (the event demon). This command applies to UNIX
only.
The following commands maintain databases:
■ as_config—Manages the encryption keys for the application server and for CA
Workload Automation Agent for UNIX, Linux, or Windows.
■ as_safetool—Maintains authentication certificates and installs or removes CA EEM
security policies.
■ autosec_test—Simulates a call to the security subsystem.
■ autosys_secure—Defines security settings.
The following commands check system status:
JIL Subcommands
JIL subcommands lets you define and modify asset definitions. You specify JIL
subcommands using the jil command.
The following JIL subcommands define and modify jobs and boxes:
delete_box
Deletes an existing box job and all the jobs in that box from the database.
delete_job
Deletes a job from the database. If the specified job is a box job, the box job is
deleted and the jobs in the box become stand-alone jobs.
insert_job
Adds a new job definition to the database.
override_job
Defines a one-time override for an existing job definition. This override affects the
job for the next run only.
update_job
Updates an existing job definition in the database.
The following JIL subcommands define and modify machines:
delete_machine
Deletes an existing real or virtual machine definition from the database.
insert_machine
Inserts a new real or virtual machine definition in the database. A machine must be
defined before it can be used in a job definition.
update_machine
Updates an existing machine in the database.
The following JIL subcommands define and modify monitor or report definitions:
delete_monbro
Deletes the specified monitor or report definition from the database.
insert_monbro
Adds a new monitor or report definition to the database.
update_monbro
Updates an existing monitor or report definition in the database.
delete_job_type
Verifies that no jobs are currently defined with the specified job type, then deletes
the specified job type definition from the database.
insert_job_type
Adds a new user-defined job type definition to the database. This is the only way to
create a user-defined job type.
update_job_type
Updates an existing user-defined job type definition in the database. You can use
update_job_type to change the values of the command and description attributes.
The following JIL subcommands define and modify blobs and globs:
insert_blob
Adds a new blob definition associated with an existing job.
insert_glob
Adds a new glob definition referenced by a given name.
delete_blob
Decouples a blob definition from an existing job and deletes the blob from the
database.
delete_glob
Deletes the specified glob definition from the database.
The following JIL subcommands define and modify external instances:
delete_xinst
Deletes the specified external instance definition from the database.
insert_xinst
Adds a new external instance definition to the database.
update_xinst
Updates an existing external instance definition in the database.
The following JIL subcommands define and modify resources:
delete_resource
Deletes a virtual resource from the database.
insert_resource
Adds a new virtual resource definition to the database.
update_resource
Updates an existing virtual resource definition in the database.
JIL Syntax Rules
JIL scripts contain one or more JIL subcommands and one or more attribute statements.
These elements constitute a job definition. You can create job definitions in interactive
mode by opening the operating system or instance command prompt and entering the
following command:
jil
Alternatively, you can enter the subcommands and attribute statements for all of your
job definitions in a text (.txt) file and then import the job definitions by redirecting the
file as input to JIL. To import job definitions from a text file, open the operating system
or instance command prompt and enter the following command:
A JIL script is valid only when it is written according to the JIL syntax rules. If you create
the job definitions in a text file import them, ensure that you follow the JIL syntax rules.
To automatically check the syntax, enter the following command:
Important! The syntax checker does not commit the job definitions in the file to the
database. To commit the definitions, ensure that you correct any syntax errors that the
checker identifies and then run the following command:
Note: Running the syntax checker adds time to the import process.
A valid job definition adheres to the following syntax rules:
Rule 1
Each subcommand uses the following form:
sub_command:object_name
sub_command
Defines the name of the object (for example, a job or a machine) to act on.
Rule 2
You can follow each subcommand with one or more attribute statements. These
statements can occur in any order and are applied to the object specified in the
preceding subcommand. A subsequent subcommand begins a new set of attributes
for a different object. The attribute statements have the following form:
attribute_keyword:value
attribute_keyword
Defines a valid JIL attribute.
value
Defines the setting to apply to the attribute.
Notes:
■ The entire attribute_keyword:value statement can be up to 4096 characters.
■ The following subcommands do not accept attributes: delete_box, delete_job,
delete_job_type, delete_xinst, delete_monbro, and delete_glob.
Rule 3
You can enter multiple attribute statements on the same line, but you must
separate the attribute statements with at least one space.
Rule 4
A box job definition must exist before you can add jobs to it.
Rule 5
Valid value settings can include any of the following characters:
■ Uppercase and lowercase letters (A-Z, a-z)
■ Hyphens (-)
■ Underscores (_)
■ Pound signs (#)
■ Numbers (0-9)
■ Colons (:), if the colon is escaped with quotation marks (" ") or a preceding
backslash (\)
■ The at character (@)
Note: Object names can only contain the following characters: a-z, A-Z, 0-9, period
(.), underscore (_), hyphen (-), and pound (#). Do not include embedded spaces or
tabs.
Rule 6
Because JIL parses on the combination of a keyword followed by a colon, you must
use escape characters (a backslash) or enclose the value in quotation marks with
any colons used in an attribute statement's value. For example, to define the start
time for a job, specify 10\:00or “10:00”.
Note: When specifying drive letters in commands, you must use escape characters
with the colon (:). For example, "C:\tmp" and C\:\tmp are valid; C:\tmp is not.
Rule 7
Use one of the following methods to indicate comments in a JIL script:
■ To comment an entire line, put a pound sign (#) in the first column.
■ To comment one or more lines, you can use the C programming syntax for
beginning a comment with a forward slash and asterisk (/*) and ending it with
an asterisk and a forward slash (*/). For example:
/* this is a comment */
Rule 8
You can use the blob_input attribute to manually enter multiline text. This attribute
is only valid for the insert_job, update_job, insert_blob, and insert_glob
subcommands. The blob_input attribute has the following form:
blob_input:<auto_blobt> this is a multi-
line text
</auto_blobt>
Note: Use the auto_blobt meta-tags to indicate the beginning and end of multiline
text. JIL interprets every character input between the auto_blobt meta-tags
literally. This implies that JIL does not enforce any of the previously discussed rules
for text entered in an open auto_blobt meta-tag.
Rule 9
To specify a comma in keyword=value combinations, you must do one of the
following:
■ Escape the comma with a backslash, as follows:
j2ee_parameter: String=Hello1\, World
■ Enclose the entire value in quotation marks, as follows:
j2ee_parameter: String="Hello1, World"
If the keyword=value combination contains commas and quotation marks, you must
escape the commas and quotation marks as follows:
j2ee_parameter: String=\"Hello1\, World\"
Issue JIL in Interactive Mode on UNIX
You can issue the jil command and subcommands on UNIX at the operating system
prompt. The operating system prompt lets you enter data interactively. You can also
create aliases for the commands that you use frequently. The interactive mode is helpful
when you do not need to issue JIL commands in batch. For example, you can use the
interactive mode when you want to test specific job definitions.
Note: Before you can issue commands at the operating system prompt, the CA
Workload Automation AE environment must be sourced in the shell and your UNIX user
ID and password must be defined on CA Workload Automation AE. For more
information about sourcing the environment and defining user IDs, see the UNIX
Implementation Guide.
Follow these steps:
1. Run the shell that is sourced to use CA Workload Automation AE.
2. Do one of the following:
■ Enter jil at the operating system prompt.
The JIL command prompt is displayed for the local CA Workload Automation AE
instance.
■ Enter jil -S instance at the operating system prompt.
The JIL command prompt is displayed for the specified CA Workload
Automation AE instance.
instance
Specifies the CA Workload Automation AE instance where you want to issue
the JIL subcommand. For single-instance environments, the jil command
defaults to the only available instance.
3. Enter a JIL subcommand and follow the prompts.
4. Enter exit when you are done entering the data.
JIL interactive mode ends and the data is loaded into the database.
Issue JIL in Interactive Mode on Windows
You can issue the jil command and subcommands on Windows by using the CA
Workload Automation AE instance command prompt. The instance command prompt
lets you enter data interactively. The interactive mode is helpful when you do not need
to issue JIL commands in batch. For example, you can use the interactive mode when
you want to test specific job definitions.
Example: Submit a Job Definition to the Local Instance Using a JIL Script
This example redirects a file called newjobdef to the jil command on the local instance
of CA Workload Automation AE.
jil < newjobdef
Before you can schedule jobs to run on a machine, you must define the machine to
Autosys. You can define real machines, virtual machines, or real
machine pools.
Real Machines :
A real machine is any single machine that meets the following criteria:
■ It has been identified in the appropriate network so that CA Workload Automation
AE can access it.
■ An agent, CA AutoSys WA Connect Option, CA NSM, or CA UAJM is installed, which
lets CA Workload Automation AE run jobs on it.
■ It is defined to CA Workload Automation AE as a real machine using JIL.
A real machine must meet these conditions to run jobs. However, for CA Workload
Automation AE to perform intelligent load balancing and queuing while running jobs, it
must know the relative processing power of the real machines. CA Workload
Automation AE uses the virtual machines to provide load balancing and queuing.
Virtual Machines :
A virtual machine is a machine definition that references one or more existing real
machine definitions. By defining virtual machines to CA Workload Automation AE and
submitting jobs to run on those machines, you can specify the following:
■ Run-time resource policies (or constraints) at a high level.
■ That CA Workload Automation AE automatically runs those policies in a
multi-machine environment.
Note: Previous releases of CA Workload Automation AE required that all machines in a
virtual machine be of the same type. In the current release, the component real
machines in a virtual machine definition can be UNIX or Windows machines or a mix of
both.
A real machine pool is similar to a virtual machine in that it references one or more
existing real machine definitions. Real machine pools are used specifically to integrate
with CA Automation Suite for Data Centers for load balancing, When a job is scheduled
that references a real machine pool, the node names associated with the machines
referenced are used by CA Automation Suite for Data Centers to assign the real machine
to run the job.
If the machine: localhost attribute is specified in a job definition, the scheduler tries to
resolve the localhost value when it runs the job. The localhost value is resolved as
follows:
■ The scheduler checks the value of the LocalMachineDefinition parameter (UNIX) or
the Local Machine Definition field (Windows).
■ If the local machine definition setting is set to a value other than “localhost”, the
scheduler searches the database for a machine definition with that name. For
example, suppose that LocalMachineDefinition is set to agentmach. If an
agentmach machine definition is found and all conditions are satisfied, the job runs
on agentmach. If the scheduler cannot find an agentmach machine definition, or if
it finds multiple agentmach machine definitions, the scheduler does not resolve
localhost. All jobs defined to run on the localhost machine fail.
■ If the local machine definition is not defined or is set to “localhost”, the scheduler
searches the database for a machine definition corresponding to the machine
where the scheduler was started (the default localhost). For example, suppose that
the scheduler was started on a machine named prodserver and
LocalMachineDefinition is not defined. When the job runs, the scheduler searches
for a machine definition named prodserver. If the scheduler cannot find the
prodserver definition, or if it finds multiple prodserver definitions, the scheduler
does not resolve localhost. All jobs defined to run on the localhost machine fail.
■ In a high availability failover where the shadow scheduler takes over from the
primary scheduler, the localhost is resolved in the same way. To run a job on the
localhost, the shadow scheduler first checks its local machine definition setting,
which may be different from the setting for the primary scheduler. If the local
machine definition is not defined, the localhost is resolved to the machine where
the shadow scheduler was started.
Define a Machine :
Before you can schedule jobs to run on a machine, you must define the machine to CA
Workload Automation AE.
Follow these steps:
1. Do one of the following:
■ Issue JIL in interactive mode.
■ Open a JIL script in a text editor.
2. Specify the following definition:
insert_machine: machine_name
node_name: address
type: type
machine_name
Defines a unique name for the machine to add.
address
Specifies the IP address or DNS name of the machine. The default is the
machine_name specified on the insert_machine statement.
type
Specifies the type of machine you are defining. Options are the following:
a
Specifies a CA Workload Automation Agent for UNIX, Linux, Windows,
i5/OS, or z/OS machine. This is the default.
c
Specifies a CA AutoSys Workload Automation Connect Option machine.
l
Specifies a 4.5.1 real UNIX machine. You must specify a lowercase l.
L
Specifies a 4.5.1 real Windows machine. You must specify a capital L.
n
Specifies an r11 real Windows machine or a virtual machine that consists
only of r11 real Windows machines (type n).
p
Specifies a real machine pool managed by CA Automation Suite for Data
Centers.
Note: In the documentation, the type "p" machine is referred to as the real
machine pool.
r
Specifies an r11 real UNIX machine.
u
Specifies a CA NSM or a CA Universal Job Management Agent (CA UJMA)
machine.
v
Specifies a virtual machine. The virtual machine can consist of CA
Workload Automation Agent machines (type a), r11 real UNIX machines
(type r), and r11 real Windows machines (type n).
3. (Virtual or CA Automation Suite for Data Centers machine pool types only) Specify
the following attribute:
machine
Specifies a real machine as a component of the virtual machine or real machine
pool. The specified machine must have been defined to CA Workload
Automation AE as a real machine.
4. (CA Workload Automation Agent for UNIX, Linux, Windows, i5/OS, or z/OS machine
only) Specify the following attribute:
opsys
Specifies the operating system where the CA Workload Automation Agent is
installed. Options are the following:
aix
Specifies a CA Workload Automation Agent for UNIX installed on an AIX
computer.
hpux
Specifies a CA Workload Automation Agent for UNIX installed on an HP-UX
computer.
linux
Specifies a CA Workload Automation Agent for LINUX.
I5os
Specifies a CA Workload Automation Agent for i5/OS.
solaris
Specifies a CA Workload Automation Agent for UNIX installed on a Solaris
computer.
windows
Specifies a CA Workload Automation Agent for Windows.
zos
Specifies a CA Workload Automation Agent for z/OS.
Example: Define a Windows Virtual Machine with Subsets of r11 Real Machines
This example defines two r11 Windows real machines (lion and lotus), and a virtual
machine (gorilla), which is composed of slices, or subsets, of the max_load specified for
the real machines. Although the real machines were defined with specific max_load
values (100 and 80), the virtual machine only makes use of the reduced loads specified
in the virtual machine definition (10 and 9).
insert_machine: lion
type: n
max_load: 100
factor: 1
insert_machine: lotus
type: n
max_load: 80
factor: .8
insert_machine: gorilla
type: v
machine: lion
max_load: 10
machine: lotus
max_load: 9
This example defines a virtual machine (sheep), which is composed of two Release
11.3.6 UNIX real machines (warthog and camel). Because the max_load and factor
attributes are not defined for the real machines, they use the default values for these
attributes (a factor of 1.0 and a max_load of none, indicating unlimited load units).
insert_machine: warthog
opsys: linux
insert_machine: camel
opsys: solaris
insert_machine: sheep
type: v
machine: warthog
machine: camel
This example defines two r11 UNIX real machines (lion and lotus), and a virtual machine
(zebra), which is composed of the two real machines. The virtual machine is a superset
of the two real machines and uses the max_load and factor attributes defined for them.
insert_machine: lion
type: r
max_load: 100
factor: 1
insert_machine: lotus
type: r
max_load: 80
factor: .9
insert_machine: zebra
type: v
machine: lion
machine: lotus
This example defines a real machine pool (DCAPOOL), which is composed of three real
machines (MWIN, MLIN, and MSQL). DCAPOOL is monitored by CA Automation Suite for
Data Centers. When you define a job to reference DCAPOOL, CA Automation Suite for
Data Centers is used for machine selection.
insert_machine: MWIN
node_name: myhost
insert_machine: MLIN
node_name: myhost1
insert_machine: MSQL
node_name: myhost2
insert_machine: DCAPOOL
type: p
machine: MWIN
machine: MLIN
machine: MSQL
To delete a real machine definition, specify the following subcommand in the JIL script:
delete_machine: name_of_real_machine
[remove_references: y]
[force: y]
name_of_real_machine
Specifies the name of the machine to delete.
remove_references: y
(Optional) Instructs JIL to remove references to the specified machine from the
definitions of machine pools and virtual machines. We recommend that you use
this option when you delete real machines that are referenced in the definitions of
any machine pools or virtual machines. If you do not instruct JIL to remove the
references, you cannot delete the real machine until you delete all of the
references manually.
force: y
(Optional) Use this option to delete a machine that is in use.
Example: Delete a Real Machine Not Referenced in Virtual Machines or Real Machine
Pools
This example deletes the real machine definition for the computer named jaguar:
delete_machine: jaguar
Example: Delete a Real Machine Currently Referenced via a Virtual Machine:
This example explicitly deletes the real machine hyena reference from the virtual
machine carnivores followed by the real machine definition itself.
delete_machine: carnivores
machine: hyena
delete_machine: hyena
Example: Delete a Real Machine and All Virtual Machines References Implictly:
This example deletes the real machine panther and implicitly deletes all references to it
that may be in any virtual machines or real machine pools.
delete_machine: panther
remove_references: y
You can use the max_load attribute to define the maximum load (in load units) that a
machine can reasonably handle. The max_load attribute is valid in a real machine
definition or component machines defined to virtual machines.
Load units are arbitrary values, the range of which is user-defined. You can use any
weighting scheme you prefer. For example, a load unit with a range of 10 to 100 would
specify that machines with limited processing power are expected to carry a load of only
10, while machines with ample processing power can carry a load of 100. There is no
direct relationship between the load unit value and any of the machine's physical
resources. Therefore, we recommend that you use conventions that are meaningful to
you. You cannot use zero (0) or negative numbers as load units.
The max_load attribute is primarily used to limit the load on a machine. As long as a
job's load will not exceed a machine's maximum load, the max_load attribute does not
influence which machine a job runs on.
If you do not define the max_load attribute in a machine definition, CA Workload
Automation AE does not limit the load on the machine.
Example: Set the Maximum Load for a Real Machine
Suppose that the range of possible load values is 1 to 100. This example sets the
maximum load for a relatively low-performance real machine.
max_load: 20
For load balancing to work, you must assign a job_load value to every job that impacts
the load on a machine. The job_load attribute in a job definition defines the relative
amount of processing power the job consumes (the relative load the job places on a
machine).
Load units are arbitrary values, and the range is user-defined. You can use any weighting
scheme you prefer. You can use the max_load attribute to assign a real machine a
maximum job load. Then, you can use the job_load attribute in the job definition to
assign the job a load value that indicates the relative amount of the machine's load that
the job should consume. These attributes let you control machine loading and prevent a
machine from being overloaded.
Example: Define the Relative Processing Load for a Job
Suppose that the range of possible load values is 1 to 100. This example sets the load for
a job that typically uses 10% of the CPU.
job_load: 10
When a job is ready to run on a designated machine but the current load on that
machine is too large to accept the new job’s load, CA Workload Automation AE queues
the job for that machine so it runs when sufficient resources are available.
For job queuing to take place, you must define the priority attribute in the job
definition. The queue priority establishes the relative priority of all jobs queued for a
given machine. The lower number indicates a higher priority. If you do not set the
priority attribute or the priority is set to 0, the job runs immediately on a machine and is
not put in the queue. The job ignores any other job or machine load settings defined.
Example: Set the Job to Run with Highest Priority
This example sets the job to run with the highest priority without overriding the
machine load control mechanism.
priority: 1
Example: Set the Job to Run in the Background
This example sets the job to run in the background when the machine load is low.
priority: 100
You can use the factor attribute to determine the relative processing power for a
machine. To calculate the relative processing power for each machine, the scheduler
multiplies the available CPU cycles by the factor attribute value:
(Available CPU Cycles) x (Factor Attribute Value) = Relative Processing Power
The scheduler determines which of the agent machines specified in the job definition
have the best calculated usage (highest relative processing power). The scheduler starts
the job on the agent machine with the best calculated usage (highest relative processing
power).
Setting the factor value to zero (0) results in a calculated usage of zero (0) but does not
disqualify the machine. The scheduler selects an agent machine with a factor value of
zero (0) only when all other available machines specified in the job definition also have a
factor value of zero (0).
Notes:
■ Factor units are arbitrary, user-defined values. The value consists of a real number,
typically between 0.0 and 1.0. You can set factor units to a value containing a
decimal, such as 0.5. If you do not define the factor attribute in a machine
definition, the value defaults to 1.0.
■ The factor attribute is valid in a real machine definition or component machines
defined to virtual machine.
■ Sometimes the scheduler identifies multiple machines as having the best calculated
usage (highest relative processing power). In such cases, the scheduler randomly
selects one of those machines and starts the job on it. To allow the scheduler to
start the job on any machine specified in the job definition, set the factor attribute
value for all of those machines to zero (0).
■ For more information about the factor attribute in machine definitions, see the
Reference Guide.
Example: Set the Factor for a Low-Performance Real Machine
This example sets the factor for a low-performance real machine, on a scale of 0.0 to
1.0.
factor: 0.1
Example: Set the Factor for a High-Performance Real Machine
This example sets the factor for a high-performance real machine, on a scale of 0.0 to
1.0.
factor: 1.0
Machine Status :
Real machines have a run-time status attribute designed to reflect the machine’s
availability. The machine status lets the scheduler run more efficiently by not wasting
time trying to contact machines that are out of service. If a job is scheduled for a
machine that is offline, it is set to PEND_MACH status until the machine comes back
online. In the case of a virtual machine, offline machines are not considered as possible
candidates for running a job.
A machine can have one of following statuses:
Online
Indicates that the machine is available and accepting jobs to run.
Offline
Indicates that the machine has been manually removed from service and will not
accept jobs to run.
Missing
Indicates that the scheduler has verified that the machine is not responding and has
automatically removed it from service. The machine will not accept jobs to run.
Unqualified
Indicates that the scheduler is attempting to qualify the status of an agent before
switching the machine from an online to missing status. The machine will not
accept jobs to run.
Empty
Indicates that a virtual machine or real machine pool does not contain any
component machines. Jobs scheduled to machines in this status will not run.
More information:
The jil Command and JIL (Job Information Language)
Job Types
When you create a job definition, you must specify the job type. Job types define the
type of work to be scheduled. For example, you can create a CMD job to run a Windows
command, an FTP job to download a file from a server, or an SAPEM job to monitor for
the triggering of an SAP event. You can also define box jobs, which are containers that
hold other jobs or box jobs. You can define your own job type.
Each job type has required and optional attributes that define the job. The job types
have many common attributes and CA Workload Automation AE treats them all
similarly. The primary differences between them are the actions taken when the jobs
run.
The structure of a job depends on the job type. For example, the following illustration
shows the structure of a Command, File Watcher, and Box job:
Common Job Attributes
■ alarm_if_fail ■ notification_id
■ application ■ notification_msg
■ auto_delete ■ owner (This attribute does not apply
to File Trigger jobs.)
■ auto_hold ■ permission
■ avg_runtime ■ priority
■ box_name ■ resources
■ box_terminator ■ run_calendar
■ condition ■ run_window
■ date_conditions ■ send_notification
■ days_of_week ■ service_desk
■ description ■ start_mins
■ exclude_calendar ■ start_times
■ group
■ job_load ■ svcdesk_desc
■ job_type ■ svcdesk_imp
■ max_run_alarm ■ svcdesk_pri
■ min_run_alarm ■ svcdesk_sev
■ must_complete_times ■ term_run_time
■ must_start_times ■ timezone
■ n_retrys
Job States
CA Workload Automation AE tracks the current state, or status, of every job. CA
Workload Automation AE displays job status in the job report that the autorep
command generates and in the CA WCC GUI.
The scheduler records job run information, including job status. The ujo_job_status
table stores job status for the current run, and the ujo_job_runs table stores job status
for previous runs. These tables use numeric codes to represent job status. The numeric
codes are resolved using the ujo_intcodes table. A job can have one of the following
statuses:
ACTIVATED (9)
Indicates that job is contained in a box job with a status of RUNNING but that the
job itself is waiting to start.
FAILURE (5)
Indicates that a job fails to complete successfully. The scheduler issues this alarm
when the alarm_if_fail attribute in a job definition is set to Y and that job fails.
INACTIVE (8)
Indicates that a newly created job has not yet run for the first time.
PEND_MACH (14)
Indicates that the offline status of the machine to which a job is assigned prevents
the job from starting. These jobs can otherwise logically start, so the scheduler
attempts to start them when the offline machine returns to service.
Note: You can use the GlobalPendMach configuration options to control how jobs
in PEND_MACH status start and what happens to new jobs scheduled to currently
offline machines. For more information about the GlobalPendMach parameters on
UNIX, see the Administration Guide. For more information about the Global Pend
Machine fields on Windows, see Online Help.
Job States
ON_HOLD (11)
Indicates that the job is on hold and cannot run until you take it off hold.
Notes:
■ You can place a job in this status only by sending the JOB_ON_HOLD event.
■ To take a job off hold, send the JOB_OFF_HOLD event.
ON_ICE (7)
Indicates that the job is removed from the job stream but is still defined.
Notes:
■ You can place a job in this status only by sending the JOB_ON_ICE event.
■ To return a job that is on ice to the job stream and resume running it, send the
JOB_OFF_ICE event.
ON_NOEXEC (16)
Indicates that the scheduler bypasses execution of the job.
Notes:
■ You can place a job in this status only by sending the JOB_ON_NOEXEC event.
■ These jobs, and box jobs containing them, evaluate as successfully completed.
Downstream jobs that are dependent on these jobs still run, conditions
permitting.
■ When you instruct the scheduler to bypass the execution of a box job, the
scheduler automatically places all jobs in that box job in ON_NOEXEC status.
■ To resume executing bypassed jobs, send the JOB_OFF_NOEXEC event.
QUE_WAIT (12)
Indicates that a lack of available load units on the machines to which a job is
assigned prevent the job from starting. When the required load units become
available, the job starts.
RESTART (10)
Indicates that the scheduler is attempting to restart a job that failed to start as
scheduled. The scheduler attempts to restart the job at periodic intervals until the
job starts or the maximum number of restart attempts is exceeded.
Note: You can set the maximum number of restart attempts to zero (0). If the
scheduler reaches the maximum number of restart attempts without successfully
starting the job, the job fails. The maximum number of restart attempts depends on
the following global settings:
■ Max Restart Trys (on the Windows Administrator) or MaxRestartTrys (in the
UNIX configuration file)
■ Max Restart Wait (on the Windows Administrator) or MaxRestartWait (in the
UNIX configuration file)
Job States
RESWAIT (15)
Indicates that the job is waiting for a resource before it can continue running. When
the resource is available, the job starts.
RUNNING (1)
Indicates one of the following situations:
■ The agent is executing the job.
■ The scheduler has instructed the agent to start jobs that are contained in the
box job.
Note: A box job acts as a container for other jobs but performs no action itself. The
agent does not execute box jobs. The scheduler places box jobs in RUNNING status
to send a message to the agent that it can start jobs that are contained in the box
job. These jobs start as soon as they meet the starting conditions that are specified
in the job definitions.
STARTING (3)
Indicates that the scheduler initiated the start job procedure with the agent. This
status does not apply to box jobs.
SUCCESS (4)
Indicates that the job exits with a code equal to or less than the maximum exit code
for success specified in the job definition. A box job enters this status in the
following situations:
■ All jobs that are contained in the box job succeed.
■ The exit condition for the box job evaluates to TRUE.
Job States
TERMINATED (6)
Indicates that the job ends while it is still in the RUNNING state. The scheduler
issues an alarm when a job is terminated. A job is terminated when one of the
following situations occurs:
■ You send a KILLJOB event.
■ You issue the kill command (UNIX).
■ The job definition specifies that the scheduler should terminate the job under
specific circumstances and those circumstances occur. For example, you can
specify that the scheduler should terminate a job when the box job containing
it fails.
■ The job does not complete within the maximum run time specified in the job
definition
WAIT_REPLY (13)
Indicates that the job cannot continue running without manual intervention. The
scheduler issues an alarm when a job requires a user response to continue running.
Note: The job continues running only when you reply to this alarm by sending the
REPLY_RESPONSE event.
The job state reflects the most recent event processed. A job enters one of the
completed states (such as SUCCESS) when all of the events that are associated with that
job are processed, and the job remains in that state until the job starts again.
Sometimes displays a status that does not reflect reality; for example, the system
displays completed jobs as in the RUNNING state when the scheduler is still processing
events that are associated with that job. You can use the autorep command to view all
the of the events (including unprocessed events) that are associated with a job. For
more information about the autorep command, see the User Guide.
Job States
Note: The scheduler determines whether or not to start jobs based on a number of
factors. These factors depend on the job type and the state of the job:
■ The scheduler re-evaluates starting conditions for jobs that are in the ON_HOLD
state when you issue the JOB_OFF_HOLD event using the sendevent command. The
scheduler also re-evaluates starting conditions for jobs that are leaving one of the
following queued states:
■ QUE_WAIT
■ RES_WAIT
■ PEND_MACH
The scheduler does not re-evaluate date and time conditions for these jobs if they
meet those conditions while they are on hold or queued. Jobs that meet date and
time conditions while they are on hold or queued start unless they do not meet
other starting conditions. Jobs that did not meet date and time conditions while
they were on hold or queued and still do not meet those conditions do not start.
You can configure CA Workload Automation AE to skip starting condition evaluation
for queued jobs. In this case, the jobs start immediately upon leaving the queue,
even if their starting conditions are no longer satisfied.
■ The scheduler does not start jobs that are in the ON_ICE state when you issue the
JOB_OFF_ICE event using the sendevent command. These jobs start the next time
that their starting conditions recur.
■ The scheduler starts box jobs that are in the ON_NOEXEC state but does not start
jobs of other types that are in this state. The scheduler places these box jobs in
RUNNING status but individual ON_NOEXEC jobs that are contained in the box job
remain in the ON_NOEXEC state. The scheduler automatically generates one
BYPASS event against jobs that are in the ON_NOEXEC state. The BYPASS event is
sent in place of the completion event for box jobs and in place of the RUNNING,
STARTING and completion events for individual jobs. After the scheduler places an
ON_NOEXEC box job in RUNNING status, the scheduler waits for all jobs in the box
job to bypass execution before returning the box job to the ON_NOEXEC state.
■ Box jobs in ON_NOEXEC status start and all of the jobs that are contained in the box
job enter the ACTIVATED state. The scheduler immediately bypasses and marks as
complete the jobs that are contained in the box job unless other conditions apply.
Jobs that are not marked complete by the time the box job completes enter or
remain in the ON_NOEXEC state.
■ All jobs that are contained in a box job enter the ACTIVATED when the box job
starts. Jobs run immediately unless other conditions apply. Jobs contained in a box
job that do not complete by the time that the box job completes enter INACTIVE
status. These jobs do not retain their statuses from previous box job processing
cycles when a new box job cycle begins.
More information:
Box Jobs (see page 187)
Defining Jobs
Defining Jobs
Job definitions specify the work that individual jobs do.
When you define jobs, you can optionally schedule those jobs using the date and time
condition attributes. Scheduling jobs to run on customized schedules requires defining
custom calendars that you can reference in job definitions. Jobs that do not have date
and time conditions specified in their definitions only run when you start them
manually.
To improve workload performance for certain types of jobs, you can define them to run
on a cluster.
job_name
Defines a unique name for the job.
machine_name
Specifies the name of the machine on which the job runs.
type
Specifies the type of job you are defining.
Defining Jobs
90 User Guide
attribute
Specifies the name of a JIL attribute that applies to the job type that you are
updating. You can specify one or more attributes.
Note: For more information about specific job types, see the chapter for that
job type. For more information about JIL job types and other job definition
attributes, the values that you can specify for those attributes, and JIL syntax,
see the Reference Guide.
value
Defines the value of the corresponding attribute.
More information:
Issue JIL in Interactive Mode on Windows (see page 33)
Issue JIL in Interactive Mode on UNIX (see page 33)
Issue JIL Using a Script on UNIX (see page 35)
Issue JIL Using a Script on Windows (see page 36)
Defining Jobs
92 User Guide
Delete a Job
When you no longer need a job definition, you can delete it from the database.
Follow these steps:
1. Do one of the following:
■ Issue JIL in interactive mode.
■ Open a JIL script in a text editor.
2. Specify the following subcommand:
delete_job: job_name
job_name
Specifies the name of the job you want to delete.
3. Do one of the following:
■ Enter exit if you are using interactive mode.
■ Redirect the script to the jil command if you are using a script.
The delete request is issued. When JIL is in job verification mode (the default), the
delete_job subcommand scans the ujo_job_cond table and notifies you of any
dependent conditions for the deleted job before deleting it.
Note: You can also delete a job using CA WCC. For more information about using CA
WCC, see the CA WCC Online Help.
Example: Delete a Job
This example deletes the test_run job.
delete_job: test_run Running a Job After Using JIL
94 User Guide
To specify the job owner, add the owner attribute to your job definition.
Notes:
■ The owner attribute does not apply to File Trigger jobs.
■ If CA Workload Automation AE is running in native security mode, you can change
the owner value only if you have EDIT superuser permissions.
■ If CA Workload Automation AE is running in external security mode using CA EEM,
you can change the owner value only if you have as-owner authority.
■ CA Workload Automation AE uses the owner value for all job types except for File
Trigger. CA Workload Automation AE does not use the oscomponent.default.user
parameter located in the agent's agentparm.txt file.
■ Other application specific uses of the owner attribute apply to certain job types. For
more information about these job type specific uses, see the documentation on
individual job types in the User Guide.
■ For more information about the owner attribute, see the Reference Guide.
Global Variables
You can define global variables using the sendevent command. After you define a global
variable to CA Workload Automation AE you can use the variable as a job dependency.
The job dependency is satisfied only when the value of the expression evaluates to
TRUE.
You can reference a global variable as part of the syntax of any of the following
attributes:
■ command
■ connect_string
■ destination_file
■ ftp_local_name
■ ftp_remote_name
■ i5_library_list
■ i5_name
■ i5_params
■ monitor_cond
■ scp_local_name
■ scp_remote_dir
■ scp_remote_name
■ sp_name
■ sql_command
■ std_err_file
■ std_in_file
■ std_out_file
■ success_criteria
■ tablename
■ text_file_name
■ trigger_cond
■ watch_file
Global Variables
96 User Guide
Notes:
■ If the length of the attribute value exceeds the limits after the global variable
expansion, the job goes into a RESTART state. The job restarts based on the value
specified in the MaxRestartTrys (on UNIX) or Max Restart Trys (on Windows)
parameter.
■ For the std_in_file, std_out_file, and std_err_file attributes, the length of the
attribute value after the global variable expansion can exceed the limits by four
characters. For the command attribute, the length of the attribute value after the
global variable expansion can be up to 1024 characters.
■ If a global variable is not defined in the database, the scheduler displays a warning
message and continues the execution of the job.
■ For more information about using the sendevent command to define global
variables or about the attributes that support global variable substitution, see the
Reference Guide.
Example: Define a Global Variable
This example sets the global variable "Today" to a value of “12/25/2007":
sendevent -E SET_GLOBAL -G "Today=12/25/2007"
Example: Monitor a File Whose Name is Assigned to a Global Variable on UNIX
This example monitors a file whose name has been assigned to the global variable
file_1.
insert_job: ft_unix2
job_type: FT
machine: unixagt
watch_file: $${file_1} Global Variables
Alerts
98 User Guide
Alerts
You can define the following job types to monitor a condition continuously:
■ CPU Monitoring (OMCPU)
■ Database Monitor (DBMON)
■ Database Trigger (DBTRIG)
■ Disk Monitoring (OMD)
■ File Trigger (FT)
■ Text File Reading and Monitoring (OMTF)
■ Windows Event Log Monitoring (OMEL)
■ Windows Services monitoring (OMS)
Each time the specified condition occurs, an ALERT event is written to the scheduler log
file (event_demon.$AUTOSERV on UNIX and event_demon.%AUTOSERV% on Windows).
An alert helps you track and report each time that a monitored condition occurs.
Note: An alert is only generated for triggers that occur during continuous monitoring.
Alerts are not generated for non-continuous monitoring (NOW and WAIT).
To stop a continuous monitor, you must complete the job manually by issuing the
following command:
sendevent –E KILLJOB –J job_name
For non-continuous monitors the proper event order will be reflected as:
1. STARTING
2. RUNNING
3. SUCCESS
You can view the text of alerts using the following methods:
■ View the scheduler log file
■ Issue the following command:
autorep –J job_name –d
■ CA WCC
Note: You cannot manually send the ALERT event using the sendevent command.
Example: Trigger Alerts When Monitoring CPU Usage Continuously
This example continuously monitors used CPU on the unixagent computer. When the
job runs, it goes into a RUNNING status. When the job detects that the used CPU is
within 70 and 100 percent, an ALERT event is raised (an alert is written to the scheduler
log file). The available, used CPU and load averages will be reported as part of the ALERT
event and the status message is reported with the RUNNING event. Subsequently, each
time the job detects that the use CPU meets the monitored condition, an alert is
triggered. The job only ends when it is complete manually.
insert_job: cpu_monitoring_used
job_type: OMCPU
machine: unixagent
lower_boundary: 70
cpu_usage: USED
inside_range: TRUE
monitor_mode: CONTINUOUS
In contrast, the following example monitors used CPU in WAIT monitor mode. When the
job runs, it goes into a RUNNING status. When the job detects that the used CPU is
within 70 and 100 percent, the job completes. No alert is triggered. The available, used
CPU and load averages are reported on the SUCCESS event.
insert_job: cpu_monitoring_used_wait
job_type: OMCPU
machine: unixagent
lower_boundary: 70
cpu_usage: USED
inside_range: TRUE
monitor_mode: WAIT Starting Conditions
Starting Conditions
CA Workload Automation AE verifies whether it should start a job by evaluating the
starting conditions defined for the job. All defined starting conditions must be true for a
job to start.
CA Workload Automation AE starts all jobs that meet their starting conditions, unless
one of the following conditions apply:
You place the job on hold or on ice. If you put a job on hold or on ice, the job does not
start until you take it off hold or off ice.
Notes:
■ To put a job on hold or on ice, issue the JOB_ON_HOLD or JOB_ON_ICE event using
the sendevent command. To take a job off hold or off ice, issue the JOB_OFF_HOLD
or JOB_OFF_ICE event.
■ You can also instruct the scheduler to bypass execution of a job by issuing the
JOB_ON_NOEXEC event.
■ Jobs in the ON_NOEXEC state start immediately when they meet their starting
conditions. The scheduler simulates running these jobs, but the agent does not
execute commands associated with the jobs. Jobs in this state immediately return
an evaluation of successfully completed on the Scheduler machine. When you issue
the JOB_OFF_NOEXEC event against a job in the ON_NOEXEC state, the agent
resumes executing commands associated with that job the next time the job runs.
■ External conditions prevent the job from running. Depending on the reason, CA
Workload Automation AE places the job in one of the following queued states:
– When an offline machine prevents the job from running, the job enters
PEND_MACH status.
– When held resources prevent the job from running, the job enters RES_WAIT
status.
– When unavailable load units prevent the job from running, the job enters
QUE_WAIT status.
When a job leaves a queued state, the scheduler determines whether to start the job by
re-evaluating starting conditions for that job unless you configure CA Workload
Automation AE to skip starting condition evaluation for queued jobs. If a job that is
contained in a box fails its starting condition checks when leaving the queue, the
scheduler places that job in the ACTIVATED state. If a job that is not contained in a box
fails its starting condition checks when leaving the queue, the scheduler places that job
in the INACTIVE state. If the job meets its starting conditions, or if you configure the
system to skip starting condition evaluation for queued jobs, the job starts.
When you take a job off hold, the scheduler re-evaluates starting conditions for that job.
When you take a job off ice, the scheduler does not restart the job until its starting
conditions recur, even if those conditions were met while the job was on ice. Starting Conditions
When you instruct the scheduler to bypass execution of a job, the scheduler starts the
job when it meets its starting conditions. The scheduler simulates running these jobs,
but the agent does not execute commands associated with the jobs. Bypassed jobs
evaluate as successfully completed on the scheduler machine. When you issue the
JOB_OFF_NOEXEC event, the agent executes commands associated with the specified
job the next time the job starts. Changing the executable status of a job does not affect
evaluation of starting conditions.
Notes:
■ When you take jobs off hold or when jobs leave a queued state, the scheduler does
not re-evaluate date and time conditions. Jobs that meet their date and time
conditions while they are in a queued state or on hold start as soon as they leave
the queue or are taken off hold unless other starting conditions apply and are not
satisfied.
■ If you configure CA Workload Automation AE to skip starting condition evaluation
for queued jobs, those jobs start immediately upon leaving a queued state.
■ For more information about configuring CA Workload Automation AE to skip
starting condition evaluation for queued jobs, see the Administration Guide or the
Online Help.
■ For more information about the sendevent command, see the Reference Guide.
When you put a job on ice or instruct the scheduler to bypass execution of the job, it
affects starting conditions of downstream dependent jobs. How CA Workload
Automation AE evaluates the downstream dependent jobs depends on the condition of
the job that you bypass or put on ice.
Suppose that you put JobA in ON_NOEXEC status. When CA Workload Automation AE
bypasses JobA, downstream jobs dependent upon JobA are evaluated when starting
conditions of JobA are met, based on the condition of JobA, as follows:
Condition Evaluates to
success (JobA) TRUE
failure (JobA) FALSE
terminated (JobA) FALSE
done (JobA) TRUE
notrunning (JobA) TRUE
exitcode TRUE, if the expression evaluates to true with an
exit code of 0
FALSE, if the expression evaluates to false with an
exit code of 0 Starting Conditions
Suppose that you put JobA in ON_ICE status. The downstream jobs dependent upon
JobA are immediately evaluated based on the condition of JobA, as follows:
Condition Evaluates to
success (JobA) TRUE
failure (JobA) FALSE
terminated (JobA) FALSE
done (JobA) TRUE
notrunning (JobA) TRUE
exitcode FALSE
TZ Environment Variable
Valid on UNIX
By default, jobs with time-based starting conditions that do not specify a time zone have
their start event scheduled based on the time zone under which the database runs.
Before you start the scheduler or application server, ensure that the TZ environment
variable is set. The scheduler or application server references this setting to determine
the default time zone. After you upgrade your database, you must start the scheduler to
insert a time zone offset value (calculated from the value of the TZ environment
variable) into the database. Do this before executing jil or autorep.
Important! Ensure that the database is running in the same time zone that the
scheduler starts up with.
Starting Conditions
You can configure more complex conditions by combining a series of conditions with the
AND and OR logical operators. You can use the pipe symbol (|) instead of the word OR
and the ampersand symbol (&) instead of the word AND. Spaces between conditions
and delimiters are optional. You can specify even more complex conditions by grouping
the expressions in parentheses, which force precedence. The equation is evaluated from
left to right.
For example, in the following set of starting conditions, either both A and B must be
successful or both D and E must be successful for the statement to evaluate as TRUE:
(success(JobA) and success(JobB)) or (success(JobD) AND success(Job E))
Note: If you specify a condition for an undefined job, the condition evaluates as FALSE,
and any jobs dependent on this condition do not run. You can use the job_depends
command to check for this type of invalid condition statement.
The syntax for defining job dependencies is the same whether the job is being defined
using JIL or the CA WCC GUI, except that the JIL statement begins with the JIL condition
keyword.
Starting Conditions
job_name
Identifies the job on which the new job is dependent.
You can also abbreviate the dependency specification EXIT CODE to e and VALUE (of a
global variable) to v.
You can use the max_exit_success (maximum exit code for success) attribute set for a
job to control the value of the SUCCESS status. If you specify this attribute, any job that
exits with an exit code less than or equal to the specified value is treated as a success. A
FAILURE status means the job exited with an exit code higher than this value. The
default exit code for normal job completion is 0. A TERMINATED status means the job
was killed.
Note: You can use either uppercase or lowercase letters to specify a status. However,
you cannot use mixed case.
Starting Conditions
When a box job starts, the status of all the jobs in the box changes to ACTIVATED.
Therefore, subsequent jobs in the box that depend on the completion of jobs performed
earlier in the same box only use the completion statuses from this box run. Placing the
jobs in one processing cycle inside a top-level box and setting the box to start at the
beginning of the processing cycle prevents time-critical jobs from being affected by
invalid information.
Starting Conditions
When a job is first entered into the database, and before it runs for the first time, its
status is set to INACTIVE. By changing the status of jobs that have completed but whose
completion status should no longer be used in dependent job conditions to INACTIVE,
the completion status from the last run is no longer the current status and it is not used.
Use the sendevent command to change a job status to INACTIVE. Alternatively, you
could create a CA Workload Automation AE job to accomplish this. If you change the
status of a top-level box to INACTIVE, all the jobs in the box also change to INACTIVE.
Deleting and reinserting the job using JIL accomplishes the same thing. However, the
past reporting history on the job is no longer available. Updating a job using JIL does not
change the status of the job.
operator
Specifies one of the following exit code comparison operators:
=
Equal to.
!=
Not equal to.
<
Less than.
>
Greater than.
<=
Less than or equal to.
>=
Greater than or equal to.
Starting Conditions
value
Defines the numeric exit code value on which to base the dependency.
For example, if a broken communication line results in JobA failing with an exit code of
4, and you want the system to run a script (JobB) that redials the line when this code is
encountered, you would enter the following for the job dependency specification for
the JobB redial job:
exitcode (JobA) = 4
You can use any job status or exit codes as part of the specification for starting
conditions. You can abbreviate the dependency specification exitcode with the letter e
(uppercase or lowercase).
Generally, a zero (0) exit code indicates success, while a non-zero exit code indicates an
error. The expected error values should be documented with each individual program,
but some programs can return unexpected exit codes. Modify these programs so that
they return expected values, and use these values when specifying exit code
dependencies.
Jobs are created using standard Windows process creation techniques. After the job is
created, the agent waits for the job to complete. When the job completes, CA Workload
Automation AE gets the program exit code from Windows and stores it in the database
for later use.
When launching programs directly, the exit codes are returned and put in the database.
However, there are some exit code behaviors that you must take into consideration
when using a job to start *.BAT batch files.
Starting Conditions
The exit code returned from a batch file is the return code from the last operation
executed in that particular batch file. Consider the following example:
REM test batch file
test
if errorlevel 1 goto bad
goto good
:bad
del test.tmp
:good
exit
This sample batch file returns a 0 exit code when the test program exits with a 1 exit
code as long as test.tmp exists. If test.tmp does not exist, the return code is from the del
line and not from the line that runs the test. Therefore, this batch file returns a 0
(successful) exit code, even if test failed to execute as intended.
<
Less than.
>
Greater than.
<=
Less than or equal to.
>=
Greater than or equal to.
value
Defines the numeric or text value of the global variable on which to base the
dependency.
Limits: This value can be up to 100 characters in length and cannot contain
quotation marks or spaces. The following characters are valid: a-z, A-Z, 0-9, period
(.), underscore (_), and hyphen (-).
Note: When using JIL, use the condition attribute to enter the above expression in the
appropriate JIL script.
For example, assume that a set of jobs in a box should only run with a manager's
approval. In this case, use the following syntax to set the global variable named
manager-ok to OK, and make the top-level box job dependent on this global variable:
VALUE(manager-ok) = OK
You can abbreviate the dependency specification VALUE with the letter v (uppercase or
lowercase).
Starting Conditions and Boxes
More Information:
Global Variables (see page 95)
– If a job is initially defined against a virtual machine and you define a one-time
override against the machine attribute while the job is in PEND_MACH status
and one or more component machines in the initial virtual machine return to
service, the scheduler starts the job on the machine specified by the override. If
the scheduler cannot contact the machine specified by the override, it puts the
job in PEND_MACH status until the machine specified by the override becomes
available.
Notes:
■ If you set the interval to 0 (the default value), the scheduler starts all jobs in
PEND_MACH status with no delay between job starts and the burst value is ignored.
■ The order in which the jobs are started depends on the job priority and amount of
time the job has been in PEND_MACH status. For example, if JOB1, JOB2, and JOB3
have the same priority and they enter the PEND_MACH status at 08:00:00 a.m.,
08:00:01a.m., and 08:00:02 a.m. respectively, the order in which they are started is
JOB1, JOB2, and JOB3. Once the scheduler determines the starting order of jobs
that are coming out of the PEND_MACH status, you cannot modify the starting
order by using the sendevent command to send the CHANGE_PRIORITY event. If
you send the CHANGE_PRIORITY event, the job priority changes do not apply to the
run of the job exiting in PEND_MACH status. The job priority changes apply to the
next run of the job.
■ If jobs enter PEND_MACH status at the same time and have the same priority, their
starting order is not guaranteed. If the job priority is set to 0, it overrides the
duration the job has been in PEND_MACH status and starts immediately.
■ For more information about the GlobalPendMachInterval parameter and
controlling the starting of jobs in PEND_MACH status on UNIX, see the
Administration Guide. For more information about the Global Pend Machine
Interval field and controlling the starting of jobs in PEND_MACH status on Windows,
see the Online Help.
Controlling Jobs in PEND_MACH Status
If a job restarts, the run number remains the same and the ntrys field is incremented. In
the standard reports (autorep command), these two values are displayed in the run
column as run_num/ntry.
The run_num/ntry value is defined in the run-time environment for the job, and is
accessible to shell scripts or executables run as the job's command. This value is
contained in the variable $AUTORUN.
CA Workload Automation AE also maintains a value for each job's name, which is
defined in the runtime environment for the job.
As with $AUTORUN, this value is accessible to shell scripts or executables run as the
job's UNIX command. The value is contained in the variable $AUTO_JOB_NAME.
The times shown in the sample script are surrounded by quotation marks because they
contain a colon. You can also use a backslash (\) as an escape character for the colon, as
the following example shows:
start_times: 10\:00, 14\:00
Note: If a job runs daily at the same time (for example, 12:00) and you edit the job
definition and save it at 11:59, the job will not run until the next day at 12:00.
When you save a start time job definition to the database within one minute of the
specified start time, the start time is placed in the future (that is, tomorrow). However,
if the start time is two minutes or more from the save time, the job runs at the next
occurrence of the specified start time (that is, today).
More information:
Job Profiles (see page 127)
Dependent Jobs
Look-Back Conditions
CA Workload Automation AE supports look-back conditions. You can use look-back
conditions to base dependencies for a job on the last run of another job. The last run is
defined by the ending time of the last successful run of a job. If the job has run with the
specified result, the condition or predecessor is satisfied and the job starts. If not, the
condition is not satisfied and the job for which the look-back condition is defined does
not start.
To specify a look-back dependency, enter the job name followed by a comma (,) then
HH (hours), period (.) and MM (minutes).
Example: Specifying Look-Back Conditions
This example shows a job definition with look-back conditions.
In the following job definition, the command job test_sample_04 can only start if all of
the following conditions are met:
■ The last run of test_sample_01 completed successfully during the last 12 hours.
■ The last run of test_sample_02 completed with a FAILURE status during the last 24
hours.
■ The last run of test_sample_03 completed successfully at any time.
insert_job: test_sample_04
machine: localhost
command: sleep 10
condition: success(test_sample_01,12.00) AND failure(test_sample_02,24.00) AND
success(test_sample_03) Specifying One-Time Job Overrides
JIL will not accept an override if it results in an invalid job definition. For example, if a
job definition has only one starting condition, start_times, JIL will not let you set the
start_times attribute to NULL because removing the start condition makes the job
definition invalid (no start time could be calculated).
One-time job overrides are applied to jobs restarted due to system problems, but are
not applied to jobs restarted because of application failures.
System problems include the following:
■ Machine unavailability
■ Media failures
■ Insufficient disk space
Application failures include the following:
■ Inability to read or write a file
■ Command not found
■ Exit status greater than the defined maximum exit status for success
■ Various syntax errors
Notes:
■ Overriding the machine attribute of a job in PEND_MACH status does not cause the
scheduler to start the job. The job remains in PEND_MACH status regardless of the
status of the machine specified by the override. The scheduler only evaluates jobs
in PEND_MACH status when it processes the MACH_ONLINE events.
■ CA Workload Automation AE does not execute overridden jobs in ON_NOEXEC
status. If you issue a one-time override for a job in this status or put a job in this
status after overriding, the override remains in effect until you issue the
JOB_OFF_NOEXEC event.
Date and Time Attributes and Time Changes
Jobs with absolute time dependencies are defined to run at a specific time of the day
(for example, 9:30 on Thursday or 12:00 on December 25). The following attributes
define absolute time dependencies:
■ days_of_week
■ exclude_calendar
■ must_start_times
■ must_complete_times
■ run_calendar
■ run_window
■ start_times
Relative time dependencies are based either on the current time or relative to the start
of the hour (for example, start a job at 10 and 20 minutes after the hour, or terminate a
job after it has run for 90 minutes). The following attributes define relative time
dependencies:
■ auto_delete
■ max_run_alarm
■ min_run_alarm
■ must_start_times
■ must_complete_times
■ start_mins
■ term_run_time
■ watch_interval
During the time change, absolute time attributes behave differently than relative time
attributes.
If you schedule a job to run more than once during the missing hour (for example, at
2:05 and 2:25), only the first scheduled job run occurs. Additional start times for the
same job in the missing hour are ignored.
Jobs with relative time dependencies run as expected. For example, a job specified to
run at 0, 20, and 40 minutes after the hour is scheduled for 1:00 ST, 1:20 ST, 1:40 ST,
3:00 DT, 3:20 DT, and 3:40 DT.
Run windows are treated differently. When the specified end of the run window falls
during the missing hour, CA Workload Automation AE recalculates its end time, so that
the effective duration of the run window remains the same. For example, the product
recalculates a run window of 1:00 - 2:30 so that the window ends at 3:30 and the run
window still remains open for 90 minutes.
When the run window’s specified start time falls during the missing hour, CA Workload
Automation AE moves the start time to 3:00. The end time does not change, so the run
window is shortened. For example, a run window of 2:45 - 3:45 becomes 3:00 - 3:45,
shortening the run window by 15 minutes.
When the run window’s start and end time both fall during the missing hour, CA
Workload Automation AE moves the start time to the first minute after 3:00 and the
end time to one hour later. Therefore, the resulting run window might be lengthened.
For example, a run window of 2:15 - 2:45 becomes 3:00 - 3:45, or 15 minutes longer.
Date and Time Attributes and Time Changes
Jobs that are not time-based but have other dependencies still run during the first hour.
Jobs with relative time dependencies run as expected. For example, if a job is scheduled
to run on Sunday at 0:30 and its term_run_time attribute is set to 120 minutes, the job
would normally terminate at 2:30. On the day of the autumn time change, the job
terminates at 1:30 standard time, which is 120 minutes after the job started.
When testing how the change from daylight time to standard time affects your jobs, you
must set the system clock to a time before 1:00 a.m. and allow the entire hour to pass
before you can observe the time change. If you manually set the time to a period during
the 1:00 a.m. to 2:00 a.m. window, the system assumes that the time change has
already occurred and does not reset at 2:00 a.m.
Run windows are treated differently. When the specified start of a run window is before
the time change and its specified end occurs during the repeated hour, the run window
closes during the daylight time period (the first hour). For example, a run window of
11:30 - 1:30 ends at 1:30 DT, not 1:30 ST (that is, the run window remains open for its
specified two hours, not for three hours). A problem might occur if there are also
associated start times for the job that occur during the repeated hour. If the job in our
example also had a start time of 1:15, the start time would be calculated for 1:15 ST and
the job would not run on the day of the time change.
Job Profiles
When the specified opening of the run window falls during the repeated hour, CA
Workload Automation AE moves its start time to the second, standard time hour. The
end time does not change, so the length of the run window remains the same. For
example, a run window of 1:45 - 2:45 becomes 1:45 ST - 2:45 ST.
When both the specified start and end of the run window occur during the repeated
hour, the run window opens during the second, standard time hour.
Job Profiles
A job profile defines the non-system environment variables for a job. When you define a
job, you can assign a job profile to it. Only one profile can be sourced for a job.
Job profiles apply to the following job types:
■ Command jobs
■ File Watcher (FW) jobs that are submitted to the legacy agent
On UNIX, job profiles are shell scripts that typically include the definitions and exports of
environment variables. The command that the job runs can reference these variables.
You can store job profiles on UNIX in any directory. Job profiles on UNIX are always
sourced using the job owner's default shell, which is set for the user in the etc/passwd
file. Therefore, when you create a job profile, you must use the syntax of the owner's
default shell. For example, if the owner's default shell is the Korn shell, you must use
Korn syntax in the profile script.
On Windows, you create job profiles using the Job Profiles window in the CA Workload
Automation AE Administrator utility. These profiles contain variable=value pairs that
define the environment variables. The profiles are stored in the
SystemAgent\agent_name\profiles directory of the CA Workload Automation AE
computer. If you move a job profile to another location, you must specify the full path
when you assign the profile to a job. The agent uses the variable=value pairs in the job
profile to set the environment variables.
Environment Variables
System environment variables are automatically set in the environment of a job.
However, user environment variables are not automatically set. You must define all
other required environment variables using one or both of the following methods:
■ envvars attribute in the job definition
■ Job profile
Job Profiles
If a job profile is assigned to a job, the agent sources the profile before running the job.
When the agent reads the profile, the environment variables in the profile are
expanded. For example, if Path is a variable in the profile, the following occurs:
■ Any environment variables specified in the value of Path are expanded.
■ That path is used to search for the command.
■ The new value for the %Path% variable is set before running the command.
If you want to specify the full path name, you can use variables set from the job profile
in the path name specification.
The agent reads profile variables in alphabetical order. Therefore, if you plan to expand
variables in the profile itself, you must define the variables so that they are in the
appropriate order when read alphabetically.
Notes:
■ On the agent, you can define environment variables that apply to all jobs at a global
agent level, scheduling manager level, or user level. For example, suppose that you
want to set an environment variable for all jobs that run on an agent under a
specific user (owner). Instead of defining that variable in every job definition using
the envvars attribute or in a job profile, you can define the variable on the agent
using the oscomponent.environment.variable_user_userid parameter. For more
information about setting environment variables on the agent, see the CA Workload
Automation Agent for UNIX, Linux, or Windows Implementation Guide.
■ For more information about the envvars and profile JIL attributes, see the Reference
Guide.
Job Profiles
To define must start times, add the must_start_times attribute to your job definition.
To define must complete times, add the must_complete_times attribute to your job
definition.
You can specify both must_start_times and must_complete_times attributes in the
same job definition.
After the job is defined, you can issue the autorep -q command to display the must start
times and the must complete times. You can issue the autorep -d command to view the
alarms generated. You can also view the scheduler log file (event_demon.$AUTOSERV
on UNIX and event_demon.%AUTOSERV% on Windows) to see which alarms were
issued.
Note: For more information about the syntax for the must_start_times and
must_complete_times attributes, see the Reference Guide.
■ The scheduler checks the CHK_START event to see whether the job has started
successfully.
■ If the job has not started, a MUST_START_ALARM is issued. An alert is written to
the scheduler log file to indicate that the CHK_START criteria has not been satisfied.
■ The scheduler checks the CHK_COMPLETE event to see whether the job has
completed successfully. The scheduler checks for the SUCCESS, FAILURE, or
TERMINATED events.
Must Start Times and Must Complete Times
Example: Specify Absolute Must Start and Must Complete Times on the Next Day
This example defines a job to run every day at 12:00 a.m. Suppose that you want each
job run to start by 10:10 a.m. the next day and end by 10:12 a.m. the next day. You must
specify 34:10 in the must_start_times attribute and 34:12 in the must_complete_times
attribute.
insert_job: job3
command: echo "hello"
machine: localhost
date_conditions: y
days_of_week: all
start_times: "12:00"
must_start_times: "34:10"
must_complete_times: "34:12"
The must start time is calculated as follows:
must start time + 24 hours
= 10:10 + 24 hours
= 34:10
The must complete time is calculated as follows:
must complete time + 24 hours
= 10:12 + 24 hours
= 34:12
If a job run does not start by the must start time, a MUST_START_ALARM is issued to
notify you that the job has not started on time. If a job run does not complete by the
must complete time, a MUST_COMPLETE_ALARM is issued to notify you that the job has
not completed on time.
Example: Specify Relative Must Start and Must Complete Times With start_mins
This example defines a job to run every day at 10 minute intervals every hour (for
example, 2:00 p.m., 2:10 p.m., 2:20 p.m., and so on). Each job run must start within 2
minutes after the specified start times and complete within 7 minutes after the
specified start times. Otherwise, an alarm is issued for each missed start or complete
time. For instance, the 2:10 p.m. job run must start by 2:12 p.m. and must complete by
2:17 p.m.
insert_job: test_must_start_complete
job_type: CMD
machine: localhost
command: /opt/StartTransactions.sh
date_conditions: y
days_of_week: all
start_mins: 10, 20, 30, 40, 50, 00
must_start_times: +2
must_complete_times: +7
Delete Obsolete Job Versions
When you update or delete a job definition, previous versions of the definitions are
stored in the database. To prevent the database from being overloaded with job
versions, you can delete obsolete job versions. Job versions are obsolete when the job is
inactive and the database no longer refers to it.
Note: We recommend that you issue the archive_events command before issuing the
archive_jobs command. We also recommend that you run archive_jobs as part of your
usual database maintenance.
Follow these steps:
1. Do one of the following:
■ On UNIX, run the shell that is sourced to use CA Workload Automation AE.
The UNIX operating system prompt is displayed.
■ On Windows, click Start, Programs, CA, Workload Automation AE, Command
Prompt (instance_name).
The CA Workload Automation AE command prompt opens. The command
prompt presets all the environment variables for the instance.
RESTRICT_DELETE_JOB=1
Restricts a user from deleting a job when the job is in ACTIVATED, RUNNING, or
STARTING states.
RESTRICT_DELETE_DEPENDENT_JOB=1
Restricts a user from deleting a job if the job has dependencies.
Application Services jobs let you manage entity beans, session beans, and MBeans,
publish and consume JMS messages, invoke programs over HTTP, and run other types of
Java-based workload.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
You can define the following Application Services jobs:
Entity Bean
Lets you create an entity bean, update the property values of an existing entity
bean, or remove an entity bean from the database.
HTTP
Lets you invoke a program over HTTP or HTTPS in a similar way to a web browser.
For example, you can use the HTTP job to invoke a CGI script, a Perl script, or a
servlet. The HTTP job sends a URL over HTTP using the GET method or a form over
HTTP using the POST method.
JMS Publish
Lets you send a message to a queue or publish a message to a topic on a JMS
server.
JMS Subscribe
Lets you consume messages from a queue or topic on a JMS server.
Application Services Jobs
138 User Guide
JMX-MBean Attribute Get
Lets you query a JMX server for the value of an MBean attribute. The returned
value is stored on the computer where the Application Services agent plug-in
resides.
JMX-MBean Attribute Set
Lets you change the value of an MBean attribute on a JMX server.
JMX-MBean Create Instance
Lets you create an MBean on a JMX server.
JMX-MBean Operation
Lets you invoke an operation on an MBean on a JMX server.
JMX-MBean Remove Instance
Lets you remove an MBean from a JMX server.
JMX-MBean Subscribe
Lets you monitor an MBean for a single notification or monitor continuously for
notifications.
POJO
Lets you instantiate a class to create a Java object and invoke a method on it. The
job is restricted to classes that take constructors with no arguments (default
constructors). You can use the POJO job to invoke custom Java code on a local
computer.
RMI
Lets you set up interaction between Java objects on different computers in a
distributed network. Using an RMI job, you can access a remote server and invoke a
method on a Java object.
Session Bean
Lets you access a session bean on an application server. This job type can make a
Remote Procedure Call (RPC) to the session bean, invoke a method that defines the
business logic, pass parameters to the method, and have the results returned as
serialized Java output. You can access stateless and stateful session beans using the
Session Bean job.
Payload Producing and Payload Consuming Jobs
A payload producing job is a job that produces binary output that is persisted as a
serialized Java object.
The following job types are payload producing jobs:
■ JMS Subscribe
Note: The appservices.jms.subscribe.persist parameter must be set to true in the
agent's agentparm.txt file for JMS Subscribe jobs to be payload producing jobs.
■ JMX-MBean Attribute Get
■ JMX-MBean Attribute Set
■ JMX-MBean Operation
■ POJO
■ RMI
■ Session Bean
■ Web Service
By default, the serialized Java object is stored on the agent computer in the spool
directory, using the job name and a numeric suffix as the file name. You can redirect the
output to a destination file.
A payload consuming job is a job that uses the output from a payload producing job as a
parameter's input value.
The following job types are payload consuming jobs:
■ Entity Bean
■ JMS Publish
■ JMX-MBean Attribute Set
■ JMX-MBean Create Instance
■ JMX-MBean Operation
■ POJO
■ RMI
■ Session Bean
■ Web Service
We recommend the payload producing job be a predecessor job to the payload
consuming job although it does not need to be an immediate predecessor.
Entity Bean Jobs
140 User Guide
The following diagram illustrates a job flow in which a payload consuming job named
Job C uses the output produced by payload producing jobs named Job A and Job B. In
this example, Job B is dependent on Job A and Job C is defined to take the output from
Job A as the value for the input parameter named inputParm1 and the output from Job
B as the value for the input parameter named inputParm2.
Entity Bean Jobs
An entity bean represents a data object, such as a customer, an order, or a product.
Entity beans may be stored in a relational database, where each instance of the bean
corresponds to a row in a database table. Each entity bean has a unique identifier
known as a primary key, which is used to find a specific instance of the bean within the
database. For example, a customer entity bean may use the customer number as its
primary key.
Unlike session beans, which are destroyed after use, entity beans are persistent. You
can use an entity bean under the following conditions:
■ The bean represents a business entity, not a procedure. For example, you use an
entity bean to represent an order and use a session bean to represent the
procedure to process the order.
■ The state of the bean must be stored. For example, if the bean instance terminates
or the application server shuts down, the bean's state will still exist in a database.
Entity Bean Jobs
The following diagram shows the functional relationship between the scheduling
manager, CA WA Agent for Application Services, and an entity bean residing on an
application server:
The Entity Bean job lets you create an entity bean, update the property values of an
existing entity bean, or remove an entity bean from the database. To find the entity
bean, the agent uses the bean's Java Naming and Directory Interface (JNDI) name along
with its finder method.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
To define an Entity Bean job, you require the following information:
■ Initial context factory supplied by the JNDI service provider
■ Service provider URL for accessing the JNDI services
■ Entity bean JNDI name
■ Operation type (CREATE, UPDATE, or REMOVE)
■ Finder method name (UPDATE and REMOVE operation types only)
Define an Entity Bean Job
You can define an Entity Bean (ENTYBEAN) job to create an entity bean, update the
property values of an existing entity bean, or remove an entity bean from the database.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: ENTYBEAN
Specifies that the job type is Entity Bean.
machine
Specifies the name of the machine on which the job runs.
bean_name
Specifies the JNDI name of the entity bean.
Entity Bean Jobs
142 User Guide
initial_context_factory
Specifies the initial context factory to use when creating the initial context. The
initial context is required within the Java Naming and Directory Interface (JNDI)
framework. The initial context factory is supplied by a specific provider of the
naming and directory service. The factory acquires an arbitrary initial context
that the application can use to connect to the application server.
operation_type
Specifies the operation to perform on the entity bean: CREATE, UPDATE,
REMOVE.
provider_url
Specifies the JNDI service provider URL.
2. Specify the following attributes if the operation_type attribute is set to CREATE:
create_name
(Optional) Specifies the name of the create method.
create_parameter
(Optional) Specifies create parameters to create an entity bean in a relational
database on your application server.
3. Specify the following attributes if the operation_type attribute is set to UPDATE:
finder_name
Specifies the name of the finder method.
finder_parameter
Specifies the finder parameters.
method_name
Specifies the method to be invoked on the application server.
modify_parameter
(Optional) Specifies the modify parameters.
4. Specify the following attributes if the operation_type attribute is set to REMOVE:
finder_name
Specifies the name of the finder method.
finder_parameter
(Optional) Specifies the finder parameters.
5. (Optional) Specify optional Entity Bean attributes:
■ j2ee_user
■ job_class
Entity Bean Jobs
6. (Optional) Specify common attributes that apply to all job types.
The Entity Bean job is defined. When the job runs, it creates an entity bean, updates
the property values of an existing entity bean, or removes an entity bean from the
database.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Create an Entity Bean
Suppose that you want to create an entity bean that stores information about a
customer such as the customer ID and phone number. The initial context factory
supplied by the JNDI service provider is weblogic.jndi.WLInitialContextFactory. The
service provider's URL is t3://localhost:7001, where localhost is the domain name of the
WebLogic application server and 7001 is the ORB port. When the job runs, the entity
bean instance is created.
insert_job: create
job_type: ENTYBEAN
machine: appagent
initial_context_factory: weblogic.jndi.WLInitialContextFactory
provider_url: "t3://localhost:7001"
bean_name: customer
create_name: createcustomer
operation_type: CREATE
create_parameter: String="customerid", String="800-555-0100" Entity Bean Jobs
144 User Guide
Example: Update an Entity Bean
Suppose that you want to update the phone number for the Acme company to
800-555-0199. The customer entity bean stores the customer ID and phone number.
The primary key for the customer is the customer ID. To find the entity bean, the job
uses the Acme's customer ID. When the job runs, the Acme company's phone number is
changed.
insert_job: update
job_type: ENTYBEAN
machine: appagent
initial_context_factory: weblogic.jndi.WLInitialContextFactory
provider_url: "t3://localhost:7001"
bean_name: customer
operation_type: UPDATE
method_name: changephone
finder_name: findByPrimaryKey
finder_parameter: String="customerid"
modify_parameter: String="800-555-0199"
Example: Remove an Entity Bean
Suppose that you want to remove the customer record for the Acme customer. The
record is stored in the database by the customer ID. When the job runs, the row in the
customer table that corresponds to the Acme customer ID is removed.
insert_job: remove
job_type: ENTYBEAN
machine: appagent
initial_context_factory: weblogic.jndi.WLInitialContextFactory
provider_url: "t3://localhost:7001"
bean_name: customer
operation_type: REMOVE
finder_name: findByPrimaryKey
finder_parameter: String="customerid"
More information:
Insert a Job Definition
HTTP Jobs
The HTTP job invokes a program over HTTP in a similar way to a web browser. For
example, you can use the HTTP job to invoke a CGI script, a Perl script, or a servlet. The
HTTP job sends a URL over HTTP using the GET method or a form over HTTP using the
POST method. The output of the invocation is returned in the job's spool file.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
The GET method requests data and sends the data as part of the URL. The POST method
submits data and is the preferred method for sending lengthy form data.
To define an HTTP job, you require the following information:
■ URL of the application server
■ Program or servlet to invoke
Note: If your company has a firewall and you must communicate through a proxy server
to access a computer outside the firewall, agent configuration is required. For more
information on configuring the agent for a proxy, see the CA Workload Automation
Agent for Application Services Implementation Guide.
Define an HTTP Job
You can define an HTTP job to invoke a program over HTTP.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: HTTP
Specifies that the job type is HTTP.
machine
Specifies the name of the machine on which the job runs.
provider_url
Specifies the host where the program or servlet you want to invoke resides.
HTTP Jobs
146 User Guide
2. (Optional) Specify optional HTTP attributes:
■ filter
■ invocation_type
■ j2ee_authentication_order
■ j2ee_conn_domain
■ j2ee_conn_origin
■ j2ee_conn_user
■ j2ee_no_global_proxy_defaults
■ j2ee_parameter
■ j2ee_proxy_domain
■ j2ee_proxy_host
■ j2ee_proxy_origin_host
■ j2ee_proxy_port
■ j2ee_proxy_user
■ job_class
■ method_name
3. (Optional) Specify common attributes that apply to all job types.
The HTTP job is defined. When the job runs, it invokes a program over HTTP.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
HTTP Jobs
Example: Define an HTTP Job to Perform a Google Search
Suppose that you want to define a job to perform a Google search and have the results
returned to the job's spool file. In this example, the job uses the HTTP GET method to
perform the Google search on "ca workload automation". When the job runs, the job's
spool file includes all the results of the search.
insert_job: google
job_type: HTTP
machine: appagent
invocation_type: GET
provider_url: "http://google.com/search"
j2ee_authentication_order: BASIC,DIGEST,NTLM
j2ee_parameter: q="ca workload automation"
Example: Define an HTTP Job to Subscribe to a Mailing List
Suppose that you want to define a job to subscribe to a mailing list located on a local
server. You want to add the email address test@abc.com to the list. The servlet path is
/examples/servlets/servlet/TheServlet.
insert_job: subscribe
job_type: HTTP
machine: appagent
invocation_type: POST
provider_url: "http://localhost:8080"
method_name: /examples/servlets/servlet/TheServlet
j2ee_parameter: key1="subscribe", key2="test@abc.com"
More information:
Insert a Job Definition (see page 88)
Attributes with Default Values
Attributes that have a default value automatically apply to the job definition. Therefore,
you do not have to specify those attributes in the definition. Your agent administrator
can define some default values on the agent in the agentparm.txt file.
If you specify the attribute in a job definition, it overrides the default.
HTTP Jobs
148 User Guide
The following HTTP job attributes have default values:
invocation_type
Specifies whether to send the URL over HTTP using the GET or POST method.
Default: POST
j2ee_conn_origin
Specifies the domain for NTLM connection authentication.
Default: The computer name where the agent is running
j2ee_no_global_proxy_defaults
Specifies whether to use the global proxy configuration specified by the proxy
parameters in the agentparm.txt file.
Default: Y (The job does not use the global proxy configuration specified by the
proxy parameters in the agentparm.txt file.)
j2ee_proxy_domain
Specifies the domain for proxy authentication.
Default: http.proxyDomain agent parameter, if specified
j2ee_proxy_host
Specifies the proxy host name to use for the request.
Default: http.proxyHost agent parameter, if specified
j2ee_proxy_origin_host
Specifies the origin host name for proxy authentication.
Default: The computer name where the agent is running
j2ee_proxy_port
Specifies the proxy port to use for the request.
Default: 80
j2ee_proxy_user
Specifies the user name required for proxy authentication.
Default: http.proxyUser agent parameter, if specified
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
HTTP Jobs
Example: Define an HTTP Job to Send a URL Over HTTP
Several attributes in the following job definition override the default values.
This example performs an HTTP query using the HTTP GET method. The output of the
invocation is returned in the job's spool file. In this example, the job specifies the
connection domain and origin for NTLM authentication, overrides the global proxy
defaults specified in the agentparm.txt file, and specifies the BASIC, DIGEST, and NTLM
protocols for web server authentication.
insert_job: HTTP.CON_USER
job_type: HTTP
machine: appagent
invocation_type: GET
provider_url: "http://host.example.com/protected"
j2ee_conn_origin: host.example.com
j2ee_conn_domain: windows_domain
j2ee_conn_user: myuser@windows_domain
j2ee_no_global_proxy_defaults: Y
j2ee_authentication_order: BASIC,DIGEST,NTLM
j2ee_proxy_domain: "http://host.domain.proxy"
j2ee_proxy_host: proxy.example.com
j2ee_proxy_origin_host: "http://host.origin.proxy"
j2ee_proxy_port: 90
j2ee_proxy_user: user01 JMS Publish and JMS Subscribe Jobs
150 User Guide
JMS Publish and JMS Subscribe Jobs
Java Message Service (JMS) is the standard for enterprise messaging that lets a Java
program or component (JMS client) produce and consume messages. Messages are the
objects that communicate information between JMS clients.
In a JMS system, a messaging server known as the JMS provider acts between two JMS
clients (the publisher and the subscriber). Publishers send messages to the JMS provider
while subscribers receive messages from the JMS provider.
The following diagram shows the functional relationship between the scheduling
manager, the CA WA Agent for Application Services, and a JMS provider:
A queue is an object on the JMS server that holds messages sent by a client that are
waiting to be consumed by another client. The queue retains a message until the
message is consumed or the message expires.
The following diagram shows Client 2 (the subscriber) consuming a message that Client
1 (the publisher) sends to a queue:
A topic is an object a client uses to specify the target of the messages it produces and
the source of the messages it consumes. A client acquires a reference to a topic on a
JMS server, and sends messages to that topic. When messages arrive for that topic, the
JMS provider is responsible for notifying all clients.
JMS Publish and JMS Subscribe Jobs
The following diagram shows two subscribers, Client 2 and Client 3, subscribed to a
topic that the publisher, Client 1, publishes to:
A JMS Publish job lets you send a message to a queue or publish a message to a topic.
Using a JMS Publish job to publish to a topic, you can broadcast a message to any topic
subscriber. A third-party client can consume this message, or a JMS Subscribe job can
listen for a particular message (using a filter).
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
The following diagram shows a JMS Publish job scenario:
A JMS Subscribe job lets you consume messages from a queue or topic. Using a filter
that you define within the job definition, the agent monitors the topic or queue output
for specific data. The scheduling manager then sends the message that meets the filter
criteria to a destination file you specify. You can define the job to continuously monitor
JMS messages.
JMS Publish and JMS Subscribe Jobs
152 User Guide
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
The following diagram shows a JMS Subscribe job scenario:
To define a JMS Publish or JMS Subscribe job, you require the following information:
■ Initial context factory supplied by the Java Naming and Directory Interface (JNDI)
service provider
■ JMS provider URL for accessing the JNDI services
■ Connection factory JNDI name that looks up the referenced topic or queue
■ JNDI name of the topic or queue on the JMS server
■ Java class of the JMS message to send or publish
JMS Publish and JMS Subscribe Jobs
Define a JMS Publish Job
You can define a JMS Publish job to send a message to a queue or publish a message to
a topic.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMSPUB
Specifies that the job type is JMS Publish.
machine
Specifies the name of the machine on which the job runs.
connection_factory
Specifies the connection factory JNDI name. The connection factory contains all
the bindings needed to look up the referenced topic or queue. JMS jobs use the
connection factory to create a connection with the JMS provider.
destination_name
Specifies the JNDI name of the topic or queue. The job uses the JNDI name to
indicate the destination where messages are received.
initial_context_factory
Specifies the initial context factory to use when creating the initial context. The
initial context is required within the Java Naming and Directory Interface (JNDI)
framework. The initial context factory is supplied by a specific provider of the
naming and directory service. The factory acquires an arbitrary initial context
that the application can use to connect to the application server.
j2ee_parameter
Specifies the message to send to a queue or publish to a topic.
message_class
Specifies the Java class of the JMS message.
provider_url
Specifies the JNDI service provider URL.
2. (Optional) Specify optional JMS Publish attributes:
■ j2ee_user
■ job_class
■ use_topic
JMS Publish and JMS Subscribe Jobs
154 User Guide
3. (Optional) Specify common attributes that apply to all job types.
The JMS Publish job is defined. When the job runs, it sends a message to a queue or
publishes a message to a topic.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
JMS Publish and JMS Subscribe Jobs
Example: Publish a Message to the WebSphere Application Server
This example publishes the message "this is my message" to the queue named Queue.
The Java class of the message is String. The initial context factory supplied by the JNDI
service provider is com.ibm.websphere.naming.WsnInitialContextFactory. The service
provider's URL is iiop://172.24.0.0:2809, where 172.24.0.0 is the IP address of the
WebSphere MQ server and 2809 is the ORB port. The job uses the cyberuser JNDI user
name to gain access to the connection factory named ConnectionFactory.
insert_job: publish
job_type: JMSPUB
machine: appagent
initial_context_factory: com.ibm.websphere.naming.WsnInitialContextFactory
provider_url: "iiop://172.24.0.0:2809"
connection_factory: ConnectionFactory
destination_name: Queue
use_topic: FALSE
message_class: String
j2ee_user: cyberuser
j2ee_parameter: java.lang.String="this is my message"
Note: The agent does not support JMS messaging on IBM WebSphere. If you have IBM
WebSphere MQ, your agent administrator can set up the agent plug-in to run JMS
Publish and JMS Subscribe for JMS queues. JMS topics are not supported on IBM
WebSphere MQ.
More information:
Insert a Job Definition (see page 88)
Define a JMS Subscribe Job
You can define a JMS Subscribe job to consume messages from a queue or topic.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMSSUB
Specifies that the job type is JMS Subscribe.
machine
Specifies the name of the machine on which the job runs.
JMS Publish and JMS Subscribe Jobs
156 User Guide
connection_factory
Specifies the connection factory JNDI name. The connection factory contains all
the bindings needed to look up the referenced topic or queue. JMS jobs use the
connection factory to create a connection with the JMS provider.
destination_name
Specifies the JNDI name of the topic or queue. The job uses the JNDI name to
indicate the destination where messages are received.
initial_context_factory
Specifies the initial context factory to use when creating the initial context. The
initial context is required within the Java Naming and Directory Interface (JNDI)
framework. The initial context factory is supplied by a specific provider of the
naming and directory service. The factory acquires an arbitrary initial context
that the application can use to connect to the application server.
provider_url
Specifies the JNDI service provider URL.
2. (Optional) Specify optional JMS Subscribe attributes:
■ continuous
■ destination_file
■ filter
■ j2ee_user
■ job_class
■ job_terminator
■ use_topic
3. (Optional) Specify common attributes that apply to all job types.
The JMS Subscribe job is defined. When the job runs, it consumes messages from a
queue or topic.
JMS Publish and JMS Subscribe Jobs
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Monitor a Queue on a WebLogic Application Server
This example continuously monitors the queue named Queue (residing on WebLogic)
for a message matching the filter criteria. The consumed messages from the queue are
stored in the file /export/home/user1/outputfile1. The service provider's URL is
t3://172.24.0.0:7001, where 172.24.0.0 is the IP address of the WebLogic Application
server and 7001 is the ORB port.
insert_job: monitor
job_type: JMSSUB
machine: appagent
initial_context_factory: weblogic.jndi.WLInitialContextFactory
provider_url: "t3://172.24.0.0:7001"
connection_factory: ConnectionFactory
destination_name: Queue
continuous: Y
filter: abc\s...\s[a-zA-Z]+\sFilter![\sa-z0-9]+
use_topic: FALSE
destination_file: /export/home/user1/outputfile1
j2ee_user: cyberuser JMS Publish and JMS Subscribe Jobs
158 User Guide
In this example, the regular expression used as the filter criteria can be defined as
follows:
abc\s...\s[a-zA-Z]+\sFilter![\sa-z0-9]+
abc\s
Specifies the text abc, followed by white space.
...\s
Specifies any three characters, followed by white space.
[a-zA-Z]+\s
Specifies at least one letter, followed by white space.
Filter![\sa-z0-9]+
Specifies the text Filter!, followed by at least one of the following: white space or
digit or lower case letter.
Example: abc vvv B Filter! 95
More information:
Insert a Job Definition (see page 88)
Attributes with Default Values
Attributes that have a default value automatically apply to the job definition. Therefore,
you do not have to specify those attributes in the definition. Your agent administrator
can define some default values on the agent in the agentparm.txt file.
If you specify the attribute in a job definition, it overrides the default.
The following JMS job attributes have default values:
continuous (JMS Subscribe jobs only)
Specifies whether the job monitors the topic or queue continuously for messages.
Default: N (The job immediately checks for the condition and completes.)
job_terminator (JMS Subscribe jobs only)
Specifies whether to terminate the job if its containing box fails or terminates.
Default: n (The job does not terminate if its containing box fails or terminates.)
destination_file (JMS Subscribe jobs only)
Specifies the output destination file for the consumed messages.
Default: spooldir agent parameter, if specified
JMS Publish and JMS Subscribe Jobs
use_topic
Specifies whether to send or publish messages to a topic or queue.
Default: FALSE (The job sends or publishes messages to a queue.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Example: Specify Optional Attributes in a JMS Subscribe Job
The continuous and destination_file attributes in the following job definition override
the default values.
This example continuously monitors the queue named Queue (residing on WebLogic)
for a message matching the filter criteria. The consumed messages from the queue are
stored in the file /export/home/user1/outputfile1. The service provider's URL is
t3://172.24.0.0:7001, where 172.24.0.0 is the IP address of the WebLogic Application
server and 7001 is the ORB port.
insert_job: monitor
job_type: JMSSUB
machine: appagent
initial_context_factory: weblogic.jndi.WLInitialContextFactory
provider_url: "t3://172.24.0.0:7001"
connection_factory: ConnectionFactory
destination_name: Queue
continuous: Y
filter: abc\s...\s[a-zA-Z]+\sFilter![\sa-z0-9]+
use_topic: FALSE
destination_file: /export/home/user1/outputfile1
j2ee_user: cyberuser JMX Jobs
160 User Guide
In this example, the regular expression used as the filter criteria can be defined as
follows:
abc\s...\s[a-zA-Z]+\sFilter![\sa-z0-9]+
abc\s
Specifies the text abc, followed by white space.
...\s
Specifies any three characters, followed by white space.
[a-zA-Z]+\s
Specifies at least one letter, followed by white space.
Filter![\sa-z0-9]+
Specifies the text Filter!, followed by at least one of the following: white space or
digit or lower case letter.
Example: abc vvv B Filter! 95
JMX Jobs
Java Management Extension (JMX) technology is included in the Java Standard Edition
(SE) platform, version 5 and higher. JMX lets you remotely access applications, using a
Remote Method Invocation (RMI) connector, for monitoring and management
purposes.
JMX jobs let you access a remote JMX server that advertises MBeans. An MBean is a
managed bean (Java object) that represents an application, a device, or any resource
that you want to manage. An MBean contains a set of attributes and a set of operations
that can be invoked. Some MBeans can send out notifications, for example, when an
attribute changes.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Consider an MBean named Config that represents an application's configuration. The
configuration parameters within that application are represented in Config by a set of
attributes. Getting the attribute named cachesize, for example, returns the current
value of the cachesize. Setting the value updates the cachesize. The Config MBean can
send out a notification every time the cachesize changes. An operation named update,
for example, can save changes to the configuration parameters.
JMX Jobs
The following diagram shows the functional relationship between the scheduling
manager, CA WA Agent for Application Services, and the JMX server:
The JMX jobs provide support for getting and setting JMX MBean attributes, invoking
JMX MBean operations, subscribing to MBean notifications, and creating and removing
instances of MBeans on a JMX server.
You can define the following six types of JMX jobs:
■ JMX-MBean Attribute Get
■ JMX-MBean Attribute Set
■ JMX-MBean Create Instance
■ JMX-MBean Operation
■ JMX-MBean Remove Instance
■ JMX-MBean Subscribe
The JMX-MBean Attribute Set, JMX-MBean Create Instance, and JMX-MBean Operation
jobs support calls to MBeans that can involve passing parameters. Each parameter can
be an actual value or a serialized Java object passed by another job. When the
JMX-MBean Operation job invokes an operation on an MBean that passes parameters,
the parameters are passed to the MBean and the returned serialized Java object is
stored on the agent computer in the spool directory or in a destination file you specify.
To define JMX jobs, you require a URL to connect to the JMX server using an RMI
connector.
Define a JMX-MBean Attribute Get Job
You can define a JMX-MBean Attribute Get job to query a JMX server for the value of an
MBean attribute. The returned value is stored on the computer where the agent
resides. You can specify a success pattern to determine the job's success or failure. If the
returned attribute value matches the success pattern, the job completes successfully;
otherwise, it fails.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
JMX Jobs
162 User Guide
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMXMAG
Specifies that the job type is JMX-MBean Attribute Get.
machine
Specifies the name of the machine on which the job runs.
mbean_attr
Specifies the name of the MBean attribute that you want to query.
mbean_name
Specifies the full object name of an MBean.
URL
Specifies the URL to connect to the JMX server using an RMI connector.
2. (Optional) Specify optional JMX-MBean Attribute Get attributes:
■ job_class
■ jmx_user
■ success_pattern
3. (Optional) Specify common attributes that apply to all job types.
The JMX-MBean Attribute Get job is defined. When the job runs, it queries a JMX
server for the value of an MBean attribute.
JMX Jobs
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Query a JMX Server for the Value of an MBean Attribute
Suppose that you want to know the value of the cachesize attribute for the Config
MBean. The URL for the JMX server is
service:jmx:rmi:///jndi/rmi://localhost:9999/server, where localhost is the host name
and 9999 is the port number.
insert_job: query
job_type: JMXMAG
machine: appagent
URL: "service:jmx:rmi:///jndi/rmi://localhost:9999/server"
mbean_name: "DefaultDomain:index=1,type=Config"
mbean_attr: cachesize
More information:
Insert a Job Definition (see page 88)
JMX Jobs
164 User Guide
Define a JMX-MBean Attribute Set Job
You can define a JMX-MBean Attribute Set job to change the value of an MBean
attribute on a JMX server. You can specify a set value for the attribute or use the
serialized Java object passed by another job. When the attribute is set, the job returns
the original attribute value as output. You can specify a success pattern to determine
the job's success or failure. If the job's output matches the success pattern, the job
completes successfully; otherwise, it fails.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMXMAS
Specifies that the job type is JMX-MBean Attribute Set.
machine
Specifies the name of the machine on which the job runs.
mbean_attr
Specifies the name of the MBean attribute that you want to set.
mbean_name
Specifies the full object name of an MBean.
URL
Specifies the URL to connect to the JMX server using an RMI connector.
2. (Optional) Specify optional JMX-MBean Attribute Set attributes:
■ jmx_parameter
■ jmx_user
■ job_class
■ success_pattern
3. (Optional) Specify common attributes that apply to all job types.
The JMX-MBean Attribute Set job is defined. When the job runs, it changes the
value of an MBean attribute on a JMX server.
JMX Jobs
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Change the Value of an MBean Attribute
Suppose that you want to set the value of the State attribute of the
cdc.jmx.SimpleDynamic MBean to the serialized Java object returned by a JMX-MBean
Attribute Set job named size.
insert_job: change
job_type: JMXMAS
machine: appagent
URL: "service:jmx:rmi:///jndi/rmi://agenttest:5099/jmxserver"
mbean_name: "DefaultDomain:index=1,type=cdc.jmx.SimpleDynamic"
mbean_attr: State
jmx_parameter: payload_job=size
condition: success(size)
More information:
Insert a Job Definition (see page 88)
JMX Jobs
166 User Guide
Define a JMX-MBean Create Instance Job
You can define a JMX-MBean Create Instance job to create an MBean on a JMX server.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMXMC
Specifies that the job type is JMX-MBean Create Instance.
machine
Specifies the name of the machine on which the job runs.
class_name
Specifies the fully qualified Java class of the MBean object.
mbean_name
Specifies the full object name of an MBean.
URL
Specifies the URL to connect to the JMX server using an RMI connector.
2. (Optional) Specify optional JMX-MBean Create Instance attributes:
■ jmx_parameter
■ jmx_user
■ job_class
3. (Optional) Specify common attributes that apply to all job types.
The JMX-MBean Create Instance job is defined. When the job runs, it creates an
MBean on a JMX server.
JMX Jobs
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Create an MBean Instance on a JMX Server
Suppose that you want to create an MBean instance on a JMX server. The job uses the
cdc.jmx.SimpleDynamic class. The constructor of the class takes a single string
parameter with the value "Hello".
insert_job: create
job_type: JMXMC
machine: appagent
URL: "service:jmx:rmi:///jndi/rmi://agenttest:5099/jmxserver"
mbean_name: "DefaultDomain:index=CreateIns1,type=cdc.jmx.SimpleDynamic"
class_name: cdc.jmx.SimpleDynamic
jmx_parameter: java.lang.String="Hello"
More information:
Insert a Job Definition (see page 88)
JMX Jobs
168 User Guide
Define a JMX-MBean Operation Job
You can define a JMX-MBean Operation job to invoke an operation on an MBean. You
can specify one or more parameter values to pass to the operation. You can specify a
success pattern to determine the job's success or failure. If the operation's output
matches the success pattern, the job completes successfully; otherwise, it fails.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMXMOP
Specifies that the job type is JMX-MBean Operation.
machine
Specifies the name of the machine on which the job runs.
mbean_name
Specifies the full object name of an MBean.
mbean_operation
Specifies the operation to be invoked.
URL
Specifies the URL to connect to the JMX server using an RMI connector.
2. (Optional) Specify optional JMX-MBean Operation attributes:
■ jmx_parameter
■ jmx_user
■ job_class
■ success_pattern
3. (Optional) Specify common attributes that apply to all job types.
The JMX-MBean Operation job is defined. When the job runs, it invokes an
operation on an MBean.
JMX Jobs
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Invoke an Operation on an MBean
Suppose that you want to invoke the resetmem operation on the config MBean to reset
the value of the memory parameter to 50.
insert_job: reset
job_type: JMXMOP
machine: agent
URL: "service:jmx:rmi:///jndi/rmi://localhost:9999/server"
mbean_name: "DefaultDomain:index=1,type=Config"
mbean_operation: resetmem
jmx_parameter: Integer=50 JMX Jobs
170 User Guide
Example: Pass Payload Producing Output as Input to Payload Consuming Job
Suppose that you want to use a JMX-MBean Operation job to invoke a method on an
MBean and pass the output of the method as input to another JMX-MBean Operation
job.
In this example, the first job, test_JMXMOP2a, is a payload producing job. It takes a
single input parameter and invokes the reset method on the MBean. The output of this
job is stored as a serialized Java object on the computer where the agent resides.
The second job, test_JMXMOP2b, is a payload consuming job. It takes two input
parameters: the string "Hello" and the serialized Java object produced by the first job.
The two input parameters are passed to the reset method, which is invoked on the
MBean.
insert_job: test_JMXMOP2a
machine: localhost
job_type: JMXMOP
url: "service:jmx:rmi:///jndi/rmi://localhost:9999/server"
mbean_name: "DefaultDomain:type=SimpleStandard,index=1"
mbean_operation: reset
jmx_parameter: String="Hello"
insert_job: test_JMXMOP2b
machine: localhost
job_type: JMXMOP
url: "service:jmx:rmi:///jndi/rmi://localhost:9999/server"
mbean_name: "DefaultDomain:type=SimpleStandard,index=1"
mbean_operation: reset
jmx_parameter: String="Hello", payload_job=test_JMXMOP2a
condition: S(test_JMXMOP2a)
More information:
Insert a Job Definition
JMX Jobs
Define a JMX-MBean Remove Instance Job
You can define a JMX-MBean Remove Instance job to remove an MBean from a JMX
server.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMXMREM
Specifies that the job type is JMX-MBean Remove Instance.
machine
Specifies the name of the machine on which the job runs.
mbean_name
Specifies the full object name of an MBean.
URL
Specifies the URL to connect to the JMX server using an RMI connector.
2. (Optional) Specify optional JMX-MBean Remove Instance attributes:
■ jmx_user
■ job_class
3. (Optional) Specify common attributes that apply to all job types.
The JMX-MBean Remove Instance job is defined. When the job runs, it removes an
MBean from a JMX server.
JMX Jobs
172 User Guide
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Remove an MBean Instance from a JMX Server
Suppose that you want to remove an MBean instance.
insert_job: remove
job_type: JMXMREM
machine: appagent
URL: "service:jmx:rmi:///jndi/rmi://agenttest:5099/jmxserver"
mbean_name: "DefaultDomain:index=CreateIns1,type=cdc.jmx.SimpleDynamic"
More information:
Insert a Job Definition (see page 88)
Define a JMX-MBean Subscribe Job
You can define a JMX-MBean Subscribe job to monitor an MBean for a single
notification or monitor continuously for notifications. You can filter the notifications the
job monitors by attributes or by type of notifications.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Application Services.
JMX Jobs
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: JMXSUB
Specifies that the job type is JMX-MBean Subscribe.
machine
Specifies the name of the machine on which the job runs.
mbean_name
Specifies the full object name of an MBean.
URL
Specifies the URL to connect to the JMX server using an RMI connector.
2. (Optional) Specify optional JMX-MBean Subscribe attributes:
■ continuous
■ filter
■ filter_type
■ jmx_user
■ job_class
■ job_terminator
3. (Optional) Specify common attributes that apply to all job types.
The JMX-MBean Subscribe job is defined. When the job runs, it monitors an MBean
for a single notification or continuously for notifications.
JMX Jobs
174 User Guide
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Monitor for a Change to a Specific MBean Attribute
Suppose that you want to monitor for a change to the cachesize attribute of the MBean
named Config. The job filters the notifications the MBean sends by attribute. When the
cachesize attribute changes, the job completes.
insert_job: change
job_type: JMXSUB
machine: agent
URL: "service:jmx:rmi:///jndi/rmi://localhost:9999/server"
mbean_name: "DefaultDomain:index=1,type=Config"
filter_type: Attributes
filter: cachesize
More information:
Insert a Job Definition (see page 88)
Attributes with Default Values
Attributes that have a default value automatically apply to the job definition. Therefore,
you do not have to specify those attributes in the definition. Your agent administrator
can define some default values on the agent in the agentparm.txt file.
If you specify the attribute in a job definition, it overrides the default.
JMX Jobs
The following JMX Subscribe job attributes have default values:
continuous
Specifies whether the job monitors the MBean continuously for notifications.
Default: N (The job immediately checks for the condition and completes.)
filter_type
Specifies whether to filter notifications by attribute or by notification type.
Default: Attributes (The job filters notifications by attribute.)
job_terminator
Specifies whether to terminate the job if its containing box fails or terminates.
Default: n (The job does not terminate if its containing box fails or terminates.)
destination_file
Specifies the output destination file for the Java serialized object produced by the
job.
Default: spooldir agent parameter, if specified
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Example: Monitor for Changes to Any MBean Attribute
The continuous attribute in the following job definition overrides the default value.
Suppose that you want to set up continuous monitoring for changes to any attribute of
the MBean named Config. Each time an attribute changes, an alert is written to the
scheduler log file.
insert_job: change
job_type: JMXSUB
machine: appagent
URL: "service:jmx:rmi:///jndi/rmi://localhost:9999/server"
mbean_name: "DefaultDomain:index=1,type=Config"
continuous: Y
filter_type: Types
filter: jmx.attribute.change POJO Jobs
176 User Guide
POJO Jobs
A Plain Old Java Object (POJO) is a Java object that follows the Java Language
Specification only. All Java objects are POJOs.
The POJO job lets you instantiate a class to create a Java object and invoke a method on
it. The job is restricted to classes that take constructors with no arguments (default
constructors).
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and either CA WA Agent for Application Services or CA WA Agent for Web Services.
You can use the POJO job to invoke custom Java code on a local computer. POJO jobs
support method calls that can involve passing parameters. The parameters can be actual
values or a serialized Java object passed by another job. When the POJO job invokes a
method on an object, the parameters, if any, are passed to the object and the returned
values are stored in a Java serialized object file.
To define a POJO job, you require the class name and method you want to call on the
instantiated object.
Note: If you use custom Java code, contact your agent administrator to verify the
required JAR file is available in the jars subdirectory of the agent installation directory.
Define a POJO Job
You can define a POJO job to create a Java object instance with no arguments, invoke a
method on the object instance, and store the method's output.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and either CA WA Agent for Application Services or CA WA Agent for Web Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: POJO
Specifies that the job type is POJO.
machine
Specifies the name of the machine on which the job runs.
class_name
Specifies the Java class to instantiate.
method_name
Specifies the Java method to call on the instance of the Java object.
POJO Jobs
A Box job (or box) is a container of other jobs. You can use it to organize and control
process flow. The box itself performs no actions, although it can trigger other jobs to
run. An important feature of this type of job is that boxes can contain other boxes. You
can use boxes to contain other boxes that contain jobs related by starting conditions or
other criteria. This feature lets you group the jobs and operate on them in a logical
manner.
Box jobs are powerful tools for organizing, managing, and administering large numbers
of jobs that have similar starting conditions or complex logic flows. Knowing how and
when to use boxes is often the result of some experimentation.
For example, assume you want to schedule a group of jobs to start running when a File
Watcher job completes successfully. Instead of making each job dependent on the File
Watcher job, you can create a Box job that is dependent on the File Watcher job,
remove the File Watcher job dependency from the individual jobs, and put all of those
jobs in the box. When the File Watcher job completes successfully, the Box job starts,
which in turn starts all the jobs it contains.
Starting Conditions for Box Jobs
When no other starting conditions are specified at the job level, a job in a box runs
when the starting conditions for the box are satisfied. When several jobs in a box do not
have job-level starting conditions, they all run in parallel. When any job in a box changes
state, other jobs check if they are eligible to start running.
Basic Box Concepts
Jobs in boxes run only once for each box execution. If you specify multiple start times
for a job during one box processing cycle, only the first start time is used. This prevents
jobs in boxes from inadvertently running multiple times.
CA Workload Automation AE starts a job when the current time matches, or is later
than, the specified start time. In addition to explicit starting conditions, jobs in boxes
have the implicit condition that the box job itself is running. This means that jobs in a
box start only if the box job is running. However, if a job in a box starts and the box job
is stopped, the started job runs to completion.
Note: Use caution when putting a job with more than one time-related starting
condition in a box. For example, assume that a job that runs at 15 and 45 minutes past
the hour is put in a box that runs at the start of every hour. The first time the box starts,
the job runs at 15 minutes past the hour. A future start is then issued for 45 minutes
past the hour, by which time the box has completed. As a result, the job will not run
until the box runs again at the start of the next hour. At that time, the job runs as soon
as the box starts because it is past its start time. The job runs, another future start job is
issued for 15 minutes past the hour, the box completes, and the cycle repeats itself.
More information:
Box Job Attributes and Terminators (see page 192)
Do not put jobs in a box solely to run reports on all of them. When you run autorep on a
box, the command generates a report about the box and all the jobs it contains (unless
you use the -L0 option).
Note: Job names can only contain the following characters: a-z, A-Z, 0-9, period (.),
underscore (_), and hyphen (-). You cannot include spaces in a job name.
When a box starts running, the system performs the following actions:
■ Analyzes each job for additional starting conditions.
■ Starts all jobs with no additional starting conditions and without any implied order
or priority.
■ Maintains jobs with additional starting conditions in the ACTIVATED state until
those additional dependencies are met.
■ Maintains the box in the RUNNING state as long as there are jobs in it with
ACTIVATED or RUNNING status.
■ Changes the status of the job directly from ACTIVATED to INACTIVE if its containing
box is terminated before the job starts.
Notes:
■ Jobs in a box cannot start unless the box has a status of RUNNING. However, after a
job starts running, it runs to completion even if the box is stopped.
■ When the box is scheduled to run, the statuses of ON_NOEXEC jobs in the box
change to ACTIVATED. If the box is terminated before the jobs start, the jobs return
to ON_NOEXEC status.
■ When a box that is in ON_NOEXEC status is scheduled to run, the status of the box
changes to RUNNING. Jobs in the box with additional starting conditions remain in
the ACTIVATED state until those additional conditions are met. Once CA Workload
Automation AE bypasses the last scheduled job in the box, the box status returns to
ON_NOEXEC.
■ When a box that is in ON_NOEXEC status is scheduled to run, CA Workload
Automation AE bypasses all scheduled jobs in that box and returns them to the
ON_NOEXEC status regardless of manual status changes to individual jobs issued
after the box has been put in ON_NOEXEC status.
After all the jobs in a box have completed successfully, the box completes with a status
of SUCCESS. The status of the box and the jobs it contains remain unchanged until the
next time the box runs.
If a box changes to TERMINATED state (for example, if a user sends a KILLJOB event), it
stays in TERMINATED state until the next time it is started, regardless of any later state
changes of the jobs it contains.
Basic Box Concepts
When simple_box starts running, the status of all the jobs changes to ACTIVATED.
Because job_a and job_b have no additional starting conditions, they start running.
When job_b completes successfully, job_c starts. When job_c completes successfully,
the box completes with a SUCCESS status.
If job_b fails, job_c does not start but remains in the ACTIVATED state. Because no
contingency conditions have been defined, simple_box continues running, waiting for
the default completion criteria (that all jobs in the box have run) to be met.
More information:
How Job Status Changes Affect Box Status (see page 191)
If a box contained only one job, and the job changed status, the box status would
change as shown in the following table:
If the box contains other jobs in addition to the job that changed status, the status of
the box is evaluated again according to the success or failure conditions assigned to the
box (either the default or user-assigned). Any jobs in the box with a status of INACTIVE
are ignored when the status of the box is being re-evaluated. For example, consider an
INACTIVE box that contains four jobs, all with a status of INACTIVE (this is typical of a
newly created box). If one of the jobs is forced to start and completes successfully, the
status of the box changes to SUCCESS even though none of the other jobs ran.
Note: When a box that is in ON_NOEXEC status is scheduled to run, CA Workload
Automation AE bypasses all scheduled jobs in the box and returns them to ON_NOEXEC
status regardless of manual status changes made to individual jobs in the box after the
box is placed in ON_NOEXEC status.
Example: Set the Success of a Specific Job in a Box Job as the Success Condition for
that Box Job
This example defines a box job named box_a, sets the success of the job named job_a as
the success condition for box_a, and defines the jobs named job_a, and job_b as jobs
that are contained in box_a.
insert_job: box_a
job_type: b
box_success: success(job_a)
insert_job: job_a
box_name: box_a
command: sleep 15
machine: machine1
insert_job: job_b
box_name: box_a
command: sleep 60
machine: machine1
CA Workload Automation AE evaluates the success of box_a when job_a completes,
regardless of the state of job_b. box_a enters the SUCCESS state when job_a enters the
SUCCESS state.
The success condition is not met when job_a enters a completion state other than
SUCCESS (such as FAILURE or TERMINATED). In this case, CA Workload Automation AE
evaluates the overall failure according to the default behavior (after job_b also
completes) because the job definition does not specify a failure condition. box_a enters
the FAILURE state because the default failure condition for box_a was met when job_a
entered the FAILURE state.
Example: Set the Failure of an External Job as the Failure Condition for a Box Job
This example defines a box job named box_a, sets the failure of the external job named
job_c^ACE as the failure condition for box_a, and defines the jobs named job_a and
job_b as jobs that are contained in box_a.
insert_job: box_a
job_type: b
box_failure: failure(job_c^ACE)
insert_job: job_a
box_name: box_a
command: sleep 60
machine: machine1
insert_job: job_b
box_name: box_a
command: sleep 300
machine: machine1 Box Job Attributes and Terminators
CA Workload Automation AE evaluates the overall failure of box_a when either job_a or
job_b completes. box_a enters the FAILURE state when job_c from the external instance
named ACE enters the FAILURE state before CA Workload Automation AE evaluates
box_a.
The failure condition is not met when one of the following situations occur:
■ Job_c enters a completion state other than SUCCESS (such as FAILURE or
TERMINATED), regardless of the completion state of job_a or job_b.
■ Job_c enters the FAILURE state after both job_a and job_b complete.
In these cases, CA Workload Automation AE evaluates the overall success of box_a
according to the default behavior (after job_a and job_b complete) because the job
definition does not specify a the box_success attribute. box_a enters the SUCCESS state
when job_a and job_b both complete and enter the SUCCESS state. box_a remains in a
RUNNING status when either job_a or job_b enters a state other than success because
the neither the failure condition specified in the box_failure attribute nor the default
success condition were met.
Example: Set the Failure of a Specific Job that is not contained in the Box Job as the
Success Condition for that Box Job
This example defines a box job named box_a, sets the success of a job that is outside of
box_a and is named job_d as the success condition for box_a, and defines the jobs
named job_a and job_b as jobs that are contained in box_a.
insert_job: box_a
job_type: b
box_success: failure(job_d)
insert_job: job_a
box_name: box_a
command: sleep 60
machine: machine1
insert_job: job_b
box_name: box_a
command: sleep 300
machine: machine1
insert_job: job_d
command: sleep 5
machine: machine2
CA Workload Automation AE evaluates the overall success of box_a when either job_a
or job_b completes. box_a enters the SUCCESS state when job_d enters the FAILURE
before the job that triggers the evaluation completes. Box Job Attributes and Terminators
The success condition is not met when job_d enters a terminal state other than
FAILURE, regardless of whether or not job_a or job_b completes. In this case CA
Workload Automation AE evaluates the overall failure of box_a according to the default
behavior (after job_a and job_b complete) because the job definition does not specify
the box_failure attribute. box_a enters the FAILURE state when the completion state of
either job_a or job_b is not SUCCESS. box_a remains in the RUNNING state when both
job_a and job_b complete and enter the SUCCESS state because the success condition
was not met.
Example: Set a Global Variable as the Failure Condition for a Box Job
This example defines a box job named box_a, sets the global variable named TEST with a
value of ABC as the failure condition for box_a, and defines the jobs named job_a and
job_b as jobs that are contained in box_a.
insert_job: box_a
job_type: b
box_failure: v(TEST) = ABC
insert_job: job_a
box_name: box_a
command: sleep 300
machine: machine
insert_job: job_b
box_name: box_a
command: sleep 600
machine: machine
CA Workload Automation AE evaluates the overall failure of box_a when either job_a or
job_b completes, regardless of the state of the other job that is contained in the box.
box_a enters the FAILURE state when the global variable named TEST evaluates to value
ABC before job_a or job_b completes.
The failure condition is not met when one of the following situations occurs:
■ TEST evaluates to a value other than ABC, regardless of the completion state of
job_a or job_b.
■ TEST evaluates to ABC after both job_a and job_b complete.
In these cases, CA Workload Automation AE evaluates the overall success of box_a
according to default behavior (after job_a and job_b complete) because the job
definition does not specify the box_success attribute. box_a enters the SUCCESS state
when job_a and job_b complete and enter the SUCCESS state. box_a remains in the
RUNNING state when either job_a or job_b enter a completion state other than
SUCCESS because neither the failure condition specified in the box_failure attribute nor
the default success condition were met.
Box Job Attributes and Terminators
job_terminator: y
Specifies that if the job's containing box completes with a FAILURE or TERMINATED
status, the job terminates. You must add this attribute to each job definition that
you want to terminate upon box failure.
Notes:
■ If a job defined with the job_terminator attribute is in ON_NOEXEC status, the job
does not terminate when the box fails.
■ If a job defined with the box_terminator attribute is in ON_NOEXEC status, then CA
Workload Automation AE bypasses the job and the job's containing box does not
terminate.
More information:
Job Flow with Box Terminator Attribute (see page 204)
Job Flow with Job Terminator Attribute (see page 203)
In the illustration, job_a is defined to run repeatedly until it succeeds; job_report has
one starting condition, the success of job_a.
At 3:00 a.m., bx_stat starts running, which causes job_a to start running. If job_a is
successful, job_report runs and also succeeds.
If job_a fails, it will not be able to run again until the next time the box starts because
jobs run only once per box execution. In this situation, the following occurs:
■ Job job_report is still ACTIVATED while it waits for the success of job_a, and the
status of the box is RUNNING.
■ Because job_a is defined as a box terminator, the box then enters into a
TERMINATED state.
■ This change also terminates job job_report because its job_terminator attribute is
set to y.
■ Box bx_stat is now in a state that permits it to run again at 3:00 a.m. the following
day.
If job_a was not defined as a box terminator, the box remains in RUNNING state
indefinitely.
run_stats
Runs statistics. This job starts when update_accounts completes successfully. It has
no other starting conditions.
Box Job Flow Examples
No conditions for success or failure have been defined for do_statistics; therefore the
default conditions are applied. The box job completes successfully when all the jobs it
contains have run and completed successfully. The box job fails when all jobs in the box
have run and at least one has failed. The box job remains in the RUNNING state until all
the jobs it contains have run.
run_stats
Runs statistics. This job starts when update_accounts completes successfully. It has
no other starting conditions.
report_stats
Reports statistics. This job starts when run_stats completes successfully. It has no
other starting conditions.
The following conditions define the criteria for success or failure of the box job
do_statistics:
■ The box job can complete successfully only when all of the jobs it contains have
completed successfully.
■ The box job fails if any of the jobs it contains fails.
Box Job Flow Examples
The following illustration shows the job definitions and the job flow:
Box Job Flow Examples
daily_payables
Processes payables. This job runs when daily_accounts starts because it has no
other starting conditions. Because daily_payables includes a job_terminator
attribute, daily_account is terminated if this job fails.
A third job, daily_balance, is not contained in daily_accounts and runs only if both
daily_receipts and daily_payables complete successfully.
Because daily_accounts can only complete successfully if both of the jobs it contains
complete successfully, the failure of daily_receipts causes daily_accounts to fail. This in
turn triggers the job_terminator attribute in daily_payables, which terminates the job if
the box that contains it fails.
Box Job Flow Examples
The following illustration shows the job definitions and the job flow:
daily_payables
Processes payables. This job runs when daily_accounts starts because it has no
other starting conditions. Because daily_payables includes a box_terminator
attribute, daily_accounts will be terminated if this job fails.
Advanced Job Flows
A third job, daily_balance, is not contained in daily_accounts and will run only if both
daily_receipts and daily_payables complete successfully.
The following illustration shows the job definitions and the job flow:
Job Flow with Time Conditions Running on the First of the Month
This scenario is an example of a job flow that begins on the first of every month.
job_monthly
Re-indexes, organizes, and purges its records based on the file created by the
mainframe. This job runs at 2:00 a.m. on the first of the month only when
job_Fwatch completes successfully.
job_daily
Generates a report. This job runs daily at 3:00 a.m. when job_monthly completes
successfully.
Advanced Job Flows
The failure of job_Fwatch causes job_monthly to skip its scheduled run because
job_monthly can only complete successfully if job_Fwatch completes successfully. Job
job_daily only runs if job_monthly completes successfully. By the same logic, job_daily
always runs if job_monthly was able to successfully run at least once.
Note: The first time the cycle is run (for example, January 1), statuses behave as
expected.
Job Flow with Time Conditions Running on the Second of the Month
This scenario builds upon the previous scenario and takes place on the following day.
On days of the month other than the first, job_Fwatch and job_monthly do not run.
They still have a status of SUCCESS in the database from the previous run on the first
day of the month. As a result, job_daily still runs.
Advanced Job Flows
Job Flow with Time Conditions Running on the First of the Following Month
This scenario builds upon the previous scenario and takes place on the first day of the
following month.
On the first day of the next month (for example, February 1), the file from the
mainframe fails to arrive in the 90 minute wait time; therefore, job_Fwatch
self-terminates. As a result, job_monthly misses its run for the month. However,
because its event status in the database is still SUCCESS from the previous month,
job_daily is able to run every day this month. When job_daily runs, it uses the previous
month's data leading to invalid reports for the month.
Resetting a Job Flow with Time Conditions Through INACTIVE Status Change
This scenario builds upon the previous scenario and takes place on the last day of the
month.
To fix time-related statuses, you can use a sendevent command to change them to
INACTIVE at the end of their valid interval. You can create another job to do this
automatically.
Changing the status of job_monthly to INACTIVE at the end of every month allows
job_daily to run only in the months that job_monthly completes successfully. In the
following example, when job_Fwatch fails, job_monthly will not run, job_daily will not
run because its status has been reset to INACTIVE.
The job flow now consists of a box called box_monthly that runs at 1:00 a.m. on the first
day of every month with the following jobs:
job_Fwatch
Waits for a specific file to be created by some mainframe process. This job runs at
1:00am on the first of every month and waits for 90 minutes before giving up.
job_monthly
Re-indexes, organizes, and purges its records based on the file created by the
mainframe. This job runs at 2:00 a.m. on the first of the month only when
job_Fwatch completes successfully.
A third job, job_daily, is not contained in box_monthly and runs only if job_Fwatch and
job_monthly complete successfully.
Advanced Job Flows
job_type: BOX
Specifies that the job type is box.
Note: If you omit this attribute, the job type defaults to cmd (Command job).
How Job Groupings Are Created
condition
Defines the dependency conditions that must be met for the job to run.
Note: The condition attribute is not always required, for example when a job is
always started manually.
Command Jobs
Command jobs let you run workload on UNIX and Windows client computers. On UNIX,
you can define jobs to run scripts and commands. On Windows, you can define jobs to
run command files and batch files.
Note: To run these jobs, your system requires one of the following:
■ CA WA Agent for UNIX, Linux, or Windows
■ Legacy agent for Unicenter AutoSys Job Management 4.5.1 through r11
Command Jobs
When you define a Command job, you can specify settings including the following:
Starting Conditions
Defines conditions (for example, date, time, job state, and machine state) that must
be met before a job can start.
Disk Space Criteria
Defines the amount of free space required before a process can start. If the free
space is not available, an alarm is sent and the job is rescheduled.
Job Profile
Specifies a script to be sourced that defines the environment where the command
runs.
Note: On Windows, you can define a job profile using the Job Profiles - CA
Workload Automation AE Administrator window in the Administrator utility.
Environment Variables
Specifies variables that define the local environment where the job runs.
The shell the CMD job uses is determined by the following settings in the following
order:
1. The shell attribute (if specified in the job definition)
2. The oscomponent.defaultshell parameter in the agentparm.txt file (if not specified
in the shell attribute)
3. The user default shell defined in the user profile (if one exists on the computer)
4. On UNIX, the shell sourced from the /etc/auto.profile script (if one is specified)
5. The shell directive line (first line) of the script (if one is specified)
Notes:
■ If the shell is defined in the first line of the script, you do not need to include the
shell attribute in the job definition. The shell attribute tells the agent which shell
interpreter to use when launching the command. When the command executes a
script that specifies a shell, the script runs from that point forward under the shell
specified in the script.
■ If the oscomponent.checkvalidshell parameter in the agent's agentparm.txt file is
set to true (the default), all shells that are used must be specified using the
oscomponent.validshell parameter. The path defined in the first line of the script or
in the job definition must match the corresponding path in the
oscomponent.validshell parameter. If the shell you want to use is not defined on
the agent, the job fails. For more information about specifying valid shells, see the
oscomponent.checkvalidshell and oscomponent.validshell parameters in the CA
Workload Automation Agent for UNIX, Linux, or Windows Implementation Guide.
machine
Specifies the name of the machine on which the job runs.
command
Specifies the command, executable, UNIX shell script, application, or batch file
to run when all the starting conditions are met.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
■ To support chained commands (commands separated by a semicolon) on UNIX,
ensure that the oscomponent.wrapper.exec.force parameter in the agentparm.txt
file is set to false (the default). For more information about supporting chained
commands, see the UNIX Implementation Guide.
interactive
(Windows only) Specifies whether to run a Command job in interactive mode or in
batch mode on Windows.
Default: n (The job runs in batch mode.)
max_exit_success
Defines the maximum exit code that the job can exit with and be considered a
success.
Default: 0 (The job interprets only zero as job success.)
owner
Specifies the user ID that the job runs under.
Default: The default owner (the user ID who invokes jil to define the job)
shell
(UNIX only) Specifies the name of the shell used to execute the script or command
file.
Note: Alternatively, you can override the default shell by specifying the shell in the
first line of the script. If a shell is specified in the script and in the job definition, the
job uses the shell specified in the job definition.
Default:
■ oscomponent.defaultshell agent parameter, if specified
■ The user default shell defined in the user profile, if the shell is not specified in
the job definition, script, or oscomponent.defaultshell parameter
Attributes with Default Values
std_err_file
Defines the path and file name where you want to redirect all standard error
output.
CA WA Agent Default: The agent's spool directory
(installation_directory/SystemAgent/agent_name/spool)
Legacy Agent Default: /dev/null (UNIX) or NULL (Windows)
std_out_file
Defines the path and file name where you want to redirect all standard output.
CA WA Agent Default: The agent's spool directory
(installation_directory/SystemAgent/agent_name/spool)
Legacy Agent Default: /dev/null (UNIX) or NULL (Windows)
success_codes
Defines which exit codes indicate job success.
Default: 0 (The job interprets zero as job success.)
Notes: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Example: Override the Default Background Mode Using the interactive Attribute
This example runs a Command job in interactive mode on Windows. The job opens the
config.txt file in the Notepad application on the Windows desktop.
insert_job: edit_file
job_type: CMD
machine: winagent
description: "Edit/review a configuration file"
command: notepad.exe "c:\run_info\config.txt"
interactive: y
More information:
Determining Which Shell is Used (UNIX) (see page 219)
PATH
Provides a list of directories that the shell searches when it needs to find a
command. Each directory is separated by a colon. and the shell searches the
directories in the order listed. The PATH variable is the most important
environment variable. You can override the PATH value to set up a user-specific
environment by specifying a different PATH in the job definition.
Note: Overriding the default system path can result in the "command not found"
error.
ENV
Contains the name of the initialization file to run when a new Korn shell starts. You
can override the ENV value to set up a user-specific environment by specifying a
different ENV value in the job definition.
Example: ENV=/home/guest/bin/myenv
Note: The name of the file used to set up the script-running environment must be
.profile. The .profile must be the same file used with the HOME variable.
PWD
Contains the absolute path name of your current directory.
Define Alternative Error, Input, and Output Sources
std_in_file
Specifies where you want to redirect standard input from. The input can be a
file or a blob.
std_out_file
Specifies where you want to redirect the standard output. The output can be
redirected to a file or a blob.
3. Run the job.
The alternative sources are defined.
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
blob_input
Specifies the text to insert for the blob.
std_err_file
Specifies that the job blob contains the job's standard error messages in textual
or binary data format.
std_out_file
Specifies that the job blob contains the job's standard output messages in
textual or binary data format.
UNIX: To specify a name without the full path, the following conditions must be
met:
■ The agent is running under the root account.
■ The agent is configured to resolve environment variables.
■ The user ID you enter in the owner attribute has the authority to run the
job on the agent. The user default shell is used.
■ The path to the script or command name is set in the PATH system
environment variable for the specified user ID.
Specify a Command or Script Name Without the Full Path
Windows: To specify a name without the full path, the following conditions
must be met:
■ The agent is configured to search for paths to command or script files.
■ The script or command file is located in one of the following directories:
- The directory the agent is installed in
- WINDOWS\system32 directory on the agent computer
- WINDOWS\system directory on the agent computer
- WINDOWS directory on the agent computer
- Any other directory whose path is set in the system path or user path on
the agent computer
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ To configure the agent to resolve environment variables, ask your agent
administrator to refer to the information about the oscomponent.lookupcommand
parameter in the CA Workload Automation Agent for UNIX, Linux, or Windows
Implementation Guide.
■ Environment variables are not currently supported in the command attribute for
Command jobs that run on Windows.
Example: Run a Script that is Located in a Path Set in the PATH Variable (UNIX)
This example runs a script named procscript.sh. The job runs under the user ID jsmith,
which has the authority to run the script. The path to procscript.sh is set in the PATH
system environment variable for jsmith on the agent computer and the agent is
configured to search for paths to command and script files.
insert_job: unix_job
job_type: CMD
machine: unixagent
command: procscript.sh
owner: jsmith Specify a Command or Script Name Using an Environment Variable (UNIX)
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ To configure the agent to resolve environment variables, ask your agent
administrator to refer to the information about the oscomponent.lookupcommand
parameter in the CA Workload Automation Agent for UNIX, Linux, or Windows
Implementation Guide.
Example: Run a Script that is Located in a Path Set in a User Environment Variable
In this example, an agent named unixagent runs a script named myscript.sh. The job
runs under the user ID jsmith, which has the authority to run the script. The path to
myscript.sh is set in the user environment variable $MY_PATH, which is defined in the
profile file for jsmith. The agent is configured to search for paths to command and script
files.
insert_job: unix_job
job_type: CMD
machine: unixagent
command: $MY_PATH/myscript.sh
owner: jsmith
Run a Script Under a Specific User Account (UNIX)
You can define a Command job to run a UNIX command or script under a specific user's
account.
Follow these steps:
1. On the client computer where you want to run the job, do one of the following:
■ Start the agent as root.
■ Start the agent as a user other than root.
Note: This user account must have permissions to access the resources that the
job requires. If the job is defined to run under a different user (owner), the user
account the agent is started under must have permissions to switch to that
user. Otherwise, the job fails.
Run a Script Under a Specific User Account (UNIX)
Notes:
■ If the shell is specified in the first line of the script and its path matches the path
defined in the oscomponent.validshell parameter, you do not have to specify the
shell attribute in the job definition to define the shell that you want the agent to
use. For example, you can run a script using the environment defined in a specific
user's account.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
Notes:
■ If the job runs under a non-root user ID, the hard limit will not be modified if the
value in the job definition is greater than the hard limit on the UNIX computer.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
Customize the Run-time Environment for a Korn Shell Script (UNIX)
4. Ask your agent administrator to configure the agent to run the Bourne shell script
using the Korn shell
5. Run the job.
The run-time environment for the Bourne shell script is customized.
Notes:
■ The ENV variable only works for the Korn shell. The Korn shell is a superset of the
Bourne shell. Anything that runs under the Bourne shell runs without modification
under the Korn shell.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
3. Add the command attribute to the job definition using the following syntax:
command: /usr/script
script
Specifies the path to the script you want to run.
Example: cmd1.pl
3. Add the command attribute to the job definition using the following syntax:
command: command argument...
command
Specifies the cmd.exe command to run.
Examples: copy, dir, echo
argument...
Specifies one or more arguments to pass to the cmd.exe command.
Note: Separate each argument with a space. You must specify each argument
in the order it is expected in the program.
4. Run the job.
The job runs the specified cmd.exe command.
Run the Windows Command Interpreter (Windows)
Notes:
■ You can specify UNC (Universal Naming Convention) names. A UNC name
is the name of a file or other resource that begins with two backslashes
(\\), indicating that it exists on a remote computer.
■ You can specify share names. A share name is an alias for the path the
resource exists in.
■ You can specify the share names C$ and ADMIN$ if the agent service logs
on to a remote Windows server as a user with administrative authority.
The agent can then access remote resources that are not marked as
shared.
owner
Specifies the Windows user ID and the domain the user ID belongs to.
Default: The default owner (the user ID who invokes jil to define the job)
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ Before accessing network resources with your agent, verify that you are complying
with the terms of your agent license agreement. In most situations, you are
permitted to access data on remote computers; however, scripts or executable files
run by an agent should use the CPU and memory of the computer where the agent
resides.
■ Although not recommended, your agent administrator can run the agent as a
Windows service under a local user account (the This Account option). When you
run the service under a local user account, when the service starts, it runs using the
security context of the specified user account. If the user account and password are
valid, the service process has access to network resources.
■ When you access a remote computer from an agent on Windows, the user ID
defined in the owner attribute or in the This Account option is a domain user. If the
local and remote servers are standalone servers, you must have the same user IDs
and passwords defined on both servers.
■ For more information on configuring and running the agent as a Windows service,
see the CA Workload Automation Agent for UNIX, Linux, or Windows
Implementation Guide.
If the user ID requires a password, your administrator must define the password on the
scheduling manager. For security reasons, you do not define the password in the job
definition. Your administrator must define and store the password in the CA Workload
Automation AE database using the autosys_secure command.
When you specify a user ID that requires a password in a job definition, the scheduling
manager sends the agent the user ID and password pair (the password is encrypted).
The scheduling manager searches the repository for an entry matching the specified
owner. The results from the search, the encrypted password or null, are provided to the
agent to run the job.
Command Jobs :
Command jobs let you run workload on UNIX and Windows client computers. On UNIX,
you can define jobs to run scripts and commands. On Windows, you can define jobs to
run command files and batch files.
Note: To run these jobs, your system requires one of the following:
■ CA WA Agent for UNIX, Linux, or Windows
■ Legacy agent for Unicenter AutoSys Job Management 4.5.1 through r11
Command Jobs
When you define a Command job, you can specify settings including the following:
Starting Conditions
Defines conditions (for example, date, time, job state, and machine state) that must
be met before a job can start.
Disk Space Criteria
Defines the amount of free space required before a process can start. If the free
space is not available, an alarm is sent and the job is rescheduled.
Job Profile
Specifies a script to be sourced that defines the environment where the command
runs.
Note: On Windows, you can define a job profile using the Job Profiles - CA
Workload Automation AE Administrator window in the Administrator utility.
Environment Variables
Specifies variables that define the local environment where the job runs.
The shell the CMD job uses is determined by the following settings in the following
order:
1. The shell attribute (if specified in the job definition)
2. The oscomponent.defaultshell parameter in the agentparm.txt file (if not specified
in the shell attribute)
3. The user default shell defined in the user profile (if one exists on the computer)
4. On UNIX, the shell sourced from the /etc/auto.profile script (if one is specified)
5. The shell directive line (first line) of the script (if one is specified)
Notes:
■ If the shell is defined in the first line of the script, you do not need to include the
shell attribute in the job definition. The shell attribute tells the agent which shell
interpreter to use when launching the command. When the command executes a
script that specifies a shell, the script runs from that point forward under the shell
specified in the script.
■ If the oscomponent.checkvalidshell parameter in the agent's agentparm.txt file is
set to true (the default), all shells that are used must be specified using the
oscomponent.validshell parameter. The path defined in the first line of the script or
in the job definition must match the corresponding path in the
oscomponent.validshell parameter. If the shell you want to use is not defined on
the agent, the job fails. For more information about specifying valid shells, see the
oscomponent.checkvalidshell and oscomponent.validshell parameters in the CA
Workload Automation Agent for UNIX, Linux, or Windows Implementation Guide.
$HOME/.profile
Runs when you log in. Use this login script to set options, set the path, and set and
export variable values.
The following is a sample $HOME/.profile file:
set -o allexport
PATH=.:/bin:/usr/bin:$HOME/bin
CDPATH=.:$HOME:$HOME/games
PS1='! $PWD> '
ENV=$HOME/.kshrc
TIMEOUT=0
set +o allexport
The script named in the Korn shell variable ENV
Runs when you create a Korn shell or run a Korn shell script. Use this file to define
aliases and functions and to set default options and variables that you want to
apply to the Korn shell invocation.
machine
Specifies the name of the machine on which the job runs.
command
Specifies the command, executable, UNIX shell script, application, or batch file
to run when all the starting conditions are met.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
■ To support chained commands (commands separated by a semicolon) on UNIX,
ensure that the oscomponent.wrapper.exec.force parameter in the agentparm.txt
file is set to false (the default). For more information about supporting chained
commands, see the UNIX Implementation Guide.
interactive
(Windows only) Specifies whether to run a Command job in interactive mode or in
batch mode on Windows.
Default: n (The job runs in batch mode.)
max_exit_success
Defines the maximum exit code that the job can exit with and be considered a
success.
Default: 0 (The job interprets only zero as job success.)
owner
Specifies the user ID that the job runs under.
Default: The default owner (the user ID who invokes jil to define the job)
shell
(UNIX only) Specifies the name of the shell used to execute the script or command
file.
Note: Alternatively, you can override the default shell by specifying the shell in the
first line of the script. If a shell is specified in the script and in the job definition, the
job uses the shell specified in the job definition.
Default:
■ oscomponent.defaultshell agent parameter, if specified
■ The user default shell defined in the user profile, if the shell is not specified in
the job definition, script, or oscomponent.defaultshell parameter
Attributes with Default Values
std_out_file
Defines the path and file name where you want to redirect all standard output.
CA WA Agent Default: The agent's spool directory
(installation_directory/SystemAgent/agent_name/spool)
Legacy Agent Default: /dev/null (UNIX) or NULL (Windows)
success_codes
Defines which exit codes indicate job success.
Default: 0 (The job interprets zero as job success.)
Notes: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
You can pass the following UNIX environment variables in a job definition to override
the variable values:
HOME
Identifies the user's login directory. You can override the HOME value to set up a
user-specific environment by specifying a different login directory in the job
definition.
Example: HOME=/home/guest/bin
Notes:
■ You can set up the script's running environment in the .profile and .login files.
■ You must also set the oscomponent.loginshell parameter to true in the agent's
agentparm.txt file to run the login scripts located in the HOME directory.
PATH
Provides a list of directories that the shell searches when it needs to find a
command. Each directory is separated by a colon. and the shell searches the
directories in the order listed. The PATH variable is the most important
environment variable. You can override the PATH value to set up a user-specific
environment by specifying a different PATH in the job definition.
Note: Overriding the default system path can result in the "command not found"
error.
ENV
Contains the name of the initialization file to run when a new Korn shell starts. You
can override the ENV value to set up a user-specific environment by specifying a
different ENV value in the job definition.
Example: ENV=/home/guest/bin/myenv
Note: The name of the file used to set up the script-running environment must be
.profile. The .profile must be the same file used with the HOME variable.
PWD
Contains the absolute path name of your current directory.
Define Alternative Error, Input, and Output Sources
std_out_file
Specifies where you want to redirect the standard output. The output can be
redirected to a file or a blob.
blob_input
Specifies the text to insert for the blob.
std_err_file
Specifies that the job blob contains the job's standard error messages in textual
or binary data format.
std_out_file
Specifies that the job blob contains the job's standard output messages in
textual or binary data format.
3. Run the job.
The job blob is created.
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ You can also use the insert_blob subcommand to create an input job blob after a
job is defined.
Create a Job Blob
UNIX: To specify a name without the full path, the following conditions must be
met:
■ The agent is running under the root account.
■ The agent is configured to resolve environment variables.
■ The user ID you enter in the owner attribute has the authority to run the
job on the agent. The user default shell is used.
■ The path to the script or command name is set in the PATH system
environment variable for the specified user ID.
Specify a Command or Script Name Without the Full Path
Windows: To specify a name without the full path, the following conditions
must be met:
■ The agent is configured to search for paths to command or script files.
■ The script or command file is located in one of the following directories:
- The directory the agent is installed in
- WINDOWS\system32 directory on the agent computer
- WINDOWS\system directory on the agent computer
- WINDOWS directory on the agent computer
- Any other directory whose path is set in the system path or user path on
the agent computer
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ To configure the agent to resolve environment variables, ask your agent
administrator to refer to the information about the oscomponent.lookupcommand
parameter in the CA Workload Automation Agent for UNIX, Linux, or Windows
Implementation Guide.
■ Environment variables are not currently supported in the command attribute for
Command jobs that run on Windows.
Example: Run a Script that is Located in a Path Set in the PATH Variable (UNIX)
This example runs a script named procscript.sh. The job runs under the user ID jsmith,
which has the authority to run the script. The path to procscript.sh is set in the PATH
system environment variable for jsmith on the agent computer and the agent is
configured to search for paths to command and script files.
insert_job: unix_job
job_type: CMD
machine: unixagent
command: procscript.sh
owner: jsmith Specify a Command or Script Name Using an Environment Variable (UNIX)
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ To configure the agent to resolve environment variables, ask your agent
administrator to refer to the information about the oscomponent.lookupcommand
parameter in the CA Workload Automation Agent for UNIX, Linux, or Windows
Implementation Guide.
Example: Run a Script that is Located in a Path Set in a User Environment Variable
In this example, an agent named unixagent runs a script named myscript.sh. The job
runs under the user ID jsmith, which has the authority to run the script. The path to
myscript.sh is set in the user environment variable $MY_PATH, which is defined in the
profile file for jsmith. The agent is configured to search for paths to command and script
files.
insert_job: unix_job
job_type: CMD
machine: unixagent
command: $MY_PATH/myscript.sh
owner: jsmith
Run a Script Under a Specific User Account (UNIX)
You can define a Command job to run a UNIX command or script under a specific user's
account.
Notes:
■ If the shell is specified in the first line of the script and its path matches the path
defined in the oscomponent.validshell parameter, you do not have to specify the
shell attribute in the job definition to define the shell that you want the agent to
use. For example, you can run a script using the environment defined in a specific
user's account.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
The login shell for user guest does not have to be the Korn shell. For example, the agent
can pick up the following environment variables for user guest:
HOME=/home/guest
LOGNAME=guest
USER=guest
SHELL=/usr/bin/csh
PWD=/home/guest
In this example, user guest has specified the login shell as the C shell. The agent,
therefore, runs the cmd1.ksh script using the environment defined in the $HOME/.login
file.
Notes:
■ If the job runs under a non-root user ID, the hard limit will not be modified if the
value in the job definition is greater than the hard limit on the UNIX computer.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
Customize the Run-time Environment for a Korn Shell Script (UNIX)
4. Ask your agent administrator to configure the agent to run the Bourne shell script
using the Korn shell
5. Run the job.
The run-time environment for the Bourne shell script is customized.
Notes:
■ The ENV variable only works for the Korn shell. The Korn shell is a superset of the
Bourne shell. Anything that runs under the Bourne shell runs without modification
under the Korn shell.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
3. Add the command attribute to the job definition using the following syntax:
command: /usr/script
script
Specifies the path to the script you want to run.
Example: cmd1.pl
3. Add the command attribute to the job definition using the following syntax:
command: command argument...
command
Specifies the cmd.exe command to run.
Examples: copy, dir, echo
argument...
Specifies one or more arguments to pass to the cmd.exe command.
Note: Separate each argument with a space. You must specify each argument
in the order it is expected in the program.
4. Run the job.
The job runs the specified cmd.exe command.
Run the Windows Command Interpreter (Windows)
Notes:
■ If the agent parameters specified in Step 1 are not set to true, you must explicitly
invoke the command interpreter in the command attribute, as follows:
command: "path\cmd.exe /C command argument..."
path
Specifies the path to cmd.exe. The path to cmd.exe depends on your Windows
operating system version. For example, on Windows NT, the path is
C:\WINNT\system32\cmd.exe.
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
Notes:
■ You can specify UNC (Universal Naming Convention) names. A UNC name
is the name of a file or other resource that begins with two backslashes
(\\), indicating that it exists on a remote computer.
■ You can specify share names. A share name is an alias for the path the
resource exists in.
■ You can specify the share names C$ and ADMIN$ if the agent service logs
on to a remote Windows server as a user with administrative authority.
The agent can then access remote resources that are not marked as
shared.
owner
Specifies the Windows user ID and the domain the user ID belongs to.
Default: The default owner (the user ID who invokes jil to define the job)
Notes:
■ For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference
Guide.
■ Before accessing network resources with your agent, verify that you are complying
with the terms of your agent license agreement. In most situations, you are
permitted to access data on remote computers; however, scripts or executable files
run by an agent should use the CPU and memory of the computer where the agent
resides.
■ Although not recommended, your agent administrator can run the agent as a
Windows service under a local user account (the This Account option). When you
run the service under a local user account, when the service starts, it runs using the
security context of the specified user account. If the user account and password are
valid, the service process has access to network resources.
■ When you access a remote computer from an agent on Windows, the user ID
defined in the owner attribute or in the This Account option is a domain user. If the
local and remote servers are standalone servers, you must have the same user IDs
and passwords defined on both servers.
■ For more information on configuring and running the agent as a Windows service,
see the CA Workload Automation Agent for UNIX, Linux, or Windows
Implementation Guide.
If the user ID requires a password, your administrator must define the password on the
scheduling manager. For security reasons, you do not define the password in the job
definition. Your administrator must define and store the password in the CA Workload
Automation AE database using the autosys_secure command.
When you specify a user ID that requires a password in a job definition, the scheduling
manager sends the agent the user ID and password pair (the password is encrypted).
The scheduling manager searches the repository for an entry matching the specified
owner. The results from the search, the encrypted password or null, are provided to the
agent to run the job.
Database Jobs :
Database jobs let you automate common database tasks on Oracle, Microsoft SQL
Server, Sybase, and IBM DB2 databases.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Databases.
You can define the following database jobs:
SQL
Lets you run an SQL query against a database.
Database Stored Procedure
Lets you run a stored procedure.
Database Trigger
Lets you monitor for added, deleted, and updated rows in a database table.
Database Monitor
Lets you monitor for added and deleted rows in a database table.
Suppose that you want to send a notification when a new row is added. Within a
10-second interval, assume a row is added while another row is deleted. A Database
Trigger job that monitors for an INSERT would complete and send the notification when
the new row is detected. A Database Monitor job that monitors for an INCREASE would
not complete or send a notification because no change in the total number of rows was
detected.
Each Database Trigger job creates a database trigger on the database. The database
trigger templates are provided with the agent. Before using a Database Trigger job,
consult with your database administrator.
Notes:
■ A table being monitored should not be dropped because the Database Trigger or
Database Monitor job remains in the RUNNING status even if the table has been
dropped.
■ For more information about the database trigger templates, see the db.trig.propfile
parameter in the CA Workload Automation Agent for Databases Implementation
Guide.
machine
Specifies the name of the machine on which the job runs.
tablename
Specifies the name of the database table to monitor for the changes.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
More information:
Insert a Job Definition (see page 88)
Example: Monitor a SQL Server Database Table for Added Rows with a Trigger
Condition
This example monitors the sales table for added rows. The job runs under the sa user,
who owns the table and is authorized to create triggers on the database or schema the
table belongs to. The job connects to the default database resource location defined on
the agent. When the qty for inserted title ID TC7777 is greater than or equal to 20, the
job completes.
insert_job: dbtrig3
job_type: DBTRIG
machine: DB_agent
dbtype: MSSQL
trigger_type: INSERT
trigger_cond: (select QTY from INSERTED where TITLE_ID='TC7777')>=20
tablename: sales
owner: sa@myhost
Example: Monitor a SQL Server Database Table for Deleted Rows
This example monitors the sales table for deleted rows. The job runs under the sa user,
who owns the table and is authorized to create triggers on the database or schema the
table belongs to. The job completes when a row is deleted.
insert_job: dbtrig4
job_type: DBTRIG
machine: DB_agent
dbtype: MSSQL
trigger_type: DELETE
tablename: sales
owner: sa@myhost
connect_string:"jdbc:sqlserver://myhost:1433;DatabaseName=pubs" Define a Database Trigger Job
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Invoke a Stored Procedure with Input and Output Parameters from an IBM
DB2 Database
This example invokes the following stored procedure under the user entadm:
CREATE PROCEDURE DEPT_MEDIAN
(IN deptNumber SMALLINT, OUT medianSalary DOUBLE)
LANGUAGE SQL
BEGIN
DECLARE v_numRecords INTEGER DEFAULT 1;
DECLARE v_counter INTEGER DEFAULT 0;
DECLARE c1 CURSOR FOR
SELECT CAST(salary AS DOUBLE) FROM staff
WHERE DEPT = deptNumber
ORDER BY salary;
DECLARE EXIT HANDLER FOR NOT FOUND
SET medianSalary = 6666;
-- initialize OUT parameter
SET medianSalary = 0;
SELECT COUNT(*) INTO v_numRecords FROM staff
WHERE DEPT = deptNumber;
OPEN c1;
WHILE v_counter < (v_numRecords / 2 + 1) DO
FETCH c1 INTO medianSalary;
SET v_counter = v_counter + 1;
END WHILE;
CLOSE c1;
END
DEPT_MEDIAN returns the median salary for the department with deptNumber 20 from
the STAFF table. The median salary, 18171.25, is recorded in the job’s spool file.
insert_job: deptmed
job_type: DBPROC
machine: DB_agent
sp_name: ENTADM.DEPT_MEDIAN
sp_arg: name=deptNumber, argtype=IN, datatype=SMALLINT, value=20
sp_arg: name=medianSalary, argtype=OUT, datatype=DOUBLE
owner: entadm
connect_string:"jdbc:db2://172.31.255.255:50000/SAMPLE"
The spool file for this job contains the following output:
----------------------------------------------------------------
Output of messages for workload object DEPTMED/DBAPPL.7/MAIN
Start date Thu Aug 31 15:23:44 EDT 2006
----------------------------------------------------------------
{ call ENTADM.DEPT_MEDIAN(?, ?) }
medianSalary=18171.25 Define an SQL Job
More information:
Insert a Job Definition (see page 88)
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
More information:
Insert a Job Definition (see page 88)
Example: Return Data from an Oracle Database Table that Match a Condition
This example queries the emp table for enames that have salaries greater than 40,000.
If the query returns an ename that begins with the letter d, the job completes:
insert_job: selectjob
job_type: SQL
machine: DB_agent
sql_command: SELECT ename FROM emp WHERE sal > 40000
owner: scott@orcl
success_criteria: ENAME=d.*
connect_string:"jdbc:oracle:thin:@myhost:1521:orcl"
destination_file: /emp/salary.txt
For example, the salary.txt file contains the following output:
Output for: SELECT ename FROM emp WHERE sal > 40000
ENAME
-----------
donald
Examples: Running SQL Queries Against Microsoft SQL Server Database Tables
The following examples are jobs that run SQL queries against Microsoft SQL Server
database tables:
Note: These examples use optional database attributes. For more information about the
optional attributes and their JIL syntax, see the Reference Guide.
Example: Add a Row to a SQL Server Database Table
This example adds a row for a new store to the stores table.
insert_job: insertjob
job_type: SQL
machine: DB_agent
sql_command: INSERT INTO stores(stor_id, stor_name, stor_address, city, state, zip)
VALUES('6523', 'BooksMart', '6523 Main St.', 'San Diego', 'CA', '93223')
owner: sa@myhost
connect_string:"jdbc:sqlserver://myhost:1433;DatabaseName=pubs" Define an SQL Job
owner
Specifies the user ID that the job runs under.
Default: The user ID who invokes jil to define the job
Note: Windows authentication is not supported.
trigger_type (Database Trigger jobs only)
Specifies the type of database change to monitor for.
Default: INSERT (The job monitors for an insertion of a row in the table.)
user_role
Specifies the Oracle database user type.
Default: db.default.userType agent parameter, if specified
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Attributes with Default Values
machine
Specifies the name of the machine on which the job runs.
watch_file
Specifies the path to and name of one or more files to monitor.
Notes:
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Define a File Watcher Job
FTP Jobs :
Using your agent, you can automate File Transfer Protocol (FTP) transfers with an FTP
job. The FTP job can upload data to or download data from an existing FTP server or
another agent running as an FTP server. The FTP job always acts as an FTP client.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, Windows,
or i5/OS.
You can use an FTP job to automate the following:
■ Download ASCII, binary, or EBCDIC (i5/OS only) files from a remote FTP server to
your agent computer.
■ Upload ASCII, binary, or EBCDIC (i5/OS only) files from your agent computer to a
remote FTP server.
Your agent administrator can set up the agent to run as an FTP client, FTP server, or
both.
EBCDIC File Transfers
The EBCDIC transfer type applies to CA WA Agent for i5/OS only.
For the QSYS file system on i5/OS systems, you can only transfer members of FILE
objects.
Note: For more information about FTP restrictions on i5/OS systems, see the IBM
documentation.
FTP Jobs
i5/OS Jobs :
The i5/OS job lets you run a program or issue a command on an i5/OS system. You can
run i5/OS jobs in the following file systems:
■ Root file system
■ Open systems file system (QOpenSys)
■ Library file system (QSYS)
Note: To run these jobs, your system requires CA WA Agent for i5/OS.
You can specify the following details in an i5/OS job definition:
■ Library name, library list, and current library for running a program
■ The i5/OS job name, options under which the job will run, where it will run, and
which user will run it
■ Ending exit value of the program, such as a severity code
You can define parameter values that you want to pass to a program at the time the
program is invoked.
Note: Default values may be set for certain parameters, such as the i5/OS user ID that
the jobs run under. Contact your agent administrator about the parameters set in the
agentparm.txt file.
i5/OS Jobs
machine
Specifies the name of the machine on which the job runs.
3. Specify at least one of the following attributes if monitor_mode is set to WAIT (the
default) or CONTINUOUS:
■ lower_boundary
■ upper_boundary
Notes:
■ If the monitor_mode is set to WAIT, the job monitors for available CPU on the
specified machine and completes when the CPU usage value falls within the
lower and upper boundaries.
■ If the monitor_mode is set to CONTINUOUS, the job monitors for the
conditions continuously and an alert is written to the scheduler log file.
4. (Optional) Specify common attributes that apply to all job types.
The CPU Monitoring job is defined. When the job runs, it monitors for available CPU
on the specified machine and completes when the CPU usage value falls within the
lower and upper boundaries.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
inside_range
Specifies whether the job completes (or triggers if monitoring continuously) when
the value of CPU usage is inside or outside the specified boundaries.
Default: TRUE (The job completes or triggers if the value of the CPU usage is within
the lower and upper boundaries.)
lower_boundary
Defines the minimum amount of CPU usage to monitor for in percent.
Default: 0 (The job monitors the CPU usage between zero and the upper boundary.)
monitor_mode
Specifies whether the job waits until the monitor conditions are met or tries to
verify them immediately.
Default: WAIT (The job waits until the specified conditions are met before
completing.)
poll_interval
Defines the interval (in seconds) between successive scans of the CPU usage.
Default: objmon.scaninterval agent parameter (This parameter is automatically set
to 10. The job polls the CPU usage every 10 seconds during continuous monitoring.)
upper_boundary
Defines the maximum amount of CPU usage to monitor for in percent.
Default: 100 (The job monitors the CPU usage between the lower boundary and
100 percent.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
3. Specify one or both of the following attributes if monitor_mode is set to WAIT (the
default) or CONTINUOUS:
■ lower_boundary
■ upper_boundary
4. (Optional) Specify common attributes that apply to all job types.
The Disk Monitoring job is defined.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
insert_job: omd_job
job_type: OMD
machine: winagent
disk_drive: C
disk_space: FREE
disk_format: KB
lower_boundary: 35000000
upper_boundary: 36000000
inside_range: TRUE
no_change: 100
monitor_mode: CONTINUOUS
The following table shows four sequential scans:
machine
Specifies the name of the machine on which the job runs.
ip_host
Specifies the DNS name or IP address.
Define an IP Monitoring Job
monitor_mode
Specifies whether the job waits until the monitor conditions are met or tries to
verify them immediately.
Default: NOW (The job checks for the conditions immediately and completes.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
machine
Specifies the name of the machine on which the job runs.
text_file_filter
Defines the text string to search for. You can specify the text string as a regular
expression.
text_file_name
Specifies the path to and name of the text file to search.
Define a Text File Reading and Monitoring Job
The following Text File Reading and Monitoring job attributes have default values:
encoding
Specifies the name of the character set used to encode the data in the file.
Default: US-ASCII (The job monitors the file as US-ASCII.)
monitor_mode
Specifies whether the job waits until the monitor conditions are met or tries to
verify them immediately.
Default: WAIT (The job waits until the specified conditions are met before
completing.)
text_file_mode
Specifies the search mode when monitoring a text file.
Default: LINE (The job searches for the text in the specified line boundaries.)
text_file_filter_exists
Specifies whether the job monitors the text file to check if the text string exists or
does not exist.
Default: TRUE (The job checks if the text string exists.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Example: Search for a String in a File When the Search Mode is DATETIME
This example searches the /export/home/logs/transmitter.log file in date and time
mode. The job searches the content between May 20, 2010 at midnight and May 27,
2010 at 11:59 p.m. The date and time values are defined using the format specified in
the time_format attribute. The job completes successfully if the transmitted string is
found.
insert_job: omtf_timedate
job_type: OMTF
machine: monagt
text_file_name: /export/home/logs/transmitter.log
text_file_filter: transmitted
text_file_mode: DATETIME
lower_boundary: "Thu May 20 00:00:00.000 EDT 2010"
upper_boundary: "Thu May 27 23:59:59.999 EDT 2010"
time_format: "EEE MMM dd HH:mm:ss.SSS zzz yyyy"
time_position: 12
monitor_mode: NOW
Example: Monitor a Text File Continuously
This example searches the transmitter.log file for the text string "Warning".
insert_job: textfile_job
job_type: OMTF
machine: monagt
text_file_name: /export/home/log/transmitter.log
text_file_filter: Warning
text_file_mode: LINE
lower_boundary: 25
text_file_filter_exists: TRUE
monitor_mode: CONTINUOUS Define a Text File Reading and Monitoring Job
When the job first runs, it searches the content between line 25 and the end of the file.
An alert is written to the scheduler log file the first time that the string is found. In other
words, suppose that the file contains multiple occurrences of "Warning" between lines
25 to the end of the file, as follows:
.
.
.
25
26 Warning
27
28 Warning
29
30
31 Warning
.
.
.
EOF
When the job first runs, the trigger only occurs at the first occurrence of the text (line
26). Subsequently, the job continues monitoring only the new data that is appended to
the file. An alert is triggered each time the string is found in the appended data.
Note: Alerts are not triggered for new occurrences of the "Warning" string in the data
that has already been searched. For example, suppose that the job has already searched
lines 25 to 100 of the file. The file is then modified to include "Warning" on line 30.
During continuous monitoring, an alert is not triggered for that occurrence.
This job runs until it is completed manually.
machine
Specifies the name of the machine on which the job runs.
win_log_name
Specifies the name of the event log.
Define a Windows Event Log Monitoring Job
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Define a Windows Event Log Monitoring Job
System log
The system log contains events logged by the Windows system components. For
example, the failure of a driver or other system component to load during startup is
recorded in the system log.
Security log
The security log can record security events (such as valid and invalid logon
attempts) and events related to resource use (such as creating, opening, or deleting
files).
For more information on Windows logs, select Start, Settings, Control Panel,
Administrative Tools, Event Viewer. Select any of the three log categories and
double-click to view its property page.
The following Windows Event Log Monitoring job attributes have default values:
monitor_mode
Specifies whether the job waits until the monitor conditions are met or tries to
verify them immediately.
Default: WAIT (The job waits until the specified conditions are met before
completing.)
win_event_type
Specifies the event type to monitor in the Windows event log.
Default: ERROR (The job monitors for the Error event type.)
win_event_op
Specifies a comparison operator against the value of a Windows Event ID.
Default: EQ (The job monitors for an Event ID that is equal to the specified value.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
machine
Specifies the name of the machine on which the job runs.
win_service_name
Specifies the name of the local Windows service to be monitored.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Define a Windows Service Monitoring Job
Chapter 14: Monitoring Jobs 373
The following Windows Service Monitoring job attributes have default values:
monitor_mode
Specifies whether the job waits until the monitor conditions are met or tries to
verify them immediately.
Default: NOW (The job checks for the conditions immediately and completes.)
win_service_status
Specifies the status of the Windows Service to be monitored.
Default: RUNNING (The job checks if the Windows service is running.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
When a PeopleSoft program runs, it modifies its run status (RUNSTATUS) in the
PSPRCSRQST table in the PS database. The following diagram shows the functional
relationship between the scheduling manager, the agent, and the PeopleSoft system:
■ ps_dlist_roles
■ ps_dlist_users
■ ps_email_address
■ ps_email_address_expanded
■ ps_email_log
■ ps_email_subject
■ ps_email_text
■ ps_email_web_report
■ ps_operator_id
■ ps_output_dest
■ ps_restarts
■ ps_run_cntrl_args
■ ps_run_control_table
■ ps_server_name
■ ps_skip_parm_updates
■ ps_time_zone
Note: A PeopleSoft job must have a valid operator ID to run successfully. Check with
your agent administrator to determine whether a default operator ID is set on the
agent. If a default is not set, you must specify this attribute.
4. (Optional) Specify common attributes that apply to all jobs.
The PeopleSoft job is defined.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs. Attributes with Default Values
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
ps_email_log
Specifies whether to email job logs with the PeopleSoft report to recipients on a
distribution list.
Default: No (Job logs are not emailed to recipients.)
ps_email_web_report
Specifies whether to email a web report to recipients on a distribution list.
Default: No (A web report is not emailed to recipients.)
ps_operator_id
Specifies the operator ID under whose authority the PeopleSoft reports run.
Default: ps.default.oprId agent parameter, if specified
ps_output_dest
Specifies the output destination for the PeopleSoft request. The destination can be
a file directory or a printer.
Default: If ps_dest_type is PRINTER, the default is one of the following, in the
following order:
■ ps.default.printer parameter in the agent's agentparm.txt file, if specified
■ The default PeopleSoft printer, lpt1
ps_restarts
Specifies whether to disable a restart feature for previously failed jobs from the
point where the job failed.
Default: No (The restart feature is not disabled.)
ps_run_cntrl_id
Specifies a set of PeopleSoft run parameters for a given PeopleSoft process.
Default: ps.default.runCntlId agent parameter, if specified
Note: All PeopleSoft jobs require a run control ID. If you do not specify this attribute
in the job definition, a default run control ID must be defined in the
ps.default.runCntlId parameter in the agent's agentparm.txt file. Otherwise, the job
fails.
Mapping of PeopleSoft Fields to Job Attributes
ps_server_name
Specifies the target server that runs the PeopleSoft job.
Default: ps.default.serverName
Note: If the PeopleSoft Server is not specified as a default on the agent or in the job
definition, the PeopleSoft Process Scheduler determines the PeopleSoft Server that
will run the job.
ps_skip_parm_updates
Specifies whether you want the agent to update job parameters with data in the
PS_PRCSDEFN table.
Default: NO (The agent updates job parameters with data in the PS_PRCSDEFN
table.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
ps_dest_format
Specifies the field name of the output destination format. PeopleSoft stores the
list of output destination formats in the PSXLATITEM table. This value
corresponds to the Format field in PeopleSoft.
ps_email_address
Specifies the email addresses of the recipients on a distribution list. This value
corresponds to the Email Address List field in PeopleSoft.
ps_email_subject
Defines an email subject to include in the email. This value corresponds to the
Email Subject field in PeopleSoft.
ps_email_text
Defines the body text of the email. This value corresponds to the Message Text
field in PeopleSoft.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
machine
Specifies the name of the machine on which the job runs.
remote_command
Specifies a command or script to run on a remote computer.
remote_target
Specifies the name of the custom properties (remote_target.properties) file
that is created on the agent for the remote system. The file contains the
default user credentials that are used to monitor all jobs run on the target
machine by the agent. The name should not include the .properties extension.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Attributes with Default Values
spool_file
Specifies the path to the spool file.
Default: spoolHome custom property
owner
Specifies the user ID that the job runs under.
Default: The default owner (the user ID who invokes jil to define the job)
success_codes
Defines which exit codes indicate job success.
Default: 0 (The job interprets zero as success.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
SAP Jobs
SAP jobs let you run SAP workload.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for SAP.
You can define the following SAP jobs:
SAP Batch Input Session
Imports data from external systems to the SAP system.
SAP Business Warehouse (BW) InfoPackage
Transfers data from a data source to an SAP Business Warehouse system.
SAP Business Warehouse (BW) Process Chain
Creates Process Chains on the SAP system.
SAP Connection Attributes
sap_client
Specifies the client number associated with an SAP instance. An SAP instance can
have multiple clients defined for it. Each client has its own data. Your agent
administrator can define a default SAP client number using the jco.client.client
property in the connection properties file.
sap_lang
Specifies the language required to run a job. Your agent administrator can define a
default language using the jco.client.lang property in the connection properties file.
sap_target_sys
Specifies the host name of an SAP application server where the job is to run.
Note: If the sap_target_sys attribute is not defined, the SAP system will select an
application server based on available resources.
Notes:
■ If a default value is not defined on the agent, you must specify the attribute in the
job definition.
■ For more information about these attributes, see the Reference Guide.
SAP User IDs and Passwords
machine
Specifies the name of the machine on which the job runs.
sap_job_name
Specifies the name of the ABAP job that creates the BDC session on the SAP
system.
sap_step_parms
Defines the SAP R/3 step specifications.
Note: We recommend that you limit the number of steps (ABAPs) to one per
job. If you run a job and one of the ABAPs fails, the job is marked as failed. If
the ABAP fails, you cannot re-run the ABAP without re-running the entire job.
Define an SAP Batch Input Session Job
■ sap_job_class
■ sap_lang
■ sap_office
■ sap_recipients
■ sap_release_option
■ sap_rfc_dest
■ sap_step_parms
■ sap_target_sys
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Define an SAP Batch Input Session Job
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
machine
Specifies the name of the machine on which the job runs.
arc_obj_name
Specifies the name of the archiving object.
arc_obj_variant
Specifies the name of the archiving object variant.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Define an SAP Event Monitor Job
machine
Specifies the name of the machine on which the job runs.
sap_event_id
Specifies the name of the SAP event to monitor or trigger.
Define an SAP Event Monitor Job
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Define an SAP Process Monitor Job
machine
Specifies the name of the machine on which the job runs.
sap_process_status
Specifies the SAP process status to monitor (RUNNING, STOPPED, or WAITING).
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
machine
Specifies the name of the machine on which the job runs.
sap_job_name
Specifies the name of the SAP R/3 job to be copied.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
sap_client
Specifies the SAP client within the SAP system.
Default: jco.client.client connection properties parameter, if specified
sap_lang
Specifies a character code representing a valid language for SAP.
Default:
■ EN (The default language is English.)
■ jco.client.lang connection properties parameter, if specified. This parameter
overrides the default type (EN).
sap_rfc_dest
Specifies the destination value for the Remote Function Call (RFC) connection and
gateway information.
Default: sap.default.destination agent parameter, if specified
sap_success_msg
Specifies a string that indicates the job completed successfully. If the string is
found in the job's spool file, the job is considered successfully completed even
if the job fails on the SAP system.
Email the Spool File of a Single Step in an SAP Job
sap_fail_msg=message
(Optional) Specifies a string that indicates the failure of the step. If the string
matches the SAP ABAP output for the step, the step is considered failed even if
the step succeeds on the SAP system.
Note: This keyword does not apply to SAPBDC jobs.
sap_success_msg=message
(Optional) Specifies a string that indicates the success of the step. If the string
matches the SAP ABAP output for the step, the step is considered successfully
completed even if the step fails on the SAP system.
Note: This keyword does not apply to SAPBDC jobs.
scp_remote_dir
Specifies the file's remote source directory (if downloading) or the file's remote
destination directory (if uploading).
scp_remote_name
Specifies the file's source location (if downloading) or the file's destination (if
uploading).
scp_server_name
Specifies a remote server name.
2. (Optional) Specify optional Secure Copy attributes:
■ job_class
■ scp_local_user
■ scp_protocol
■ scp_server_port
■ scp_target_os
■ scp_transfer_direction
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Attributes with Default Values
scp_protocol
Specifies whether the SCP data transfer uses Secure File Transfer Protocol (SFTP) or
regular Secure Copy (SCP).
Default: SFTP
scp_server_port
Specifies the port number of the remote server.
Default: 22
Attributes with Default Values
scp_target_os
Specifies the remote operating system type, which is used to determine the path
separator on the remote system.
Default: UNIX
scp_transfer_direction
Specifies the file transfer direction between the agent computer and the remote
server.
Default: DOWNLOAD
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
SNMP Jobs
The agent supports a built-in SNMP manager capability. You can enable the agent to act
as an SNMP manager to emit and listen for SNMP traps in addition to its other roles. The
agent supports SNMP v1, v2, and v3. After the agent is configured, you can define and
run SNMP job types on the agent.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or
Windows.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Specify a Timeout Limit When you Broadcast the WOL Signal to a MAC
address
This example broadcasts the WOL signal to the subnet identified by the 172.16.255.255
broadcast IP address and the server identified by the 00-1E-4F-C1-0F-FE MAC address.
After the agent sends the Wake on LAN (WOL) signal, the agent pings port 7 at the
172.16.1.101 IP address to ensure it is available. If port 7 becomes available within 5
minutes (300 seconds), the job completes successfully; otherwise, it exceeds the
timeout limit and fails.
insert_job: wol_job
job_type: WOL
machine: agentnme
broadcast_address: 172.16.255.255
mac_address: 00-1E-4F-C1-0F-FE
ping_host: 172.16.1.101
ping_ports: 7
ping_timeout: 300
Web Service Document/Literal lets you call an operation within a web service and pass
parameters to the operation using document/literal style binding. The parameters
represent a flattened view of the XML document the agent constructs.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: WSDOC
Specifies that the job type is Web Service Document/Literal.
machine
Specifies the name of the machine on which the job runs.
endpoint_URL
Specifies the target endpoint address URL.
port_name
Specifies the WSDL port name.
service_name
Specifies the web service name.
Define a Web Service Document/Literal Job
wsdl_operation
Specifies the operation to be invoked.
WSDL_URL
Specifies the URL to the Web Service Description Language (WSDL) of the web
service to invoke.
2. (Optional) Specify optional Web Service Document/Literal attributes.
■ destination_file
■ job_class
■ job_criteria
■ ws_authentication_order
■ ws_conn_domain
■ ws_conn_origin
■ ws_conn_user
■ ws_global_proxy_defaults
■ ws_parameter
■ ws_proxy_domain
■ ws_proxy_host
■ ws_proxy_origin
■ ws_proxy_port
■ ws_proxy_user
■ ws_security
3. (Optional) Specify common attributes that apply to all jobs.
The Web Service Document/Literal job is defined. When the job runs, it calls an
operation within a web service.
Define a Web Service Document/Literal Job
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Invoke a Web Service to List All Amazon Buckets Operation
Suppose that you want to invoke an Amazon web service that lists all your Amazon
"buckets". The URL for the WSDL that describes the web service and its location is
http://s3.amazonaws.com/doc/2006-03-01/AmazonS3.wsdl. The target endpoint
address URL is https://s3.amazonaws.com/soap. The job calls the operation
ListAllMyBuckets within the AmazonS3 web service. When the job invokes the web
service, information about the list of my buckets is passed to the operation. The
ListAllMyBuckets operation assigns different parameter values.
insert_job: execws
job_type: WSDOC
machine: wsagent
endpoint_URL: "https://s3.amazonaws.com/soap"
wsdl_url: "http://s3.amazonaws.com/doc/2006-03-01/AmazonS3.wsdl"
service_name: AmazonS3
port_name: AmazonS3
wsdl_operation: ListAllMyBuckets
ws_proxy_host: 141.202.248.209
ws_proxy_port: 80
ws_proxy_user: causer@tant-a01
ws_proxy_domain: tant-a01
ws_parameter: Name="/ListAllMyBuckets", Value=""
ws_parameter: Name="/ListAllMyBuckets/AWSAccessKeyId", Value="0x0102030405060708"
ws_parameter: Name="/ListAllMyBuckets/Timestamp", Value="2011-08-25T02:24:21"
ws_parameter: Name="/ListAllMyBuckets/Signature", Value="0x0102030405060708" Define a Web
Service RPC/Encoded Job
Define a Web Service RPC/Encoded Job
You can define a Web Service RPC/Encoded job to call an operation within a web
service.
Note: To run these jobs, your system requires CA WA Agent for UNIX, Linux, or Windows
and CA WA Agent for Web Services.
Follow these steps:
1. Insert a job and specify the following attributes in the definition:
job_type: WBSVC
Specifies that the job type is Web Service RPC/Encoded.
machine
Specifies the name of the machine on which the job runs.
target_namespace
Specifies the target namespace used for the names of messages, port type,
binding, and services defined in the WSDL for the web service. Complex data
types such as arrays require the target namespace.
wsdl_operation
Specifies the operation to be invoked.
2. (Optional) Specify optional Web Service RPC/Encoded attributes:
■ destination_file
■ endpoint_URL
■ job_class
■ one_way
■ port_name
■ return_class_name
■ return_namespace
■ return_xml_name
■ service_name
■ success_pattern
■ web_parameter
■ web_user
■ WSDL_URL
Define a Web Service RPC/Encoded Job
470 User Guide
Notes:
■ In a Web Service RPC/Encoded job, if you specify the WSDL_URL attribute but
not the endpoint_URL attribute, you must specify both the service_name and
port_name attributes. For the job to run successfully without the
endpoint_URL attribute, the agent must be running on the same computer as
the application server such as WebLogic or JBoss. If you specify both the
WSDL_URL and endpoint_URL attributes, then the service_name and
port_name attributes are optional.
■ The agent does not support document/literal styles of web services.
3. (Optional) Specify common attributes that apply to all job types.
The Web Service RPC/Encoded job is defined. When the job runs, it calls an
operation within a web service.
Notes:
■ The one_way attribute is set to FALSE by default. If you do not specify this attribute
in your job definition, the job waits for a response after the agent invokes the
operation before completing. You can override this default setting by specifying the
one_way attribute in your job definition.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Get a Company Stock Quote
Suppose that you want to invoke a web service that returns a company stock quote. The
URL for the WSDL that describes the web service and its location is
http://www.webservicex.com/stockquote.asmx?WSDL. The WSDL port name within the
target namespace http://www.webserviceX.NET is StockQuoteSoap. The target
endpoint address URL is http://www.webservicex.com/stockquote.asmx. The job calls
the operation GetQuote within the StockQuote web service. When the job invokes the
web service, the company's stock symbol is passed to the operation. The GetQuote
operation returns a java.lang.String object, which maps to the XML type string in the
return namespace http://www.webserviceX.NET/. When the job completes, the stock
quote for CA is stored as a serialized Java object in the job's spool directory.
Define a Web Service RPC/Encoded Job
insert_job: quote
job_type: WBSVC
machine: wsagent
target_namespace: "http://www.webserviceX.NET/"
service_name: StockQuote
port_name: StockQuoteSoap
wsdl_operation: GetQuote
one_way: FALSE
WSDL_URL: "http://www.webservicex.com/stockquote.asmx?WSDL"
endpoint_URL: "http://www.webservicex.com/stockquote.asmx"
web_parameter: xsd\:string="CA"
return_class_name: java.lang.String
return_xml_name: string
return_namespace: "http://www.webserviceX.NET/"
Example: Validate an Email Address in a Web Service Job
Suppose that you want to invoke a web service that validates an email address. The URL
for the WSDL that describes the web service and its location is
http://www.webservicex.net/ValidateEmail.asmx?wsdl. The job calls the IsValidEmail
operation within the ValidateEmail web service. When the job invokes the web service,
the email address is passed to the operation. If the email address is valid, the operation
returns true and the job completes successfully. If the email address is invalid, the
operation returns false and the job fails.
insert_job: subscribe
job_type: WBSVC
machine: wsagent
target_namespace: "http://www.webserviceX.NET/"
service_name: ValidateEmail
port_name: ValidateEmailSoap
wsdl_operation: IsValidEmail
WSDL_URL: "http://www.webservicex.net/ValidateEmail.asmx?wsdl"
endpoint_URL: "http://www.webservicex.net/ValidateEmail.asmx"
web_parameter: xsd\:string="john.smith@example.com"
return_class_name: java.lang.Boolean
return_xml_name: boolean
return_namespace: "http://www.webservicex.net"
success_pattern: true
More information:
Insert a Job Definition (see page 88)
Attributes with Default Values
472 User Guide
Attributes with Default Values
Attributes that have a default value automatically apply to the job definition. Therefore,
you do not have to specify those attributes in the definition. Your agent administrator
can define some default values on the agent in the agentparm.txt file.
If you specify the attribute in a job definition, it overrides the default.
The following Web Service Document/Literal Job attributes have default values:
ws_global_proxy_defaults
Specifies whether to use the global proxy configuration specified by the proxy
parameters in the agentparm.txt file.
Default: Y (The job uses the global proxy configuration specified by the proxy
parameters in the agentparm.txt file.)
ws_proxy_domain
Specifies the domain for proxy authentication.
Default: http.proxyDomain agent parameter, if specified
ws_proxy_host
Specifies the proxy host name to use for the request.
Default: http.proxyHost agent parameter, if specified
ws_proxy_origin
Specifies the origin host name for proxy authentication.
Default: http.proxyOrigin agent parameter, if specified
ws_proxy_port
Specifies the proxy port to use for the request.
Default: http.proxyPort agent parameter, if specified
ws_proxy_user
Specifies the user name required for proxy authentication.
Default: http.proxyUser agent parameter, if specified
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Attributes with Default Values
Example: Override the Proxy Host, Proxy User, and the Proxy Domain in a Web Service
Document/Literal Job
Several attributes in the following job definition override the default values.
Suppose that the service name and the port name are AmazonS3. In this example,
ws_proxy_host, ws_proxy_port, ws_proxy_user and ws_proxy_domain attributes
override the global proxy defaults specified in the agentparm.txt file. The credentials of
user causer@tant-a01 are used for authorization to the proxy server.
insert_job: execws
job_type: WSDOC
machine: wsagent
endpoint_URL: "https://s3.amazonaws.com/soap"
wsdl_url: "http://s3.amazonaws.com/doc/2006-03-01/AmazonS3.wsdl"
service_name: AmazonS3
port_name: AmazonS3
wsdl_operation: ListAllMyBuckets
ws_proxy_host: 141.202.248.209
ws_proxy_port: 80
ws_proxy_user: causer@tant-a01
ws_proxy_domain: tant-a01
ws_parameter: Name="/ListAllMyBuckets", Value=""
ws_parameter: Name="/ListAllMyBuckets/AWSAccessKeyId", Value="0x0102030405060708"
ws_parameter: Name="/ListAllMyBuckets/Timestamp", Value="2011-08-25T02:24:21"
ws_parameter: Name="/ListAllMyBuckets/Signature", Value="0x0102030405060708"
z/OS Jobs
You can use z/OS jobs to run mainframe workload.
Note: To run these jobs, your system requires CA WA Agent for z/OS.
CA WA Agent for z/OS submits and tracks the z/OS jobs. You can define the following
three types of z/OS jobs:
z/OS Regular
Schedules z/OS jobs.
z/OS Manual
Creates dependencies on z/OS jobs that are submitted outside of the scheduling
manager.
z/OS Data Set Trigger
Creates dependencies on data set activities. You can customize trigger conditions to
define the conditions in which the z/OS Data Set Trigger job completes. You can
specify trigger conditions for the following data set activities:
■ When a data set is created or updated
■ When a specific job, group of jobs, or user ID creates a data set
■ When an explicit data set notification is received (used when the data set
activity does not generate an SMF record)
■ When an FTP file is sent or received successfully
Note: Each data set must have its own individual z/OS Data Set Trigger job. To
create dependencies on multiple data sets, you must create multiple z/OS Data Set
Trigger jobs.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Define a z/OS Data Set Trigger Job
This example triggers when the data set PROD.CICS.FILE1602 is closed (created or
updated).
insert_job: PROD.NIGHTLY
job_type: ZOSDST
machine: ZOS1
zos_dataset: PROD.CICS.FILE1602
owner: zosuser
More information:
Insert a Job Definition (see page 88)
Define a z/OS Data Set Trigger Job
478 User Guide
Attributes with Default Values
Attributes that have a default value automatically apply to the job definition. Therefore,
you do not have to specify those attributes in the definition. Your agent administrator
can define some default values on the agent in the agentparm.txt file.
If you specify the attribute in a job definition, it overrides the default.
The following z/OS Data Set Trigger job attributes have default values:
zos_explicit_dsn
Specifies whether the job monitors for an explicit data set.
Default: FALSE (The job does not monitor for an explicit data set.)
zos_dsn_renamed
Specifies whether the job monitors when a data set is renamed.
Default: N (The job does not monitor when the data set is renamed.)
zos_dsn_updated
Specifies whether the job monitors for updates to a data set.
Default: N (The job does not monitor for updates to the data set.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Define a z/OS Data Set Trigger Job
Monitor Data Set Activity by a User or Job
You can define a z/OS Data Set Trigger job to monitor when a specific job, group of jobs,
or user ID creates a data set. When the specified condition is met, the job completes.
Follow these steps:
1. Define a z/OS Data Set Trigger job (see page 476).
2. Add the following attributes to the job definition:
zos_trigger_type
Specifies whether the job monitors data set activity by a job or a user ID.
zos_trigger_by
Specifies the name of the job or user who performs the data set activity that
triggers the job.
3. Run the job.
The job monitors for data set activity by the specified user or job.
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Example: Restrict the Trigger to Specific Data Sets Created by a Particular User
Suppose that you want the z/OS Data Set Trigger job PROD.PAY_DATA to release its
successors when the user CYB1 creates generation data set USER1.PAYROLL
(USER1.PAYROLL.G-). The agent ZOS1 monitors the data set under user CYBDL01.
insert_job: PROD.PAY_DATA
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: USER1.PAYROLL.G-
zos_trigger_type: zos_user_id
zos_trigger_by: CYB1 Define a z/OS Data Set Trigger Job
480 User Guide
Example: Restrict the Trigger to Specific Data Sets Created by a Particular Job
Suppose that you want a z/OS Data Set Trigger job named PROD.PAY_DATA to release
its successors when job ABC creates generation data set USER1.PAYROLL
(USER1.PAYROLL.G-).The agent ZOS1 monitors the data set under user CYBDL01.
insert_job: PROD.PAY_DATA
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: USER1.PAYROLL.G-
zos_trigger_type: zos_job_name
zos_trigger_by: ABC
Monitor an FTP Transfer on z/OS
You can define a z/OS Data Set Trigger job to monitor when an FTP file is sent or
received successfully. When the specified condition is met, the job completes.
Follow these steps:
1. Define a z/OS Data Set Trigger job (see page 476).
2. Add the zos_explicit_dsn attribute to the job definition using the following syntax:
zos_explicit_dsn: FALSE
3. Add the following attributes:
zos_ftp_direction
Specifies whether the job monitors for an FTP transfer to a remote computer or
from a remote computer.
zos_ftp_host
Specifies the name of the remote computer involved in the FTP transfer. The
data is transferred to or from the local mainframe computer.
zos_ftp_userid
Specifies the FTP user ID used to connect to a remote computer.
4. Run the job.
The job monitors for the specified FTP transfer.
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Define a z/OS Data Set Trigger Job
Example: Monitor for a Data Set Sent to a Remote FTP partner
Suppose that you want the z/OS Data Set Trigger job CYBER.XFER to release its
successors when data set CYBER.XFER.001 is successfully sent from the local mainframe
partner to a remote FTP partner. The agent ZOS1 monitors the FTP transfer under user
CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_ftp_direction: SEND
Example: Restrict Triggering to a Specific Host
Suppose that you want the z/OS Data Set Trigger job CYBER.XFER to release its
successors when a remote FTP partner with IP address 172.16.0.0 successfully transfers
a file creating the data set CYBER.XFER.001. The agent ZOS1 monitors the FTP transfer
under user CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_ftp_direction: RECEIVE
zos_ftp_host: 172.16.0.0
zos_ftp_userid: CYB1 Define a z/OS Data Set Trigger Job
482 User Guide
Example: Restrict Triggering to a Specific Login ID
Suppose that you want the z/OS Data Set Trigger job CYBER.XFER to release its
successors when a remote FTP partner successfully transfers a file creating the data set
CYBER.XFER.001, assuming that the remote FTP partner logged on to the FTP server with
the CYBER005 user ID. The agent ZOS1 monitors the FTP transfer under user CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_ftp_direction: RECEIVE
zos_ftp_host: 172.16.0.0
zos_ftp_userid: CYBER005
Example: Restrict the Trigger to an FTP Transfer from a Specific User ID
This example releases the job's successors when a remote FTP partner successfully
transfers a file creating the data set CYBER.XFER.001, assuming that the user ID prefix of
the local FTP partner is CYB (CYB-). The agent ZOS1 monitors the FTP transfer under user
CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_trigger_type: zos_user_id
zos_trigger_by: CYB-
zos_ftp_direction: RECEIVE
zos_ftp_userid: CYB- Define a z/OS Manual Job
Real Resources
Real resources are system conditions that are directly tied to a physical system (for
example, physical memory). Real resources are predefined to CA Workload Automation
AE and are managed by external resource managers such as CA Automation Suite for
Data Centers. You cannot define or update real resources using CA Workload
Automation AE. If the required resources are not available, the job goes into a RESWAIT
state and is not submitted until the resources are available.
You can specify real resources as dependencies to jobs. A job with resource
dependencies is submitted only when the resources required are available. If the
required resources are not available, the job goes into a RESWAIT state and is not
submitted until the resources are available.
You can specify the following supported real resource types as dependencies:
CPU_IDLE_PCT
Defines the percentage of time over the sample period that the system's CPUs were
idle.
Example: (CPU_IDLE_PCT, VALUE=50, VALUEOP=GT) indicates that the system's
CPUs were idle for at least 50% of the sample period.
Corresponding metric in the CA SystemEDGE agent: cpuTotalIdlePercent
Real Resources
CPU_LOAD_AVG_15MIN
Defines the load average in the last 15 minutes.
Example: (CPU_LOAD_AVG_15MIN, VALUE=50, VALUEOP=LT) indicates that the
load average was less than 50 in the last 15 minutes.
Corresponding metric in the CA SystemEDGE agent: loadAverage15Min
CPU_LOAD_AVG_5MIN
Defines the load average in the last 5 minutes.
Example: (CPU_LOAD_AVG_5MIN, VALUE=50, VALUEOP=LT) indicates that the load
average was less than 50 in hte last 5 minutes.
Corresponding metric in the CA SystemEDGE agent: loadAverage5Min
MEM_INUSE_PCT
Defines the percentage of the system’s active memory that is in use.
Example: (MEM_INUSE_PCT, VALUE=30, VALUEOP=LTE) indicates that 30% or less
of the system's active memory is in use.
Corresponding metric in the CA SystemEDGE agent: memCapacity
SWAP_INUSE_PCT
Defines the percentage of the system’s total swap that is in use.
Example: (SWAP_INUSE_PCT, VALUE=60, VALUEOP=LT) indicates that less than 60%
of the system's total swap is in use.
Corresponding metric in the CA SystemEDGE agent: swapCapacity
SWAP_SPACE_TOTAL
Defines the total swap space (in KB).
Example: (SWAP_SPACE_TOTAL, VALUE=10240, VALUEOP=GTE) indicates that the
total swap space is 10240 KB or more.
Corresponding metric in the CA SystemEDGE agent: totalSwapSpace
SYSTEM_CPU_COUNT
Defines the total number of CPUs that the job requires.
Example: (SYSTEM_CPU_COUNT, VALUEOP=EQ, VALUE=2) indicates that the job
requires a machine with 2 CPUs.
Corresponding metric in the CA SystemEDGE agent: Number of CPUs
SYSTEM_CPU_SPEED
Defines the system clock speed (in MHz) the job requires.
Example: (SYSTEM_CPU_SPEED, VALUEOP=EQ, VALUE=100) indicates that the job
requires a machine with clock speed of 100MHz.
Corresponding metric in the CA ACM agent: CPU Speed
Real Resources
SYSTEM_OS_TYPE and VERSION
Specifies the operating system name and version number that the job requires.
Example: (SYSTEM_OS_TYPE, VALUEOP=EQ, VALUE=AIX, VERSION=5.3) indicates
that the job requires a machine with an AIX 5.3 operating system.
Corresponding metrics in the CA SystemEDGE agent: OS Type/OS Version
SYSTEM_PHYSICAL_MEMORY
Defines the total amount of available physical memory (in MB) that the job
requires.
Example: (SYSTEM_PHYSICAL_MEMORY, VALUEOP=GTE, VALUE=200) indicates that
the job requires a machine with at least 200 MB of physical memory.
Corresponding metric in the CA SystemEDGE agent: Physical Memory
SOFTWARE_NAME and VERSION
Specifies the software and version number that the job requires.
Example: (SYSTEM_SOFTWARE_NAME, VALUEOP=EQ, VALUE=Adaptive Enterprise
Server Sybase, VERSION=15.0) indicates that the job requires a machine that has
Adaptive Enterprise Server Sybase 15.0 installed.
Corresponding metrics in the CA ACM agent: SOFTWARE_NAME/VERSION
The previous examples show the syntax for specifying the resource value in a real
resource dependency definition.
Notes:
■ To use real resource dependencies, you must do the following:
■ Install and configure the CA Automation Suite for Data Centers SDK clients on
the CA Workload Automation AE scheduler and application server machines.
■ Install the CA Automation Suite for Data Centers agents (CA SysEdge and CA
ACM agents) on all agent machines that utilize real resources for load
balancing. You must install the CA ACM agent only if you want to utilize
SOFTWARE and SYSTEM_CPU_SPEED metrics.
■ For more information about configuring CA Workload Automation AE to work with
CA Automation Suite for Data Centers, see the UNIX Implementation Guide or
Windows Implementation Guide.
Virtual Resources
Virtual resources can help you control job execution and can improve your
environment's performance. They represent values that can be quantified, but they are
not directly tied to a physical system. CA Workload Automation AE does not check
whether a virtual resource is an actual device that exists or whether it is a device that is
being used by another process.
You can use virtual resources to prevent jobs from running simultaneously and ensure
that a job is submitted only when the minimum number of resources is available. For
example, you can define a virtual resource to represent the maximum number of
floating product licenses available in your enterprise. Each time a qualified job runs, a
unit of that resource is used. When all the units are used, no more jobs can run.
You can define the following types of virtual resources on CA Workload Automation AE:
■ Depletable
■ Renewable
■ Threshold
A virtual resource can be defined for a specific machine, or it can be defined at the
global level. A resource defined for a specific machine is available to jobs submitted to
that machine. A resource may be defined to more than one specific machine. A resource
at the global level is available to all machines controlled by CA Workload Automation
AE. Global resources can help control workload balancing across all machines.
Note: You can define resources for distributed machines only. Before you can define a
resource on a machine, the machine must already be defined on the database.
You can specify virtual resources as dependencies to jobs. A job with resource
dependencies is submitted only when the resources required are available. If the
required resources are not available, the job goes into a RESWAIT state and is not
submitted until the resources are available.
Virtual resources are associated with corresponding resource pools. When jobs with
virtual resource dependencies run, the used resources are temporarily or permanently
removed from the resource pool, depending on the virtual resource type.
CA Workload Automation AE is the resource manager for virtual resources.
Virtual Resources
Notes:
■ When you force start a job in FAILURE or TERMINATED status that has a virtual
resource dependency with free=Y or free=N and has not released the virtual
resources, the FORCE_STARTJOB event verifies if the job's current status is FAILURE
or TERMINATED and schedules the job using the already held virtual resources.
Before force starting the job, the scheduler does not re-evaluate other resource
dependencies. For more information about the FORCE_STARTJOB event, see the
Reference Guide.
■ When you update a job, you cannot update the resources attribute in the existing
job definition if the job has a resource dependency and has held the resource.
■ Virtual resources are secured using CA EEM (external security mode). The native
security in CA Workload Automation AE does not secure virtual resources. For more
information about securing virtual resources using CA EEM, see the Security Guide.
Depletable Resources
A depletable resource is a consumed resource. When a job that uses this resource is
submitted, the used resource units are permanently removed from the resource pool.
When the resource is completely depleted or jobs require more units than what is
currently available, jobs that need it go into a RESWAIT state and are not submitted until
the resource is available. You can manually replenish the resource using the
update_resource JIL subcommand. After the resource is replenished, other jobs can use
it.
Depletable resources are helpful when you want to represent values that have a limit,
such as the maximum times to run a job. Depletable resources are also helpful when
you want to control how many times a job can run in a specified time period.
Example: Run a Job Only Once a Day
Suppose that a bank wants to post daily transactions to its master database only once a
day at midnight to ensure data integrity and system performance. To run this critical job
only once a day, you can do the following:
1. Define a depletable resource with an amount of 1, as follows:
insert_resource: depletable1
res_type: D
machine: hostname
amount: 1 Virtual Resources
496 User Guide
2. Define the critical job with the following conditions:
■ The job requires one unit of the depletable resource before it can start.
■ The job is scheduled to start at midnight.
The job is defined as follows:
insert_job: ResDepJob
job_type: CMD
command: /tmp/DBIntensiveApp
machine: hostname
owner: root@hostname
resources: (depletable1,QUANTITY=1)
When the job is submitted, one unit of the resource is permanently removed from the
resource pool. If the job fails, CA Workload Automation AE restarts the job (based on
the n_retrys attribute), but the job goes into RESWAIT state because no units of the
resource are available. The RESWAIT state indicates that a potential problem occurred.
You must run the job must manually.
Note: To add additional resources to a depletable resource, use the update_resource
subcommand. For example, the following command adds 15 units to the depletable1
resource:
update_resource: depletable1
machine: hostname
amount: 15
Renewable Resources
A renewable resource is a borrowed resource. When a job that uses this resource is
submitted, the used resource units are temporarily removed from the resource pool.
When the job completes, the resource units are returned to the pool, or the units are
held until they are manually released back to the pool. Renewable resources are helpful
when you want to control jobs that run concurrently or serially.
When the resource is being used, other jobs that need more units than what is currently
available go into a RESWAIT state and are not submitted until the resource is available.
You can change the amount of resource units available using the update_resource JIL
subcommand. After the amount is changed, a greater number of jobs that need the
resource can run concurrently.
Virtual Resources
Example: Control the Maximum Number of Licenses Used
Suppose that your enterprise has 10 floating licenses for a program. Multiple licenses
can be used on one machine, or they can be used on up to 10 machines. At any time,
you want to ensure that the maximum number of licenses used is 10. To control the
maximum number of licenses being used, you can do the following:
1. Define a renewable resource at the global level with an amount of 10, as follows:
insert_resource: r1
res_type: R
amount: 10
2. Define each job that requires the license with the following conditions:
■ The job requires one unit of the renewable resource before it can start.
■ The job frees the renewable resource whether it completes successfully or not.
The job is defined as follows:
insert_job: jr1
command: sleep 500
machine: hostname
resources: (r1,quantity=1, FREE=A)
When a job is submitted, one unit of the resource is temporarily removed from the
resource pool. Because there are only 10 units, only 10 of these jobs can run
simultaneously on any machine in the enterprise. Other jobs that require a license
cannot be submitted because no resources are available. When a job that is running
completes, one unit of the resource is returned to the resource pool. Another job can be
submitted because a unit is now available.
Threshold Resources
A threshold resource is a sizing resource. For example, if the threshold resource is set to
2, CA Workload Automation AE submits the jobs that require 2 or fewer units. Threshold
resources are helpful when you want to define a boundary that controls which jobs are
submitted to run. The used resource units are not removed from the resource pool.
A job that has a dependency on a threshold resource is only submitted if it requires the
available resource units or fewer. Otherwise, the job goes into a RESWAIT state and is
not submitted until the threshold amount is increased. You can change the threshold
amount using the update_resource JIL subcommand. After the amount is changed, the
jobs that meet the threshold can run.
Virtual Resources
498 User Guide
Example: Prevent Jobs from Running When a Critical Resource is Offline
Suppose that multiple jobs read and write to a disk on a machine named mach1. When
the disk needs to be formatted, you want the jobs to stop running. To prevent the jobs
from running when the disk is offline, you can do the following:
1. Define a threshold resource on the mach1 machine with an amount of 1, as follows:
insert_resource: t1
machine: mach1
res_type: T
amount: 1
2. Define each job that reads and writes to the disk and requires one unit of the
threshold resource before it can start, as follows:
insert_job: jt1
command: readnadwritetodisk
machine: mach1
resources: (t1, quantity=1)
3. Define a job named TRIGGER_JOB that resets the threshold amount to 0 to indicate
that the disk is offline. The trigger job runs the update_resource command as
follows:
update_resource: t1
machine: mach1
amount: 0
When the disk is online, the threshold resource amount is 1, so all jobs that need to
read and write to the disk are submitted (the jobs meet the threshold requirement).
When the disk needs to be formatted, you can run TRIGGER_JOB, which resets the
threshold resource amount to 0. All the jobs that need to read and write to the disk go
into a RESWAIT state and are not submitted until the threshold is set to 1.
Define a Virtual Resource
To use virtual resource dependencies in your jobs, you must first add the virtual
resource definition to the database. You can define virtual resources on distributed
machines only.
Follow these steps:
1. Do one of the following:
■ Issue JIL in interactive mode.
■ Open a JIL script in a text editor.
2. Specify the following subcommand and attributes:
insert_resource: resource_name
Specifies the virtual resource to be defined.
amount
Defines the number of units to assign to the virtual resource.
res_type
Specifies the virtual resource type (D for depletable, R for renewable, or T for
threshold).
3. Specify the following additional attribute if you want to define the resource for a
machine:
machine
Specifies the name of the machine to define the virtual resource for. The
machine must already be defined on the database, and the type of the machine
cannot be v, w, or p.
Note: If you do not specify the machine attribute, the resource will be available to
all machines (global level resource).
4. (Optional) Specify the following additional attribute:
description
Defines a free-form text description of the virtual resource.
5. Do one of the following:
■ Enter exit if you are using interactive mode.
■ Redirect the script to the jil command if you are using a script.
The insert_resource subcommand is issued and the specified virtual resource is
defined.
Define a Virtual Resource
500 User Guide
Notes:
■ The virtual resource name must be unique across all resource types.
■ You cannot define the same virtual resource at the machine level and global level.
■ You can define the same virtual resource on multiple machines.
■ For more information about the syntax for the insert_resource subcommand and
related attributes, see the Reference Guide.
Example: Define a Global Depletable Resource
This example defines a virtual depletable resource named glob_res. The machine
attribute is not specified, so the resource is available to all machines.
insert_resource: glob_res
res_type: D
amount: 50
description: "This resource is permanently consumed."
Example: Define a Machine-Level Threshold Resource
This example defines a threshold resource for the unixagent machine. The resource is
assigned 10 units, so only jobs that require 10 or fewer units of this resource are
submitted to the unixagent machine.
insert_resource: threshold_res
res_type: T
machine: unixagent
amount: 10 Update a Virtual Resource
Update a Virtual Resource
You can update the amount and description properties of a virtual resource definition in
the database. Updating the resource amount is helpful when you want to change the
number of jobs that can run concurrently or serially.
Follow these steps:
1. Do one of the following:
■ Issue JIL in interactive mode.
■ Open a JIL script in a text editor.
2. Specify the following subcommand:
update_resource: resource_name
Specifies the virtual resource to be updated. This resource must be defined in
the database.
3. Specify the following additional attribute if the resource is defined for a machine:
machine
Identifies the name of the machine that the virtual resource is defined for.
Note: If you do not specify the machine attribute, CA Workload Automation AE
assumes the resource is a global resource. If the resource is machine-level, but the
machine attribute is not specified, you will get an error.
4. (Optional) Specify the following additional attributes:
amount
Defines the number of units to assign to the virtual resource. The number can
be an absolute value or a relative value.
description
Defines a free-form text description of the virtual resource.
5. Do one of the following:
■ Enter exit if you are using interactive mode.
■ Redirect the script to the jil command if you are using a script.
The update_resource subcommand is issued and the specified virtual resource is
updated.
Update a Virtual Resource
502 User Guide
Notes:
■ You cannot update resource types or machine names using the update_resource
subcommand. To update resource types or machine names, you must delete the
resource and add it to database again with the new properties.
■ For more information about the syntax for the update_resource subcommand and
related attributes, see the Reference Guide.
Example: Update a Machine-Level Virtual Resource
This example updates a virtual resource that is associated with the unixagent machine.
The number of units is changed to 35.
update_resource: mach_res
machine: unixagent
amount: 35
Suppose that the amount attribute is defined as follows:
amount: +20
In this situation, the command adds 20 units to the available resource count. For
example, if the resource already has 35 units, the command adds 20 units and the total
would be 55.
Similarly, suppose that the amount attribute is defined as follows:
amount: -20
If the resource has 35 units, the command removes 20 units and the total would be 15.
Example: Define a Virtual Resource Dependency that Does Not Free the Resources
After Job Completion
This example defines a Command job that has a dependency on a virtual renewable
resource. Before the job can start running, it needs all the units of the renew_res
resource.
insert_job: no_free_job
job_type: CMD
machine: unixagent
command: /u1/procrun.sh
resources: (renew_res, QUANTITY=ALL, free=N)
After the job completes, the units of the renew_res resource are not freed from the job.
To return the units back to the available resource pool, you must issue the following
command:
sendevent -E RELEASE_RESOURCE -J no_free_job
Suppose that the job is defined with the following attribute:
resources: (renew_res, QUANTITY=5, free=Y)
If the job completes successfully, the resource is added back to the resource pool. This is
the default behavior.
Suppose that the job is defined with the following attribute:
resources: (renew_res, QUANTITY=5, free=A)
The resource is released back to the pool unconditionally.
Update Real and Virtual Resource Dependencies in a Job
506 User Guide
Example: Define Real and Virtual Resource Dependencies
This example defines a Command job that has real and virtual resource dependencies.
Before the job can start running, it needs a machine that satisfies all the following
dependencies:
■ 1 unit of the depletable resource named D1
■ 3 units of the threshold resource named T1
■ 4 units of the renewable resource named R1
■ SYSTEM_OS_TYPE is AIX 5.3
■ SYSTEM_PHYSICAL_MEMORY is greater than 2 GB
insert_job: res_dep_job
job_type: CMD
machine: unixagent
command: /u1/procrun.sh
resources: (D1, QUANTITY=1) AND (T1, QUANTITY=3) AND
(R1, QUANTITY=4, FREE=Y) AND
(SYSTEM_OS_TYPE, VALUEOP=EQ, VALUE=AIX, VERSION=5.3) AND
(SYSTEM_PHYSICAL_MEMORY, VALUEOP=GT, VALUE=2048)
Update Real and Virtual Resource Dependencies in a Job
You can update the real and virtual resource dependencies defined in a job.
Follow these steps:
1. Do one of the following:
■ Issue JIL in interactive mode.
■ Open a JIL script in a text editor.
2. Specify the following subcommand and attribute:
update_job: job_name
Specifies the job to update.
resources
Specifies one or more real and virtual resource dependencies to update.
Update Real and Virtual Resource Dependencies in a Job
Job Blobs
Job blobs are associated with an existing CA Workload Automation AE job and are
referenced by the job name. Job blobs can either be created at the time of the job
definition or after the job has been defined. They are deleted when the job is deleted.
There are three types of job blobs, which include the following:
Input
Contains the input data that is reserved for the job to which they are associated in
textual data format.
Output
Stores the program output messages of a running job in textual or binary data
format.
Error
Stores the error messages of a running job in textual or binary data format.
Input Job Blobs
Input blobs are uploaded to the database using JIL. You can insert an input job blob
multiple times. Each time it is inserted, it acquires a new version number.
When the job starts, the most recent version of the job input blob is used. All the earlier
versions of the blob remain in the database until they are manually deleted. If you
delete an input job blob, only the active version of the input job blob is deleted. The
version which was prior to the deleted version becomes the new active version.
When you run a job, the CA Workload Automation AE agent downloads the active
version of job's input blob from the database into a temporary file on the computer.
This file is then passed into the standard input of the program that is executed by the
job. When the job completes, the temporary file containing the input blob data is
deleted. The blob in the database, however, is not deleted and remains as the active
version for subsequent job runs.
Global Blobs
Output and Error Job Blobs
Output and error job blobs store the program output and error messages of a running
job. When you run a job, the CA Workload Automation AE agent creates temporary files
on the computer that are used to capture the standard output and standard error
messages from the program that was executed by the job. After the job has completed
its run, the agent uploads the files containing the output data as blobs into the
database, overwriting the existing files, and deletes the temporary files. An output job
blob can be used as input by another job. An error job blob, on the other hand, cannot
be used as input by another job.
Global Blobs
Global blobs are general purpose blobs in textual or binary data format. Like the CA
Workload Automation AE global variables, they are referenced by a unique name. You
can either upload the global blobs to the database using JIL or they can be uploaded by
the CA Workload Automation AE agent, after a job has completed its run. After a global
blob is created, it is available to any job as input. Global blobs remain in the database
until they are deleted using JIL.
Manage Blobs Using JIL
The following section describes how to use JIL to do the following:
■ Upload blobs to the database
■ Delete blobs from the database
Note: For more information, see the Reference Guide.
Blob Attributes
The following table lists the subcommands and attributes associated with the definition
or destruction of a blob:
Task Subcommands Attributes
Create input job blob insert_job, update_job blob_input or blob_file
Create input job blob insert_blob blob_input or blob_file
Delete job blob delete_blob blob_type Blob Attributes
522 User Guide
Task Subcommands Attributes
Create global blob
insert_glob blob_mode, blob_input, or
blob_file
Delete global blob delete_glob
The blob_input attribute lets you manually input the contents of a blob containing
textual data. The blob_input attribute has the following format:
blob_input: <auto_blobt>textual data</auto_blobt>
Note: The textual data begins immediately after the auto_blobt XML-style open tag and
may span multiple lines. JIL recognizes the end of the textual data when it reads the
auto_blobt XML-style end tag. This implies that the literal character string
</auto_blobt> cannot form part of the blob_input value. If you want to include this
character string as part of the textual blob data, use the blob_file attribute.
The blob_file attribute allows the user to specify the location and name of a file on the
computer that serves as the input job blob or global blob file. The blob_file attribute has
the following format:
blob_file: filename
Note: If the blob_file attribute is used to specify an input job blob through the
insert_job or insert_blob subcommand, the file is interpreted as a text-based file.
Create Input Job Blobs
To create an input job blob in the database using JIL, do the following:
■ Upload an input job blob at the time of the definition of the associated job.
■ Upload an input job blob after you have defined the job.
Note: Input job blobs are referenced by the name of the job.
To create an input job blob at the time of the definition of the associated job, use the
insert_job JIL subcommand and specify either the blob_input or blob_file attributes, as
follows:
insert_job: test_job_with_blob
job_type: cmd
command: sleep 60
machine: juno
owner: jerry@juno
std_in_file: $$blobt
blob_input: <auto_blobt>multi-lined text data for job blob
</auto_blobt>
or
blob_file: /test_job_with_blob_file.txt
To create an input job blob after you have defined the job, use the insert_blob JIL
subcommand and specify either the blob_input or blob_file attributes, as follows:
insert_blob: test_job_with_blob
blob_input: <auto_blobt>multi-lined text data for job blob
</auto_blobt>
or
blob_file: /test_job_with_blob_file.txt
JIL interprets the file name that is specified in the blob_file attribute as a file that
contains the textual data and performs a conversion of the new line character. JIL also
displays the version number of the most recent input job blob.
Delete Job Blobs
524 User Guide
Delete Job Blobs
You can use the JIL delete_blob subcommand to delete the following:
■ Active version of the input job blob
■ Output and error job blobs
You must specify whether to delete the job input or output blob data using the
blob_type attribute.
Note: Job blobs are referenced by the name of the job. JIL displays the version number
of the most recent job input blob.
To delete the most recent version of the input job blob, use the delete_blob JIL
subcommand and specify the blob_type attribute with the value of input, as follows:
delete_blob: test_job_with_blob
blob_type: input
To delete the output and error job blobs, use the delete_blob JIL subcommand and
specify the blob_type attribute with the value of output, as follows:
delete_blob: test_job_with_blob
blob_type: output
Create Global Blobs
You can use the JIL insert_glob subcommand to upload blobs containing textual or
binary data.
As the global blobs are not associated with a job, you must do the following:
■ Provide a unique identifier.
■ Specify the mode of the blob data that is being used in the blob_mode attribute.
Note: If you use the insert_glob JIL subcommand using the same name as an existing
global blob, the blob data is reinserted into the database. In this case, the original blob
data is deleted and the new blob data takes its place.
Delete Global Blobs
To create a global blob containing textual data, use the insert_glob JIL subcommand and
specify the blob_mode attribute with a value of text and either the blob_input or
blob_file attributes, as follows:
insert_glob: my_text_global_blob
blob_mode: text
blob_input: <auto_blobt>multi-lined text data for job blob
</auto_blobt>
or
blob_file: /my_text_global_blob_file.txt
Note: JIL interprets the file name that is specified in the blob_file attribute as a file that
contains textual data and performs a conversion of the new line character.
To create a global blob containing binary data, use the insert_glob subcommand and
specify the blob_mode attribute with a value of binary and the blob_file attribute, as
follows:
insert_glob: my_binary_global_blob
blob_mode: binary
blob_file: /my_binary_global_blob_file
Note: You cannot use the blob_input attribute to create a global blob that contains the
binary data.
Delete Global Blobs
You can use the JIL delete_glob subcommand to delete the existing global blobs.
Note: You must provide a unique identifier because global blobs are not associated with
a job.
To delete a global blob, use the delete_glob JIL subcommand and provide the name of
an existing global blob, as follows:
delete_glob: my_global_blob
Use Blobs in Job Definitions
You can use the std_in_file, std_out_file, and std_err_file attributes of the JIL insert_job,
update_job, or override_job subcommands to reference blobs in addition to files. Based
on the keyword values you specify for these attributes, CA Workload Automation AE
downloads a blob for input or uploads a job’s output as blob to meet the job’s needs.
The keywords are explained in the subsequent sections.
Use Blobs in Job Definitions
526 User Guide
std_in_file Attribute
The keywords that are supported by the std_in_file attribute include the following:
$$blobt
Uses the input job blob of the current job as input and treats the blob data as
textual data.
$$blob.<job name>
Uses the output job blob of the specified job as input and treats the blob data as
binary data.
$$blobt.<job name>
Uses the output job blob of the specified job as input and treats the blob data as
textual data.
$$glob.<global blob name>
Uses the specified global blob as input and treats the blob data as binary data.
$$globt.<global blob name>
Uses the specified global blob as input and treats the blob data as textual data.
Note: You cannot use the keyword $$blob to specify the use of the current job's input
blob.
To define a job that uses the output blob of its previous run as input
1. Define the job so that the job's name is in the std_in_file attribute using either the
$$blob.<job name> or $$blobt.<job name> keyword.
2. Apply a one-time override of the std_in_file attribute, so that the job reads from a
local file on the computer on its first run.
Use Blobs in Job Definitions
std_out_file and std_err_file Attributes
The keywords that are supported by the std_out_file and std_err_file attributes include
the following:
$$blob
Uploads the output or error of the current job as a job blob and treats the data as
binary data.
$$blobt
Uploads the output or error of the current job as a job blob and treats the data as
textual data.
$$glob.<global blob name>
Uploads the output or error of the current job as a global blob with the specified
name and treats the data as binary data.
$$globt.<global blob name>
Uploads the output or error of the current job as a global blob with the specified
name and treats the data as textual data.
Note:
■ You cannot append data to an existing job or global blob.
■ CA Workload Automation AE does not support the use of > or >> character strings
in the std_out_file or std_err_file attributes.
■ Existing blob data is overwritten with the new data after the job run is completed.
Generate Blob Reports Using Autorep
528 User Guide
Generate Blob Reports Using Autorep
You can use the autorep utility to report on and download the input job blobs and global
blobs. To export the job definition using the autorep –J <jobname> -q option includes
exporting all versions of that job’s input blob. If a download path is not specified, the
contents of all input job blobs are displayed along with the job definition. Otherwise,
autorep downloads the input blob to the specified directory and displays the input blob
file names numbered by version along with the job definition. Reports generated against
one or more global blobs are extracted in binary format unless otherwise specified using
the –a command line parameter. If a download path is not specified, autorep downloads
the global blob into a temporary directory.
Options specific to blob and glob data include the following:
-z globname
Specifies a glob name or mask whose contents are to be extracted. ALL may be
specified to extract all globs. Wildcard characters % and _ are also supported.
-a
Specifies that the global blob can be downloaded as textual data.
-f outdir
Specifies the directory name where input job blobs or global blobs are extracted to.
The default value is as follows:
■ UNIX—The /tmp directory.
■ Windows—The directory represented by the environment variable %TEMP%.
Note: For more information about autorep reports, job input, and global blobs, see the
Reference Guide.
Generate Blob Reports Using Autorep
Example: Export Job Definition with Input Blobs
This example uses the autorep command to export a job definition:
autorep -J ALL -q
The output might resemble the following:
insert_job: test_job
job_type: cmd
command: cat
machine: juno
owner: jerry@ca
permission: gx,ge,wx
alarm_if_fail: 1
If the job has one or more input blobs tied to it, in addition to the job definition, the
autorep command extracts each of the job blob definitions, and the output might
resemble the following:
insert_job: test_job_with_blob job_type: cmd
command: cat
machine: juno
owner: jerry@juno
permission:
std_in_file: $$blobt
alarm_if_fail: 1
/* -- test_job_with_blob:insert_blob #1 -- */
insert_blob: test_job_with_blob
blob_input: <auto_blobt>multi-lined text data for job blob 1
</auto_blobt>
/* -- test_job_with_blob:insert_blob #2 -- */
insert_blob: test_job_with_blob
blob_input: <auto_blobt> multi-lined text data for job blob 2
</auto_blobt>
/* -- test_job_with_blob:insert_blob #3 -- */
insert_blob: test_job_with_blob
blob_input: <auto_blobt> multi-lined text data for job blob 3
</auto_blobt>
You can also specify a location to download the blobs using the -f parameter as follows:
autorep -J ALL -q -f /myblobsdir
The output might resemble the following:
insert_job: test_job_with_blob job_type: cmd
command: cat
machine: juno
owner: jerry@juno
permission: Generate Blob Reports Using Autorep
530 User Guide
std_in_file: $$blobt
alarm_if_fail: 1
/* -- test_job_with_blob:insert_blob #1 -- */
insert_blob: test_job_with_blob
blob_file: /myblobsdir/test_job_with_blob_1.txt
/* -- test_job_with_blob:insert_blob #2 -- */
insert_blob: test_job_with_blob
blob_file: /myblobsdir/test_job_with_blob_2.txt
/* -- test_job_with_blob:insert_blob #3 -- */
insert_blob: test_job_with_blob
blob_file: /myblobsdir/test_job_with_blob_3.txt
Example: Generate a Report for All Global Blobs
This example generates a report that downloads the contents of all global blobs to the
location /myblobsdir as binary data:
autorep -z ALL -f /myblobsdir
The report might resemble the following:
Glob Name File Name
____________ _____________________________
MYGLOB /myblobsdir/MYGLOB
REPORT_CHART /myblobsdir/REPORT_CHART
ARCHIVED_DATA /myblobsdir/ARCHIVED_DATA
JOB_SNAPSHOT /myblobsdir/JOB_SNAPSHOT
This example generates a report that downloads the contents of all global blobs to the
location /myblobsdir as text data:
autorep -z ALL -f /myblobsdir -a
The report might resemble the following:
Glob Name File Name
___________ __________________________________
MYGLOB /myblobsdir/MYGLOB.txt
REPORT_CHART /myblobsdir/REPORT_CHART.txt
ARCHIVED_DATA /myblobsdir/ARCHIVED_DATA.txt
JOB_SNAPSHOT /myblobsdir/JOB_SNAPSHOT.txt
Bi-Directional Scheduling
CA Workload Automation AE supports bi-directional scheduling, which lets you start jobs
from remote machines (inbound) or submit jobs on remote machines (outbound).
With inbound job scheduling, CA Workload Automation AE acts as an agent and accepts
job submissions from remote machines or other scheduling managers (such as CA
Jobtrac Job Management and CA Workload Automation SE). The jobs are defined and
run on the CA Workload Automation AE instance that is acting as an agent.
With outbound job scheduling, CA Workload Automation AE acts as a scheduling
manager and sends job submissions to remote machines. The jobs are defined on the CA
Workload Automation AE instance that is acting as a scheduling manager. The jobs run
on the remote machine or other scheduling manager.
CA Workload Automation AE Cross-Instance Job Dependencies
For example, a Linux Oracle instance can initiate jobs in a Windows Microsoft SQL Server
instance, or a Windows Microsoft SQL Server instance can initiate jobs in a Solaris
Oracle instance. You can add additional instances, such as Solaris Sybase, AIX Oracle, or
HP Oracle instance, to the environment.
The CA Workload Automation AE cross-platform interface controls the bi-directional
scheduling mode. You can configure the cross-platform interface to enable the following
modes:
■ Outbound job scheduling
■ Inbound and outbound job scheduling (bi-directional scheduling)
■ No cross-platform scheduling (the default)
Note: There are no restrictions on platforms, event servers, or number of instances
when running in bi-directional scheduling mode.
Multiple CA Workload Automation AE instances are not connected, but they can
communicate with one another. This communication lets you schedule workload across
instances in your enterprise. You can define jobs that have dependencies on jobs
running on other instances (cross-instance job dependencies). A CA Workload
Automation AE job with these dependencies conditionally starts based on the status of
the job on the other instance. In this situation, the local instance scheduler acts as a
client and issues sendevent commands to the external instance. The other instance's
application server processes the sendevent request and stores the dependency request
or status update in its database. You can also manually send events from one instance
to another.
When the status of a job with cross-instance dependencies changes, the scheduler
sends a CHANGE_STATUS event to the remote instance event server while the job in the
local instance runs. The scheduler processes incoming events and stores the status
changes in the ujo_ext_job table on the remote instance event server. The scheduler
evaluates condition dependencies for external jobs based on the stored status.
CA Workload Automation AE Cross-Instance Job Dependencies
The scheduler also sends an equivalent CHANGE_STATUS event to the remote instance
for status changes not resulting from a CHANGE_STATUS event, specifically status
changes resulting from one of the following:
■ Unavailable machine load units, resources or agents prevent a job from running and
the scheduler change the status of the job.
■ The user changes the status by issuing a sendevent command for one of the
following events: JOB_ON_HOLD, JOB_OFF_HOLD, JOB_ON_ICE, JOB_OFF_ICE,
JOB_ON_NOEXEC, JOB_OFF_NOEXEC.
The equivalent CHANGE_STATUS event may also result in changes to job exit codes
stored on the remote instance. This helps ensure that the scheduler accurately
evaluates downstream jobs dependent on the remote jobs, including the job status and
exit code conditions of the dependent jobs.
Notes:
■ The equivalent CHANGE_STATUS event represents the actual status change that
occurs in the local instance, and the event includes text specifying the actual status
change. The remote scheduler log records this information.
■ For more information about the translated status that the local scheduler sends to
the remote instance, see the Administration Guide.
■ Before you can submit jobs on other CA Workload Automation AE instances, you
must define the instances to each other. For more information about configuring
CA Workload Automation AE to support cross-instance scheduling, see the UNIX
Implementation Guide or Windows Implementation Guide.
How Cross-Instance Job Dependencies are Processed
The jobs are entered in the ujo_ext_job and ujo_req_job tables using the following
syntax:
job_name^INSTANCE_NAME
For example, jobB^PRD indicates a job named jobB on the PRD instance.
The use of multiple databases is independent of instances using cross-instance
dependencies. You can have multiple instances that each use dual event servers.
xtype: u
Indicates that CA UJMA is installed with the external scheduling manager or on the
remote machine. CA UJMA can be installed on the mainframe, UNIX, and Windows.
It lets you submit job requests to the remote machine where CA UJMA is installed.
It lets you submit job requests to and receive job submissions from the following
scheduling managers:
■ CA Job Management Option
■ CA Jobtrac Job Management
■ CA Scheduler Job Management
■ CA Workload Automation SE
The CA Workload Automation AE scheduler uses CAICCI to communicate with CA
UJMA.
Note: Unlike CA AutoSys WA Connect Option, CA UJMA does not let you define
cross-instance job dependencies on the mainframe. To define cross-instance job
dependencies on the mainframe, you must install CA AutoSys WA Connect Option
on the same computer as the mainframe scheduling manager.
Creating Cross-Instance Job Dependencies Using CA AutoSys WA Connect Option
xtype: e
Indicates that the external scheduling manager is CA Workload Automation EE. You
can define cross-instance job dependencies.
Note: Bi-directional scheduling is currently not supported between CA Workload
Automation AE and CA Workload Automation EE.
CA Workload Automation AE can also receive job submission requests from a CA UJMA
computer. The job to start must be a job defined on CA Workload Automation AE and
cannot be a command or script. If CA Workload Automation AE receives a job
submission request from the mainframe, the job to run (specified by the SUBFILE
parameter of the mainframe job) must be defined as a valid job on the CA Workload
Automation AE computer.
For the CA Workload Automation AE scheduler to communicate with CA UJMA
computers, the scheduler must convert CA Workload Automation AE-based events to
events that CA UJMA can interpret. Similarly, the CA Workload Automation AE scheduler
must convert events returned from CA UJMA back to events the scheduler can interpret.
The following table lists the CA Workload Automation AE and CA UJMA events:
■ The CA Workload Automation AE scheduler updates the ujo_ext_job table with the
status updates from CA Workload Automation EE.
■ When the CA Workload Automation AE job is deleted or its condition attribute is
changed, an EXTERNAL_DEPENDENCY event is created in the CA Workload
Automation AE database. The event contains the information required to remove
the external job dependency from the ujo_ext_job table.
■ The CA Workload Automation AE scheduler sends a request to CA Workload
Automation EE to deregister the job dependency on the external instance.
The following process occurs when CA Workload Automation AE cannot send status
updates (events) to CA Workload Automation EE:
■ An INSTANCE_UNAVAILABLE alarm is issued.
■ The ujo_asext_config table is updated to indicate that the external instance is
offline.
■ While the job continues to run, all events to be sent to the external instance are
stored in the ujo_ext_event table.
■ The CA Workload Automation AE scheduler periodically tries to connect to CA
Workload Automation EE.
■ When the CA Workload Automation AE scheduler successfully re-connects to CA
Workload Automation EE, all the events are sent to CA Workload Automation EE,
and the events are deleted from the ujo_ext_event table.
The following table lists the CA Workload Automation AE and CA Workload Automation
EE events:
Cross-Platform Scheduling
Cross-platform scheduling lets you schedule and reroute jobs between CA Workload
Automation AE and other machines running on different platforms, including
mainframe.
To use cross-platform scheduling, required components must be installed on the CA
Workload Automation AE computer and on the external machine that CA Workload
Automation AE works with. The scheduling manager or remote machine must also be
defined as an external instance in the CA Workload Automation AE database.
Note: Before you can submit jobs on other scheduling managers, you must activate the
CA Workload Automation AE cross-platform interface and define the scheduling
manager as an external instance on CA Workload Automation AE. For more information
about configuring CA Workload Automation AE to support cross-platform scheduling,
see the UNIX Implementation Guide or Windows Implementation Guide.
The following message indicates that the scheduler has transferred a job to the
cross-platform interface for submission to a CA UJMA computer:
CAUAJM_I_10073 AutoSys --> Cross Platform Interface:
machine=machine_name job_name=job_name
machine_name
Identifies the CA UJMA computer to which the job is being submitted.
job_name
Identifies the CA Workload Automation AE job name as defined to the event server.
Cross-Platform Interface Messages Logged for CA UJMA
The following message indicates that an event status has been received from CA UJMA.
The event status is converted to the appropriate CA Workload Automation AE event
status and inserted in the event server.
CAUAJM_I_40263 EVENTU: event_name
EXITCODE: exitcode/dbcode JOB: job_name
event_name
Identifies one of the following events:
JOBINITU
Indicates that a job has started on a CA UJMA computer.
JOBTERMU
Indicates that a job has completed on a CA UJMA computer.
JOBFAILU
Indicates that a job has failed to start on a CA UJMA computer.
SUBMITU
Indicates that a job has been submitted to CA Workload Automation AE.
exitcode/dbcode
Identifies the actual job exit code returned by CA UJMA.
job_name
Identifies the CA Workload Automation AE job name as defined to the event server.
Define an External Instance
Notes:
■ For CA Workload Automation EE, the xcrypt_type value must match the encryption
type specified in the AGENTDEF data set.
■ For more information about the syntax for the insert_xinst subcommand and
related attributes, see the Reference Guide.
Example: Define a CA Workload Automation EE Instance
This example defines the CA Workload Automation EE instance named CYB to CA
Workload Automation AE. CYB runs on the CYBHOST computer at port 7550. The CM
manager name is unique to this CA Workload Automation EE instance. The CA Workload
Automation AE scheduler communication alias is defined in the AGENTDEF data set on
CA Workload Automation EE. CA Workload Automation EE is also configured to point to
the CA Workload Automation AE computer on the auxiliary listening port.
insert_xinst: CYB
xtype: e
xmanager: CM
xmachine: CYBHOST
xcrypt_type: NONE
xport: 7550
Update an External Instance
You can update an external instance defined in CA Workload Automation AE. The
external instance can be another CA Workload Automation AE instance or a scheduling
manager running on another platform. You can update the instance definition when the
connection information changes. The connection information must be accurate so that
the scheduling managers can communicate with each other.
Follow these steps:
1. Do one of the following:
■ Issue JIL in interactive mode.
■ Open a JIL script in a text editor.
2. Specify the following JIL subcommand:
update_xinst: instance_name Delete an External Instance
550 User Guide
Note: For more information about the syntax for the delete_xinst subcommand, see the
Reference Guide.
Example: Delete a CA Workload Automation EE Instance
This example deletes the definition of the CA Workload Automation EE instance named
CYB.
delete_xinst: CYB
Start a Job on an External CA Workload Automation AE
Instance
CA Workload Automation AE instances are not connected, but they can communicate
with one another. You can send a STARTJOB event directly from one instance to
another. This helps you integrate your workload across CA Workload Automation AE
instances in your enterprise.
To start a job on an external CA Workload Automation AE instance, enter the following
command at the UNIX operating system prompt or the Windows instance command
prompt:
sendevent -E STARTJOB -J job_name -S autoserv
job_name
Specifies a job defined on the autoserv instance.
autoserv
Specifies the instance's unique, capitalized three-character identifier.
Example: ACE
The sendevent command is issued and the job request is submitted on the external CA
Workload Automation AE instance.
Notes:
■ To use the sendevent -S option, the instance from where you issue the sendevent
command must have a client installed for the external instance. For more
information about configuring cross-instance communication, see the UNIX
Implementation Guide or Windows Implementation Guide.
■ For more information about the syntax for the sendevent command and related
attributes, see the Reference Guide.
Define a Job to Run on an External Instance
owner
Specifies the user on the external instance that the job runs under. The owner
must be specified as owner@machine.
CA UJMA Note: The specified owner must have an account on the external CA
UJMA computer. The account must match the owner name exactly, and the
owner (user ID and password) must be defined using the autosys_secure
command.
command
Specifies the job to run on the external instance when all the starting
conditions are met.
JOB_NAME
Specifies the name of the external job that the local job depends on.
Limits: The names of jobs specified as job dependencies between CA Workload
Automation AE and CA AutoSys WA Connect Option must follow these guidelines:
■ The first character of a job name must be an uppercase letter (A-Z), a pound
sign (#), an at sign (@), or a dollar sign ($).
■ The remaining characters in the job name can be any combination of uppercase
letters (A-Z), numbers (0-9), pound signs (#), at signs (@), and dollar signs ($).
■ All letters (A-Z) must be in uppercase.
■ Job names can be up to eight characters in length.
INS
Specifies the name of the external instance that JOB_NAME runs on. The name
must be three uppercase alphanumeric characters. The first character must be a
letter (A-Z).
Notes:
■ You can specify multiple job dependencies in a definition.
■ For detailed information about the syntax for the condition attribute, see the
Reference Guide.
insert_xinst: CCT
xtype: c
xmachine: WACNCTHOST
insert_xinst: NSM
xtype: u
xmachine: NSMHOST Generate a Report on an External Instance
insert_xinst: WAE
xtype: a
xmachine: WAAEHOST
xport: 9001
xcrypt_type: DEFAULT
insert_xinst: WEE
xtype: e
xmachine: WAEEHOST
xport: 7550
xcrypt_type: NONE
xmanager: WAAEMGR
Monitoring Tools
Monitoring workflow helps you to identify problems with the current or predicted
workflow, so that you can resolve those problems. You can use the following CA
Workload Automation AE tools to monitor workflow:
Forecast Reports
Generate reports that display information about the predicted workflow to identify
problems before they occur.
Note: You can also use forecast reports to plan changes to your workflow in a test
environment.
Monitors
Track events to identify problems as they occur.
Browsers
Generate reports that display information about past events to identify recurring
problems.
You can solve problems before they occur or as they occur when you can identify the
issue that is associated with the problem. When you cannot determine the cause of a
problem, notify the administrator.
To solve a problem that you identify in real time using a monitor, correct the associated
issue and restart the job. To address recurring problems or problems with predicted
workflow that you identify using browsers and forecast reports, correct the associated
issues and use monitors to track the progress of the workflow.
Correcting issues that cause jobs to fail requires modifying workflow objects (job
definitions, machine definitions, and calendar object definitions). You can modify
workflow objects only when you have write access to those objects. When you cannot
solve a problem without modifying a workflow object and you do not have write access
to the problematic object, notify the scheduler.
Important! Modifying workflow objects sometimes has unexpected impacts on the rest
of the workflow. We recommend that you plan changes to the workflow in a test
environment before you implement the changes in the live instance.
Run a Monitor or Browser
Notes:
■ You can also use the CA WCC Forecast and Monitoring applications to monitor
workflow. For more information about these applications, see the CA WCC
documentation.
■ You can use the sendevent command to restart a job. You can use jil to update job
or machine definitions and the autocal_asc command to update calendar
definitions. For more information about the sendevent, jil, and autocal_asc
commands, see the Reference Guide.
Run a Monitor or Browser
Monitors and browsers help you identify problems with your workflow by tracking
events in real-time (monitors) or generating reports that display historical information
about events (browsers). For example, the scheduler component automatically restarts
jobs that fail, so examining events that change the status of jobs to RESTART helps
identify problems with specific jobs.
Note: By default, CA Workload Automation AE is configured to specify the date and time
using the "MM/dd/yyyy HH:mm[:ss]" format, but you can configure CA Workload
Automation AE to use a different format by changing the value of the DateFormat
parameter in the configuration file. For more information about the parameters in the
configuration file, see the Administration Guide.
Limits:
■ MM: 01-12
■ dd: 01-31
■ yyyy: 1900-current year
■ HH: 00-23
■ mm: 00-59
■ ss: 00-59
Follow these steps:
1. Open the operating system or instance command prompt:
■ (UNIX) Run the shell that is sourced to use CA Workload Automation AE.
The UNIX operating system command prompt opens. The shell that is sourced
to use CA Workload Automation AE presets all of the environment variables for
the instance.
■ (Windows) Click Start, Programs, CA, Workload Automation AE, Command
Prompt (instance_name).
The CA Workload Automation AE instance command prompt opens. The
command prompt presets all of the environment variables for the instance.
Run a Monitor or Browser
alarm_verif: y|n
(Monitors) Specifies whether the monitor waits for you to acknowledge alarms
that the scheduler issues. This attribute is valid only for monitors that are
defined to track alarms. When you set the value of this attribute to y, you are
prompted to acknowledge any alarms that the scheduler sends.
A monitor is defined to track alarms when the value of the alarms attribute is
set to y or when the value of the all_events attribute is set to y. For monitors
that are defined to prompt you to acknowledge alarms, the monbro utility
pauses, displays the name of the alarm, and issues the following message and
prompts:
Alarm: alarm_name issue MM/dd/yyyy HH:mm:ss Run# run_num
Message Acknowledged by: user_name
Comment:[your_comment]
The utility displays the alarm information and leaves the following two fields
blank. To acknowledge the alarm, enter your user name in the Message
Acknowledged by field. Optionally, you can enter information in the Comment
field (such as "Reported to DB Administrator for follow up").
Important! The monitor cannot resume until you acknowledge the alarm by
entering your user name.
Note: For more information about the monbro utility, see the Reference Guide.
4. Enter the following jil command:
exit
The monitor or browser is inserted into the database, and the jil command prompt
closes.
5. Open the operating system or instance command prompt and enter the following
command:
{monbro -N monbro_name|monbro -N monbro_name -P ss}
-P ss
(Optional, Monitors only) Specifies the frequency, in seconds, at which the
monitor polls for events. The monitor polls for events at the default frequency
when you do not specify this option. The option is not valid with browsers.
Limits: Integers greater than 0
Default: 10
The monitor or browser runs. A monitor polls for events at the specified interval. A
browser generates a report that displays the event information for the specified
period based on the specified event filters.
Run a Monitor or Browser
566 User Guide
Example: Define a Browser
This example defines the browser named job_restarts to generate a report listing all
events that changed the status of a job to RESTART after September 10, 2012 at
midnight.
insert_monbro: job_restarts
mode: browser
restart: y
all_status:n
all_events:n
after_time: "09/10/2012 00:00:00"
Example: Define a Monitor
This example defines the monitor named track_alarms to track alarm events and to
prompt the user to acknowledge all alarms as they occur.
insert_monbro: track_alarms
mode: monitor
alarm: y
all_status: n
all_events: n
alarm_verif: y
Example: Acknowledge an Alarm
This example shows that the operator acknowledged notification of a JOBFAILURE alarm
when the job with run number 33:2 failed at 20:15 29 on 09/24/2012 and that the
operator reported the job failure to the scheduler for follow up and resolution.
Alarm: JOBFAILURE fail 09/20/2012 20:15:29 Run# 33:2
Message Acknowledged by: operator
Comment:Reported to the scheduler for follow up.
Example: Run a Monitor
This example runs the monitor named track_alarms so that it polls the database for
alarm events at 30 second intervals.
monbro -N track_alarms -P 30 Generate a Forecast Report
Generate a Forecast Report
Forecast reports display information about predicted workflow. Forecast reports help
you identify problems with the predicted workflow to resolve them before they occur or
to plan changes in the workflow.
Note: By default, CA Workload Automation AE is configured to specify the date and time
using the "MM/dd/yyyy HH:mm[:ss]" format, but you can configure CA Workload
Automation AE to use a different format by changing the value of the DateFormat
parameter in the configuration file. For more information about the parameters in the
configuration file, see the Administration Guide.
Limits:
■ MM: 01-12
■ dd: 01-31
■ yyyy: 1900-current year
■ HH: 00-23
■ mm: 00-59
■ ss: 00-59
Follow these steps:
1. Open the operating system or instance command prompt:
■ (UNIX) Run the shell that is sourced to use CA Workload Automation AE.
The UNIX operating system command prompt opens. The shell that is sourced
to use CA Workload Automation AE presets all of the environment variables for
the instance.
■ (Windows) Click Start, Programs, CA, Workload Automation AE, Command
Prompt (instance_name).
The CA Workload Automation AE instance command prompt opens. The
command prompt presets all the environment variables for the instance.
Generate a Forecast Report
568 User Guide
2. Enter the following command:
forecast {-M machine_name| -J job_name [-M machine_name]} -F "mm/dd/yyyy HH:MM
[:ss][-T "mm/dd/yyyy HH:MM [:ss]]" [OPTIONS]
-M machine_name| -J job_name [-M machine_name]
Specifies what predicted workflow information the forecast report displays. To
specify predicted workflow for a particular machine, use the -M parameter. To
specify predicted workflow for a particular job, use the -J parameter.
Notes:
■ The report displays predicted workflow for all jobs that are scheduled to
run on the specified machine when you specify the -M parameter alone.
■ The report displays a predicted workflow that lists runs of the specified job
on all machines when you specify the -J parameter alone.
■ The report displays a predicted workflow that lists runs of the specified job
on the specified machine and excludes runs on other machines when you
specify the -J and -M parameters together.
-F "MM/dd/yyyy HH:mm [:ss]"
Specifies that the forecast report predicts workflow starting on the specified
date.
-T "MM/dd/yyyy HH:mm [:ss]"
(Optional) Specifies that the forecast report predicts workflow ending on the
specified date. This option is required only when you want to forecast
workflow for multiple days.
OPTIONS
(Optional) Specifies optional parameters that you can use to control what
information the forecast report displays.
Note: For more information about these optional parameters, see the
Reference Guide.
The command generates a forecast report that displays information about
predicted workflow.
3. (Optional) Depending on the information that you need, repeat the procedure for
other jobs or machines that are defined within the instance.
The command generates additional forecast reports
Chapter 30: Maintaining Highly-
Available Environments
source_server
Defines the name of the source Oracle System ID (for example, AEDB) or
Sybase server name (for example, SourceServer). For Sybase, the source server
name is defined in the interfaces file.
source_db
Defines the source Sybase database (for example, AEDB).
source_userid
Defines the user ID that is used to connect to the source Oracle System ID, or
Sybase server.
Note: On Oracle, use aebadmin as the source user ID.
source_password
Defines the password that corresponds to the user ID that is used to connect to
the source Oracle System ID, or Sybase server.
target_server
Defines the target Oracle System ID (for example, AEDB2), or Sybase server
name (for example, DestinationServer). For Sybase, the target server name is
defined in the interfaces file.
Note: For Oracle, the source server must be different from the target server.
target_db
Defines the target Sybase database (for example, AEDB2).
Note: The autobcpDB script deletes all of the data in the target database and
replaces it with the data in the source database. If you want to save the data in
the target database, archive it before you run the autobcpDB script.
target_userid
Defines the user ID that is used to connect to the target Oracle System ID, or
Sybase server.
Note: On Oracle, use aedbadmin as the target user ID.
target_password
Defines the password that corresponds to the user ID that is used to connect to
the target Oracle System ID, or Sybase server.
How to Maintain Highly-Available Environments
580 User Guide
dump_file
Defines the temporary file that is used in the transfer of data from one
database to the other database.
Note: Specify a file that is local to the computer where this script is running.
oracle_directory
Defines the path to the Oracle home directory.
blk_size
(Optional) Specifies the number of rows that can be inserted from the
dump_file to the destination database at a time.
Default: 5000
Note: The Sybase script uses the default value when you run it in the interactive
mode, or when you do not specify the blk_size value. Do not specify a large value
because the transaction log encounters problems when it becomes too full.
The event servers are synchronized.
9. Restart the server processes for the instance. If you are operating in a
highly-available cluster environment, restart the services on the active node.
a. Open the operating system command prompt, and enter the following
commands:
unisrvcntr start waae_sched.$AUTOSERV
unisrvcntr start waae_server.$AUTOSERV
b. Repeat this action on every server machine in the instance. If you are operating
in a highly-available cluster environment, restart the components on the active
node only.
Note: In highly-available cluster environments, the scheduler and application
server actively execute work on the active node only. The cluster manager
prompts the scheduler or application server on one of the passive nodes to
begin executing tasks only when it detects a failure of the same component on
the active node.
The database is restored.
High-availability is restored. To maintain your highly-available environment, continue
monitoring the scheduler log and recovering from scheduler and database failures when
they occur.
How to Maintain Highly-Available Environments
Recover the Failed Database on Windows
If you are using dual event server mode as your database failover solution and the
scheduler initiates a database rollover, dual event server mode is disabled.
Highly-available cluster environments do not function properly without a
highly-available database. A database rollover does not disable high-availability mode,
but the risk of down-time and data loss increases without a failover solution for your
database.
Operating without a failover solution to the database increases the risk of downtime
and data loss. To mitigate this risk, restore the failed database.
If you are operating with a clustered database and a database failure occurs, some
cluster managers require manual intervention to recover the failed database. In this
case, take one of the following actions:
■ Review messages issued by the cluster manager and database vendor, and follow
the instructions that the messages provide.
■ Consult the documentation for your cluster management software and your
database software, and the instructions for manually recovering from a database
failure.
■ Contact your database or network administrator.
Notes:
■ You can operate with a clustered database only when you have cluster
management software installed and are using a cluster aware database. Some
cluster managers restore a failed database automatically, so no action is required.
In this case, your cluster manager issues messages indicating that the database is
restored.
■ If you have cluster management software installed, we recommend that you set up
a highly-available cluster environment instead of configuring high-availability mode.
If you are using dual event server mode as your database failover solution and the
scheduler rolls over the database, CA Workload Automation AE begins operating in
single event server mode. To return to dual event server mode, recover from the failure
and reconfigure dual event servers.
Follow these steps:
1. Review the scheduler log file to determine the problem that caused the failure.
2. Consult your database software documentation, and follow the instructions for
manually resolving the problem that caused the database failure.
The failed database is recovered, and you can reconfigure dual event servers.
How to Maintain Highly-Available Environments
582 User Guide
3. Log in to CA Workload Automation AE machine in the instance with a client
installation and click Start, Programs, CA, Workload Automation AE, Command
Prompt (instance_name).
The instance command prompt opens.
4. Enter the following command:
sendevent -E STOP_DEMON -v ALL
All server processes that are running in the instance stop.
5. Restore, enable, and reconfigure the failed database (event server).
a. Review the scheduler log file to determine the problem that caused the failure.
b. Consult your database software documentation, and follow the instructions for
manually resolving the problem that caused the database failure.
The status of the failed database changes and you can reconfigure dual event
servers.
c. Click the Event Server icon on the toolbar in any CA Workload Automation AE
Administrator window.
The Event Server - CA Workload Automation AE Administrator window appears.
d. Clear the A Database Rollover Has Occurred check box, verify the event server
configuration settings and make any desired modifications, and then click
Apply.
Important! Ensure that the configuration settings for Event Server 2 are
identical to the configuration settings for Event Server 1.
The failed event server is restored and the configuration settings are saved, but
CA Workload Automation AE does not return to dual event server mode until
you synchronize the event servers.
6. Run the CA Workload Automation AE bulk copy script. The directory and script that
you synchronize the event servers following a database failure are the same as the
directory and script that you use to switch to dual event server mode when you did
not enable dual event servers during installation. The script that you run depends
on your database vendor.
■ Oracle
Open the %AUTOSYS%\dbobj\ORA directory and run the following script:
perl autobcpORA.pl source_server target_server source_userid
source_password target_userid target_password dump_file oracle_directory
■ Sybase
Open the %AUTOSYS%\dbobj\SYB directory and run the following script:
perl autobcpSYB.pl source_server source_db target_server target_db
source_userid source_password target_userid target_password dump_file
blk_size How to Maintain Highly-Available Environments
■ Microsoft SQL Server
Open the %AUTOSYS%\dbobj\MSQ directory and run the following script:
perl autobcpMSQ.pl source_server source_db target_server target_db
source_userid source_password target_userid target_password dump_file
The event servers are synchronized.
7. Restart the server processes for the instance. If you are operating in a
highly-available cluster environment, restart the services on the active node.
a. Click Start, Programs, CA, Workload Automation AE, Administrator.
The Instance - CA Workload Automation AE Administrator window opens.
b. Select an instance from the Instance drop-down list in the Settings pane.
c. Click the Services icon on the toolbar.
A list of the services that are running on the instance appears.
d. Right-click the scheduler service and select Start, then right-click the
application server service and select start.
e. If you are operating in a highly-available cluster environment, restart the
components on the active node only. Otherwise, repeat these actions on every
server machine in the instance. If you are operating in a highly-available cluster
environment, restart the components on the active node only.
Note: In highly-available cluster environments, the scheduler and application
server actively execute work on the active node only. The cluster manager
prompts the scheduler or application server on one of the passive nodes to
begin executing tasks only when it detects a failure of the same component on
the active node.
The database is recovered and CA Workload Automation AE returns to dual event
server mode.
High-availability is restored. To maintain your highly-available environment, continue
monitoring the scheduler log and recovering from scheduler and database failures when
they occur.
z/OS Jobs
You can use z/OS jobs to run mainframe workload.
Note: To run these jobs, your system requires CA WA Agent for z/OS.
CA WA Agent for z/OS submits and tracks the z/OS jobs. You can define the following
three types of z/OS jobs:
z/OS Regular
Schedules z/OS jobs.
z/OS Manual
Creates dependencies on z/OS jobs that are submitted outside of the scheduling
manager.
z/OS Data Set Trigger
Creates dependencies on data set activities. You can customize trigger conditions to
define the conditions in which the z/OS Data Set Trigger job completes. You can
specify trigger conditions for the following data set activities:
■ When a data set is created or updated
■ When a specific job, group of jobs, or user ID creates a data set
■ When an explicit data set notification is received (used when the data set
activity does not generate an SMF record)
■ When an FTP file is sent or received successfully
Note: Each data set must have its own individual z/OS Data Set Trigger job. To
create dependencies on multiple data sets, you must create multiple z/OS Data Set
Trigger jobs.
Notes:
■ Attributes that have a default value automatically apply to the job definitions;
therefore, they are optional. For example, jobs with no specified job type are
defined as command jobs by default. Other optional attributes specify information
that is not required but affects how or when a job runs, such as attributes that
specify scheduling conditions.
■ Some optional attributes are common to all job types but others apply to certain
jobs types only. Optional attributes that apply to all job types are known as
common optional attributes. For more information about common optional
attributes and the values that you can specify for them (including their default
values when applicable), see the Reference Guide.
■ For information about required attributes and job type specific optional attributes,
see the procedure topics that provide instructions for defining jobs.
■ This guide provides instructions for defining jobs interactively. You also create job
definitions in script files and then import them using the jil command or use CA
WCC to define them. For more information about the JIL command and JIL syntax,
see the Reference Guide. For more information about using CA WCC to define the
job, see the CA Workload Control Center Workload Scheduling Guide.
Example: Define a z/OS Data Set Trigger Job
This example triggers when the data set PROD.CICS.FILE1602 is closed (created or
updated).
insert_job: PROD.NIGHTLY
job_type: ZOSDST
machine: ZOS1
zos_dataset: PROD.CICS.FILE1602
owner: zosuser
More information:
Insert a Job Definition (see page 88)
Define a z/OS Data Set Trigger Job
478 User Guide
Attributes with Default Values
Attributes that have a default value automatically apply to the job definition. Therefore,
you do not have to specify those attributes in the definition. Your agent administrator
can define some default values on the agent in the agentparm.txt file.
If you specify the attribute in a job definition, it overrides the default.
The following z/OS Data Set Trigger job attributes have default values:
zos_explicit_dsn
Specifies whether the job monitors for an explicit data set.
Default: FALSE (The job does not monitor for an explicit data set.)
zos_dsn_renamed
Specifies whether the job monitors when a data set is renamed.
Default: N (The job does not monitor when the data set is renamed.)
zos_dsn_updated
Specifies whether the job monitors for updates to a data set.
Default: N (The job does not monitor for updates to the data set.)
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Define a z/OS Data Set Trigger Job
Monitor Data Set Activity by a User or Job
You can define a z/OS Data Set Trigger job to monitor when a specific job, group of jobs,
or user ID creates a data set. When the specified condition is met, the job completes.
Follow these steps:
1. Define a z/OS Data Set Trigger job (see page 476).
2. Add the following attributes to the job definition:
zos_trigger_type
Specifies whether the job monitors data set activity by a job or a user ID.
zos_trigger_by
Specifies the name of the job or user who performs the data set activity that
triggers the job.
3. Run the job.
The job monitors for data set activity by the specified user or job.
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Example: Restrict the Trigger to Specific Data Sets Created by a Particular User
Suppose that you want the z/OS Data Set Trigger job PROD.PAY_DATA to release its
successors when the user CYB1 creates generation data set USER1.PAYROLL
(USER1.PAYROLL.G-). The agent ZOS1 monitors the data set under user CYBDL01.
insert_job: PROD.PAY_DATA
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: USER1.PAYROLL.G-
zos_trigger_type: zos_user_id
zos_trigger_by: CYB1 Define a z/OS Data Set Trigger Job
480 User Guide
Example: Restrict the Trigger to Specific Data Sets Created by a Particular Job
Suppose that you want a z/OS Data Set Trigger job named PROD.PAY_DATA to release
its successors when job ABC creates generation data set USER1.PAYROLL
(USER1.PAYROLL.G-).The agent ZOS1 monitors the data set under user CYBDL01.
insert_job: PROD.PAY_DATA
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: USER1.PAYROLL.G-
zos_trigger_type: zos_job_name
zos_trigger_by: ABC
Monitor an FTP Transfer on z/OS
You can define a z/OS Data Set Trigger job to monitor when an FTP file is sent or
received successfully. When the specified condition is met, the job completes.
Follow these steps:
1. Define a z/OS Data Set Trigger job (see page 476).
2. Add the zos_explicit_dsn attribute to the job definition using the following syntax:
zos_explicit_dsn: FALSE
3. Add the following attributes:
zos_ftp_direction
Specifies whether the job monitors for an FTP transfer to a remote computer or
from a remote computer.
zos_ftp_host
Specifies the name of the remote computer involved in the FTP transfer. The
data is transferred to or from the local mainframe computer.
zos_ftp_userid
Specifies the FTP user ID used to connect to a remote computer.
4. Run the job.
The job monitors for the specified FTP transfer.
Note: For more information about JIL job types and other job definition attributes, the
values that you can specify for those attributes, and JIL syntax, see the Reference Guide.
Define a z/OS Data Set Trigger Job
Example: Monitor for a Data Set Sent to a Remote FTP partner
Suppose that you want the z/OS Data Set Trigger job CYBER.XFER to release its
successors when data set CYBER.XFER.001 is successfully sent from the local mainframe
partner to a remote FTP partner. The agent ZOS1 monitors the FTP transfer under user
CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_ftp_direction: SEND
Example: Restrict Triggering to a Specific Host
Suppose that you want the z/OS Data Set Trigger job CYBER.XFER to release its
successors when a remote FTP partner with IP address 172.16.0.0 successfully transfers
a file creating the data set CYBER.XFER.001. The agent ZOS1 monitors the FTP transfer
under user CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_ftp_direction: RECEIVE
zos_ftp_host: 172.16.0.0
zos_ftp_userid: CYB1 Define a z/OS Data Set Trigger Job
482 User Guide
Example: Restrict Triggering to a Specific Login ID
Suppose that you want the z/OS Data Set Trigger job CYBER.XFER to release its
successors when a remote FTP partner successfully transfers a file creating the data set
CYBER.XFER.001, assuming that the remote FTP partner logged on to the FTP server with
the CYBER005 user ID. The agent ZOS1 monitors the FTP transfer under user CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_ftp_direction: RECEIVE
zos_ftp_host: 172.16.0.0
zos_ftp_userid: CYBER005
Example: Restrict the Trigger to an FTP Transfer from a Specific User ID
This example releases the job's successors when a remote FTP partner successfully
transfers a file creating the data set CYBER.XFER.001, assuming that the user ID prefix of
the local FTP partner is CYB (CYB-). The agent ZOS1 monitors the FTP transfer under user
CYBDL01.
insert_job: CYBER.XFER
job_type: ZOSDST
machine: ZOS1
owner: CYBDL01
zos_dataset: CYBER.XFER.001
zos_trigger_type: zos_user_id
zos_trigger_by: CYB-
zos_ftp_direction: RECEIVE
zos_ftp_userid: CYB- Define a z/OS Manual Job