Job scheduler
From Wikipedia, the free encyclopedia
This article does not cite any references or sources. Please help improve this article by adding citations to reliable sources (ideally, using inline citations). Unsourced material may be challenged and removed. (September 2007) |
A job scheduler is an enterprise software application that is in charge of unattended background executions, commonly known for historical reasons as batch processing.
Synonyms are batch system, Distributed Resource Management System (DRMS), and Distributed Resource Manager (DRM). Today's job schedulers typically provide a graphical user interface and a single point of control for definition and monitoring of background executions in a distributed network of computers. Increasingly job schedulers are required to orchestrate the integration of real-time business activities with traditional background IT processing, across different operating system platforms and business application environments.
Job scheduling should not be confused with process scheduling, which is the assignment of currently running processes to CPUs by the operating system.
Contents |
[edit] Overview
Basic features expected of job scheduler software are:
- Interfaces which helps to define workflows and/or job dependencies
- Automatic submission of executions
- Interfaces to monitor the executions
- Priorities and/or queues to control the execution order of unrelated jobs
If software from a completely different area includes all or some of those features, this software is considered to have job scheduling capabilities.
Most operating system platforms such as Unix and Windows provide basic job scheduling capabilities, for example Cron. Many programs such as DBMS, backup, ERPs, and BPM also include relevant job scheduling capabilities. Operating System (OS) or point program supplied job scheduling will not usually provide the ability to schedule beyond a single OS instance or outside the remit of the specific program. Organizations needing to automate highly complex related and un-related IT workload will also be expecting more advanced features from a job scheduler, such as:
- Real-time scheduling based on external, un-predictable events
- Automatic restart and recovery in event of failures
- Alerting and notification to operations personnel
- Generation of incident reports
- Audit trails for regulatory compliance purposes
These advanced capabilities can be written by in-house developers but are more often provided by solutions from suppliers that specialize in systems management software.
[edit] Main concepts
There are many concepts that are central to almost every job scheduler implementation and that are widely recognized with minimal variations:
- Jobs
- Dependencies
- Job Streams
- Users
Beyond the basic, single OS instance scheduling tools there are two major architectures that exist for Job Scheduling software.
- Master/Agent architecture — the historic architecture for Job scheduling software. The Job Scheduling software is installed on a single machine (Master) while on production machines only a very small component (Agent) is installed that awaits commands from the Master, executes them, and returns the exit code back to the Master.
- Cooperative architecture — a decentralized model where each machine is capable of helping with scheduling and can offload locally scheduled jobs to other cooperating machines. This enables dynamic workload balancing to maximize hardware resource utilization and high availability to ensure service delivery.
[edit] History
Job Scheduling has a long history. Job Schedulers are one of the major components of the IT infrastructure since the early mainframe systems. At first, stacks of punch cards were processed one after the other, hence the term “batch processing.”
From a historical point of view, we can distinguish two main eras about Job Schedulers:
- The mainframe era
- Job Control Language (JCL) on IBM mainframes. Initially based on JCL functionality to handle dependencies this era is typified by the development of sophisticated scheduling solutions forming part of the systems management and automation toolset on the mainframe.
- The open systems era
- Modern schedulers on a variety of architectures and operating systems. With standard scheduling tools limited to such as Cron, the need for mainframe standard job schedulers has grown with the increased adoption of distributed computing environments.
In terms of the type of scheduling there are also distinct eras:
- Batch processing - the traditional date and time based execution of background tasks based on a defined period during which resources were available for batch processing (the batch window). In effect the original mainframe approach transposed onto the open systems environment.
- Event-driven process automation - where background processes cannot be simply run at a defined time, either because the nature of the business demands that workload is based on the occurrence of external events (such as the arrival of an order from a customer or a stock update from a store branch) or because there is no / insufficient batch window.
- Service Oriented job scheduling - recent developments in Service Oriented Architecture (SOA) have seen a move towards deploying job scheduling as a reusable IT infrastructure service that can play a role in the integration of existing business application workload with new Web Services based real-time applications.
[edit] Scheduling
Various schemes are used to decide which particular job to run. Parameters that might be considered include:
- Job priority
- Compute resource availability
- License key if job is using licensed software
- Execution time allocated to user
- Number of simultaneous jobs allowed for a user
- Estimated execution time
- Elapsed execution time
- Availability of peripheral devices
- Occurrence of prescribed events
[edit] Implementations
[edit] Part of operating system installation
- Cron: Unix and Unix-like OS
- Task Scheduler: Microsoft Windows, since Windows 98
- launchd: Mac OS X, since v10.4; Darwin
[edit] Supplementary software
- ActiveBatch Enterprise Job Scheduling and Workload Automation Solution by Advanced Systems Concepts, Inc.
- ASG-Zena for Distributed Workload Management and Process Automation by ASG Software
- ASG-OpsCentral for Centralized Management of Enterprise Scheduling Workloads by ASG Software
- ASG-Zeke for z/OS and VSE Enterprise Event Scheduling by ASG software
- AutoMan by Exspans - Job Scheduling, Console and Event automation, and I/O monitor for z/OS
- Automation Anywhere helps streamline various IT task schedules, complex business processes and batch processing.
- Automation Center by OpsWise - cross-platform solution that's 100% web-based and automates workload on Linux, Windows, UNIX, or Mainframe (z/OS)
- BatchMan by Honico
- CA Autosys Workload Automation - A distributed hosted job scheduler.
- CA dSeries Workload Automation - A distributed hosted job scheduler from Cybermation. Acquired by CA in 2006.
- CA 7 Workload Automation - A mainframe hosted job scheduler
- CA ESP Workload Automation - A mainframe hosted job scheduler from Cybermation. Acquired by CA in 2006.
- Condor High-Throughput Computing System (also known as Condor cycle scavenger), a software framework for coarse-grained distributed parallelization of computationally intensive tasks.
- CONTROL-M by BMC Software
- COSbatch by OSM
- Cronacle by Redwood Software
- Dollar Universe by ORSYP S.A
- [1]Exact JobBOSS Shop Management Software
- Enterprise Job Scheduling Solution by Stonebranch
- Flux, an embeddable or standalone 100% Java-based job scheduler
- Global ECS by Vinzant Software
- Grid MP by Univa UD (formerly United Devices)
- IBM's Tivoli Workload Scheduler from their Tivoli Software Division
- ISE EnterpriseSCHEDULE System by ISE Inc.
- IBM's LoadLeveler
- JAMS by http://www.mvpsi.com
- Job Scheduling Resources
- JobSheduler (Open Source) by SOS-Berlin
- TaskForest
- JobServer, an SOA powered job scheduling platform by Grand Logic, Inc.
- Maui Cluster Scheduler
- Macro Scheduler
- N1 Grid Engine — commercial version of Sun Grid Engine
- NetworkComputer (NC), a commercial job scheduler by Runtime Design Automation
- OAR, an open source resource and job management system
- OpCon/xps by Software and Management Associates
- Open Source Job Scheduler at Sourceforge
- Platform LSF, a commercial computer software job scheduler.
- Portable Batch System, a computer software job scheduler that allocates network resources to batch jobs.
- PTC Scheduler Windows & Unix batch scheduler by PTC Software Ltd
- Quartz Open source job scheduling system. Integrates with J2EE and J2SE applications; ported to .NET as Quartz.NET.
- ROC Maestro for Open Systems by ROC Software
- SAP Central Process Scheduling by Redwood, co-developed by Redwood Software and SAP
- SLURM, developed by LLNL.
- Sun Grid Engine, an open source batch-queuing system, supported by Sun Microsystems.
- TIDAL Enterprise Scheduler by TIDAL Software
- TORQUE Resource Manager, an open source initiative originally based on OpenPBS
- UC4 Workload Automation Suite by UC4 Software GmbH
- Xgrid — Controller within the commercial version by Apple Computer
- Visual TOM by Absyss
[edit] Other distributed command execution software
Tentakel (python), ClusterSSH, dsh, fanout, ghost macro language, mussh shell script, p-run utility, pconsole shell tool, Taktuk scheduller, smux shell multiplexer, rshall, rgang and distribulator among others.