US8490096B2 - Event processor for job scheduling and management - Google Patents

Event processor for job scheduling and management Download PDF

Info

Publication number
US8490096B2
US8490096B2 US10/890,471 US89047104A US8490096B2 US 8490096 B2 US8490096 B2 US 8490096B2 US 89047104 A US89047104 A US 89047104A US 8490096 B2 US8490096 B2 US 8490096B2
Authority
US
United States
Prior art keywords
event
threads
processor
event processor
single process
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US10/890,471
Other versions
US20050022199A1 (en
Inventor
Bradford C. Davis
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
CA Inc
Original Assignee
CA Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by CA Inc filed Critical CA Inc
Priority to US10/890,471 priority Critical patent/US8490096B2/en
Publication of US20050022199A1 publication Critical patent/US20050022199A1/en
Assigned to COMPUTER ASSOCIATES THINK, INC. reassignment COMPUTER ASSOCIATES THINK, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DAVIS, BRADFORD C.
Assigned to CA, INC. reassignment CA, INC. MERGER (SEE DOCUMENT FOR DETAILS). Assignors: COMPUTER ASSOCIATES THINK, INC.
Application granted granted Critical
Publication of US8490096B2 publication Critical patent/US8490096B2/en
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/542Event management; Broadcasting; Multicasting; Notifications
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1479Generic software techniques for error detection or fault masking
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/202Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where processing functionality is redundant
    • G06F11/2023Failover techniques
    • G06F11/2028Failover techniques eliminating a faulty processor or activating a spare
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/202Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where processing functionality is redundant
    • G06F11/2038Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where processing functionality is redundant with a single idle spare processing component
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/202Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where processing functionality is redundant
    • G06F11/2046Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where processing functionality is redundant where the redundant components share persistent storage

Definitions

  • This application relates generally to computer systems, and more particularly to enterprise-wide process scheduling.
  • Event processing and job scheduling systems typically schedule events and jobs on one or more computer nodes. Despite substantial backlog of work to be processed, however, many of the currently existing event processors still underutilize the cpu (central processing unit) and i/o (input/output) resources. Accordingly, an improved event processing and job scheduling system is desirable.
  • Event processor system and method for job scheduling and management applications are provided.
  • the system in one aspect, includes a single process event processor comprising a plurality of threads enabled to handle one or more events.
  • Each of the plurality of threads is asynchronous and has a database connection.
  • the plurality of threads includes at least one or more event processor threads operable to retrieve an event and dispatch an event.
  • the plurality of threads also may include one or more connectivity threads operable to establish communication with one or more agents residing on a node where the event is to be processed.
  • the plurality of threads may further include one or more event handler threads operable to receive the event dispatched by the one or more event processor threads.
  • the one or more event handler threads are further operable to communicate the event to the one or more connectivity threads.
  • the plurality of threads is enabled to handle failover.
  • the method in one aspect, includes providing a single process event processor having a plurality of threads for handling one or more events, enabling each of the plurality of threads to be asynchronous, and enabling each of the plurality of threads to have database connection.
  • the method may further include providing one or more event processor threads operable to retrieve an event and dispatch an event and providing one or more connectivity threads.
  • the one or more connectivity threads are operable to establish communication with one or more agents residing on a node where the event is to be processed.
  • the method may further include providing one or more event handler threads operable to receive the event dispatched by the one or more event processor threads.
  • the one or more event handler threads are operable to communicate the event to the one or more connectivity threads.
  • FIG. 1 is a block diagram illustrating the components of the event processor in one embodiment of the present disclosure.
  • FIG. 2 is a diagram illustrating the components for failover procedure in one embodiment.
  • FIG. 1 is a block diagram illustrating the components of the event processor in one embodiment of the present disclosure.
  • Event processor 101 of the present disclosure in one embodiment is a single multi-threaded event processor. Each thread component shown is asynchronous and has its own database connection in one embodiment.
  • Epx 102 iterates in a tight loop on get_event and dispatches these events to an event handler ehx 104 .
  • Event handler ehx 104 may be arrayed.
  • Box 106 performs the initial processing of box jobs, for example, check and start, and dispatches that result to cnx 108 .
  • the cnx 108 in one embodiment qualifies and starts jobs. For instance, cnx 108 checks one or more conditions on whether a job can be started. Such conditions may include whether a job is waiting for another job to complete, etc.
  • Cnx 108 can be arrayed and may include an xnd 110 thread that communicates with the auto_remote, that is, an agent that runs on each machine or node and processes jobs running on respective machine or node. Cnx 108 may communicate with the auto_remote, for example, by executing the code the start_rem_job.
  • the xnd 110 in one embodiment, performs inetd/auto_remote connectivity and communication, and need not own a d/b (database) connection. Rather, in one embodiment, a messaging transport mechanism may be used to communicate with database software.
  • Psx 112 performs post starting processing, for example, checking whether a process started.
  • Dibs 114 performs the failover algorithm directly against primary and shadow database in one embodiment. This takes the auto_remote and inetd out of the algorithm and reduces a substantial number of potential failure points.
  • inetd refers to a daemon program that listens for connection requests or messages for selected ports and starts server programs to perform the services associated with those ports.
  • Auto_remote refers to agents residing on one or more nodes to run and process a job on the respective nodes. Failover refers to automatically switching to a redundant or standby server, system, or network upon failure or abnormal termination of the currently-active server, system, or network.
  • Log 116 or individual thread dispatches msgs (messages) to an event manager 118 such as the UnicenterTM Event Manager.
  • interactions with databases are optimized and the xnd thread 110 in the cnx 108 are allowed to be independent of the database. Allowing the xnd thread 110 to be independent of the database reduces scenarios where processes are hung up waiting for database server to service them. For instance, processes are blocked on the data server and the data server blocks on i/o.
  • database activity is distributed across each thread where each thread has access to a pool of database connections. Accordingly, an operating system (os) scheduler can find an xnd 110 that is not pinned against the database 124 . The xnd sub-thread of the cnx breaks the logjam and improves job starts.
  • an operating system (os) scheduler can find an xnd 110 that is not pinned against the database 124 . The xnd sub-thread of the cnx breaks the logjam and improves job starts.
  • dividing up the event processor into various components as shown in FIG. 1 a plurality of database transactions can be identified and consolidated. Moreover, redundant and therefore unnecessary database transactions may be eliminated or at least consolidated.
  • the decomposition of the event processor enables queuing between processes (ultimately threads) and allows replacing of several areas of iterative processing with batch processing.
  • jobs 106 job rows are picked up one per transaction.
  • epx 102 s plurality of qualified events routinely build up in the event table but are fetched one per transaction. Both of these situations benefit with the batch processing of rows from those respective tables. This will speed throughput while reducing pressure on the system.
  • the exemplary event processor brings the plurality of processes described above into a single process.
  • the failover and rollover models become easier to implement since the designs are simpler and more robust.
  • Neither the failover nor rollover models need to work in the context of the event processor and/or box iteration, across multiple event processors, through the auto_remote and inetd to get to the database.
  • this is cut out and communication with the database is direct, independent and asynchronous of the other event processor activity.
  • the threads are enabled to communicate with the databases simultaneously.
  • inter-thread communication is simpler and quicker than inter-process communication and threads switch context quicker, reducing pressure on the entire system.
  • the event processor of the present disclosure in one embodiment also improves the database interface.
  • the interface is uniform and allows, for instance, small, shared objects to interface with the various database vendors and thereby substantially reduces the job scheduling system footprint.
  • the interface can also be extended into new database vendors or to accommodate new database vendor releases. Dual server mode performance is improved and made more robust by localizing it within the interface and exploiting parallelism.
  • the event processor of the present disclosure in one embodiment runs under a smaller footprint utilizing the shared database objects. It is a simpler runtime configuration since it is a single process.
  • the failover model is more responsive and more robust as it no longer need to work in the context of the event processor and/or box iteration across multiple event processor processes and through the inetd and auto_remote to get to the database. Dual server performance is enhanced through parallelism and the database rollover model enjoys advantages similar to the failover model. Further, the exemplary event processor processes significantly higher throughput and proportionately fewer cycles are used in both the event processor and data server.
  • Failover model used for the above-described event processor will now be described.
  • a plurality of failure points may be eliminated by a reduction in the number of processes involved in the failover model.
  • the event processor of the present disclosure in one embodiment is a single process that is multi-threaded, there is no event processor to event processor IPC (interprocess communication), no forking, and no child handling.
  • a tiebreaker process is included in one embodiment of the present application and the functionality known as the “dibs file” is put into the database. In one embodiment, the tiebreaker only comes into play in dual server mode.
  • FIG. 2 is a diagram illustrating the components for failover procedure in one embodiment.
  • Level 0 is single server mode. Its configuration includes, for example, of a primary 202 and shadow 204 event processor and a single database 206 .
  • Level 1 introduces the second data server 208 and the tiebreaker 210 process.
  • the tiebreaker is similar to the ‘third machine.’ The tiebreaker machine, for instance, straightens out confusion that may occur between the two data servers. Failover and High Availability are run independently of one another or they can be combined.
  • a component of this model is an ‘accessor’ object which includes a pair of three integer pairs, (pid, time0).
  • the pid is the pid (process identifier) of the accessor.
  • Time0 is the d/b time of the most recent access.
  • references to “primary” and “shadow” refer to a primary event processor and a shadow (backup) event processor respectively.
  • the primary 202 registers its status in the database 206 at a specified cadence.
  • the shadow 204 reads this status at the same cadence and knows that the primary 202 is healthy and that it (shadow) remains a shadow. If the shadow 204 determines that the state of the primary 202 is not ‘up’ it goes into a ‘pending takeover’ state.
  • the shadow 204 rechecks the state of the primary 202 and via a global, turns the primary 202 inactive. Thus if the primary 202 comes back, it will shut itself down. Once the shadow 204 confirms the primary 202 has been set inactive, the shadow 204 takes over.
  • the shadow 204 If the shadow 204 cannot reach the data server 206 , it shuts down. Failure to register the shadow's state sets an alarm in the primary 202 and the primary 202 alerts the operator that the shadow 204 has terminated.
  • level 1 failover in dual server mode in one embodiment. Also referred to as HA/DS, level 1 introduces the second data server 208 and the tiebreaker 210 process.
  • the shadow 204 monitors both data servers 206 208 for the state of the primary 202 . If the primary 202 is ‘down’ according to both data servers 206 208 , the shadow 204 sets the primary 202 inactive and takes over.
  • the shadow 204 can establish 1) the primary 202 e/p has failed to update the secondary data server 208 ; and 2) the shadow 204 cannot connect to the primary data server 206 .
  • tiebreaker 210 residing on a third machine confirms, or fails to confirm, the shadow's perception of the primary.
  • the third machine sets the primary 202 inactive and sets the shadow active 204 .
  • the following object resides in both databases 206 208 .
  • data server data server (d/s) data server (d/s) 0 1 t_0 pid t_0 pid // primary t_0 pid t_0 pid // shadow t_0 pid t_0 pid // ping
  • failover procedure is a thread in each e/p and this thread is the tiebreaker program, which could be extended to a full third failover e/p.
  • the shadow can determine failover based on the information contained in the accessor object at a quick cadence and with few potential failure points.
  • the shadow 204 When the shadow 204 has determined it is ready to take over, it turns on a flag, which shuts down the primary 202 , should the primary 202 attempt to come back.
  • a thread hi-water mark may be established to limit the number of threads the e/p 202 can start, to be configurable by the user.
  • the TEP third e/p
  • job scheduler system is in single server mode.
  • the secondary is the database not in use under single server mode.
  • a pending shutdown state may be established such that all database activity will cease prior to a failover or rollover. This will allow the thread which monitors the data servers to connect/disconnect/reconnect with greatity, eliminating all small time deltas and race conditions which thwart the control necessary to insure database reads and writes are done from the desired database.
  • timeout_interval* number_of_reconnects may be chosen.
  • the CHANGE_STATUS:RUNNING for the box may still need to be shown as in process' (depending on what's going on with the box during shutdown) so that the next time the EP starts it will re-queue the event and finish loading the box. More generally, the system is aware of what state things are left in when threads are shutdown, i.e., is it a recoverable state? In one embodiment, a persistent store on the local machine is not done for EPs because it will be lost in a rollover to shadow.
  • indication of an HA failover is done automatically to, for example, prevent confusion about a failover whose in charge (primary event processor or shadow event processor).
  • HA gets into a pend mode and then connections are restored, a check is performed for any failovers before continuing.
  • a timeout wrapper may be added.
  • the above-described failover method may apply to configurations such as dual-server/high-availability, dual-server alone, high-availability alone.
  • system and method of the present disclosure may be implemented and run on a general-purpose computer.
  • system and method may be implemented as set of computer instructions to be stored on computer memory units and executed on the computer processor.
  • the embodiments described above are illustrative examples and it should not be construed that the present invention is limited to these particular embodiments. Thus, various changes and modifications may be effected by one skilled in the art without departing from the spirit or scope of the invention as defined in the appended claims.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Quality & Reliability (AREA)
  • Multimedia (AREA)
  • Hardware Redundancy (AREA)

Abstract

Event processor system and method for job scheduling and management applications are provided. A single process event processor comprises a plurality of threads enabled to handle one or more events. Each of the plurality of threads is asynchronous and has a database connection.

Description

CROSS-REFERENCE TO RELATED APPLICATIONS
This application claims the benefit of U.S. Provisional Patent Application No. 60/486,505 entitled EVENT PROCESSOR FOR JOB SCHEDULING AND MANAGEMENT APPLICATIONS filed on Jul. 11, 2003, the entire disclosure of which is incorporated herein by reference.
TECHNICAL FIELD
This application relates generally to computer systems, and more particularly to enterprise-wide process scheduling.
BACKGROUND
Event processing and job scheduling systems typically schedule events and jobs on one or more computer nodes. Despite substantial backlog of work to be processed, however, many of the currently existing event processors still underutilize the cpu (central processing unit) and i/o (input/output) resources. Accordingly, an improved event processing and job scheduling system is desirable.
SUMMARY
Event processor system and method for job scheduling and management applications are provided. The system, in one aspect, includes a single process event processor comprising a plurality of threads enabled to handle one or more events. Each of the plurality of threads is asynchronous and has a database connection.
The plurality of threads includes at least one or more event processor threads operable to retrieve an event and dispatch an event. The plurality of threads also may include one or more connectivity threads operable to establish communication with one or more agents residing on a node where the event is to be processed. The plurality of threads may further include one or more event handler threads operable to receive the event dispatched by the one or more event processor threads. The one or more event handler threads are further operable to communicate the event to the one or more connectivity threads. The plurality of threads is enabled to handle failover.
The method, in one aspect, includes providing a single process event processor having a plurality of threads for handling one or more events, enabling each of the plurality of threads to be asynchronous, and enabling each of the plurality of threads to have database connection.
The method may further include providing one or more event processor threads operable to retrieve an event and dispatch an event and providing one or more connectivity threads. The one or more connectivity threads are operable to establish communication with one or more agents residing on a node where the event is to be processed.
The method may further include providing one or more event handler threads operable to receive the event dispatched by the one or more event processor threads. The one or more event handler threads are operable to communicate the event to the one or more connectivity threads.
Further features as well as the structure and operation of various embodiments are described in detail below with reference to the accompanying drawings. In the drawings, like reference numbers indicate identical or functionally similar elements.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram illustrating the components of the event processor in one embodiment of the present disclosure.
FIG. 2 is a diagram illustrating the components for failover procedure in one embodiment.
DETAILED DESCRIPTION
FIG. 1 is a block diagram illustrating the components of the event processor in one embodiment of the present disclosure. Event processor 101 of the present disclosure in one embodiment is a single multi-threaded event processor. Each thread component shown is asynchronous and has its own database connection in one embodiment. Epx 102 iterates in a tight loop on get_event and dispatches these events to an event handler ehx 104. Event handler ehx 104 may be arrayed. Box 106 performs the initial processing of box jobs, for example, check and start, and dispatches that result to cnx 108.
The cnx 108, in one embodiment qualifies and starts jobs. For instance, cnx 108 checks one or more conditions on whether a job can be started. Such conditions may include whether a job is waiting for another job to complete, etc. Cnx 108 can be arrayed and may include an xnd 110 thread that communicates with the auto_remote, that is, an agent that runs on each machine or node and processes jobs running on respective machine or node. Cnx 108 may communicate with the auto_remote, for example, by executing the code the start_rem_job. The xnd 110, in one embodiment, performs inetd/auto_remote connectivity and communication, and need not own a d/b (database) connection. Rather, in one embodiment, a messaging transport mechanism may be used to communicate with database software.
Psx 112 performs post starting processing, for example, checking whether a process started. Dibs 114 performs the failover algorithm directly against primary and shadow database in one embodiment. This takes the auto_remote and inetd out of the algorithm and reduces a substantial number of potential failure points.
Briefly, inetd refers to a daemon program that listens for connection requests or messages for selected ports and starts server programs to perform the services associated with those ports. Auto_remote refers to agents residing on one or more nodes to run and process a job on the respective nodes. Failover refers to automatically switching to a redundant or standby server, system, or network upon failure or abnormal termination of the currently-active server, system, or network. Log 116 or individual thread dispatches msgs (messages) to an event manager 118 such as the Unicenter™ Event Manager.
In one embodiment, interactions with databases are optimized and the xnd thread 110 in the cnx 108 are allowed to be independent of the database. Allowing the xnd thread 110 to be independent of the database reduces scenarios where processes are hung up waiting for database server to service them. For instance, processes are blocked on the data server and the data server blocks on i/o.
In one embodiment of the event processor described in the present application, database activity is distributed across each thread where each thread has access to a pool of database connections. Accordingly, an operating system (os) scheduler can find an xnd 110 that is not pinned against the database 124. The xnd sub-thread of the cnx breaks the logjam and improves job starts.
In one embodiment, dividing up the event processor into various components as shown in FIG. 1, a plurality of database transactions can be identified and consolidated. Moreover, redundant and therefore unnecessary database transactions may be eliminated or at least consolidated.
The decomposition of the event processor enables queuing between processes (ultimately threads) and allows replacing of several areas of iterative processing with batch processing. In boxes 106, job rows are picked up one per transaction. In the epx 102, s plurality of qualified events routinely build up in the event table but are fetched one per transaction. Both of these situations benefit with the batch processing of rows from those respective tables. This will speed throughput while reducing pressure on the system.
The exemplary event processor brings the plurality of processes described above into a single process. Thus, for example, the failover and rollover models become easier to implement since the designs are simpler and more robust. Neither the failover nor rollover models need to work in the context of the event processor and/or box iteration, across multiple event processors, through the auto_remote and inetd to get to the database. In an exemplary embodiment, this is cut out and communication with the database is direct, independent and asynchronous of the other event processor activity. In one embodiment, the threads are enabled to communicate with the databases simultaneously.
Further, there are performance gains made in the consolidation under a single process. The inter-thread communication is simpler and quicker than inter-process communication and threads switch context quicker, reducing pressure on the entire system.
The event processor of the present disclosure in one embodiment also improves the database interface. The interface is uniform and allows, for instance, small, shared objects to interface with the various database vendors and thereby substantially reduces the job scheduling system footprint. The interface can also be extended into new database vendors or to accommodate new database vendor releases. Dual server mode performance is improved and made more robust by localizing it within the interface and exploiting parallelism.
The event processor of the present disclosure in one embodiment runs under a smaller footprint utilizing the shared database objects. It is a simpler runtime configuration since it is a single process. The failover model is more responsive and more robust as it no longer need to work in the context of the event processor and/or box iteration across multiple event processor processes and through the inetd and auto_remote to get to the database. Dual server performance is enhanced through parallelism and the database rollover model enjoys advantages similar to the failover model. Further, the exemplary event processor processes significantly higher throughput and proportionately fewer cycles are used in both the event processor and data server.
Failover model used for the above-described event processor will now be described. In one embodiment, a plurality of failure points may be eliminated by a reduction in the number of processes involved in the failover model. For example, because the event processor of the present disclosure in one embodiment is a single process that is multi-threaded, there is no event processor to event processor IPC (interprocess communication), no forking, and no child handling.
A tiebreaker process is included in one embodiment of the present application and the functionality known as the “dibs file” is put into the database. In one embodiment, the tiebreaker only comes into play in dual server mode.
FIG. 2 is a diagram illustrating the components for failover procedure in one embodiment. In one embodiment, there are two levels of failover, 0 and 1. Level 0 is single server mode. Its configuration includes, for example, of a primary 202 and shadow 204 event processor and a single database 206. Level 1 introduces the second data server 208 and the tiebreaker 210 process. The tiebreaker is similar to the ‘third machine.’ The tiebreaker machine, for instance, straightens out confusion that may occur between the two data servers. Failover and High Availability are run independently of one another or they can be combined.
A component of this model is an ‘accessor’ object which includes a pair of three integer pairs, (pid, time0). The pid is the pid (process identifier) of the accessor. Time0 is the d/b time of the most recent access. The processes described below each access this object and can accomplish the existing failover algorithms given the information in these objects, maintained independently in each data server 206 208 in the case of dual server mode.
The following description applies to level 0, failover in single server mode in one embodiment. In the following description, references to “primary” and “shadow” refer to a primary event processor and a shadow (backup) event processor respectively. The primary 202 registers its status in the database 206 at a specified cadence. The shadow 204 reads this status at the same cadence and knows that the primary 202 is healthy and that it (shadow) remains a shadow. If the shadow 204 determines that the state of the primary 202 is not ‘up’ it goes into a ‘pending takeover’ state. The shadow 204 rechecks the state of the primary 202 and via a global, turns the primary 202 inactive. Thus if the primary 202 comes back, it will shut itself down. Once the shadow 204 confirms the primary 202 has been set inactive, the shadow 204 takes over.
If the shadow 204 cannot reach the data server 206, it shuts down. Failure to register the shadow's state sets an alarm in the primary 202 and the primary 202 alerts the operator that the shadow 204 has terminated.
The following describes level 1, failover in dual server mode in one embodiment. Also referred to as HA/DS, level 1 introduces the second data server 208 and the tiebreaker 210 process. The shadow 204 monitors both data servers 206 208 for the state of the primary 202. If the primary 202 is ‘down’ according to both data servers 206 208, the shadow 204 sets the primary 202 inactive and takes over.
It is possible that the shadow 204 can establish 1) the primary 202 e/p has failed to update the secondary data server 208; and 2) the shadow 204 cannot connect to the primary data server 206.
Now two independent instances may be allowed to run. Given that potential, the tiebreaker 210 residing on a third machine confirms, or fails to confirm, the shadow's perception of the primary.
If the tiebreaker 210 confirms a break between primary e/p 202 and primary data server 206, the third machine sets the primary 202 inactive and sets the shadow active 204.
The following object resides in both databases 206 208.
data server (d/s) data server (d/s)
0 1
t_0 pid t_0 pid // primary
t_0 pid t_0 pid // shadow
t_0 pid t_0 pid // ping
In one embodiment, failover procedure is a thread in each e/p and this thread is the tiebreaker program, which could be extended to a full third failover e/p.
The following pseudo code illustrates a failover thread in one embodiment.
FailoverThread( ) {
for (;;) {
for (j=0;j<2;j++) {
for (n=0;n<3;n++) {
machine(n)  {
calls d/s_((j+1)%2)
posts t_0 next to its pid space
gets a copy of the entire accessor object
posts the entire object to d/s_(j%2)
posts t_0 next to its pid space
sleep (heartbeat)
}
}
}
}
}
If a d/s_j is unavailable, that side of the object is not changed and is apparent when the object is read from d/s, which is available.
The shadow can determine failover based on the information contained in the accessor object at a quick cadence and with few potential failure points.
When the shadow 204 has determined it is ready to take over, it turns on a flag, which shuts down the primary 202, should the primary 202 attempt to come back. In addition, a thread hi-water mark may be established to limit the number of threads the e/p 202 can start, to be configurable by the user. In one embodiment the TEP (third e/p) should not update the secondary database once a failover has occurred, and job scheduler system is in single server mode. The secondary is the database not in use under single server mode.
A pending shutdown state may be established such that all database activity will cease prior to a failover or rollover. This will allow the thread which monitors the data servers to connect/disconnect/reconnect with impunity, eliminating all small time deltas and race conditions which thwart the control necessary to insure database reads and writes are done from the desired database.
In addition, the time interval in which an EP is considered missing, for example, timeout_interval* number_of_reconnects, may be chosen.
In one embodiment, if a box is loaded and then a shutdown is received, the CHANGE_STATUS:RUNNING for the box may still need to be shown as in process' (depending on what's going on with the box during shutdown) so that the next time the EP starts it will re-queue the event and finish loading the box. More generally, the system is aware of what state things are left in when threads are shutdown, i.e., is it a recoverable state? In one embodiment, a persistent store on the local machine is not done for EPs because it will be lost in a rollover to shadow.
In another embodiment, indication of an HA failover is done automatically to, for example, prevent confusion about a failover whose in charge (primary event processor or shadow event processor). When HA gets into a pend mode and then connections are restored, a check is performed for any failovers before continuing. A timeout wrapper may be added. The above-described failover method may apply to configurations such as dual-server/high-availability, dual-server alone, high-availability alone.
The system and method of the present disclosure may be implemented and run on a general-purpose computer. For example, the system and method may be implemented as set of computer instructions to be stored on computer memory units and executed on the computer processor. The embodiments described above are illustrative examples and it should not be construed that the present invention is limited to these particular embodiments. Thus, various changes and modifications may be effected by one skilled in the art without departing from the spirit or scope of the invention as defined in the appended claims.

Claims (12)

I claim:
1. An event processor system, comprising:
a database;
a single process event processor configured to retrieve a job from the database and generate a message to schedule the job on a computer node, the single process event processor comprising a plurality of threads enabled to handle an event, each of the plurality of threads is connected to the database and executes asynchronously, wherein the generated message is associated with the event; and
wherein the plurality of threads comprises:
one or more event processor threads configured to retrieve the event and dispatch the event;
one or more connectivity threads configured to establish communication with one or more agents residing on a node where the event is to be processed; and
one or more event handler threads configured to receive the event dispatched by the one or more event processor threads, the one or more event handler threads further operable to communicate the event to the one or more connectivity threads.
2. The system of claim 1, wherein the plurality of threads are enabled to handle failover.
3. The system of claim 1, further including a shadow event processor used for failover.
4. The system of claim 1, wherein the system further includes dual data servers and a tie breaker for handling failover between a primary event processor and a secondary failover event processor.
5. An event processor method, comprising:
using a single process event processor, to retrieve one or more jobs from a database, the single process event processor comprising a plurality of threads to handle an event;
asynchronously executing each of the plurality of threads;
connecting each of the plurality of threads to the database;
generating a message to schedule the one or more jobs on one or more computer nodes, wherein the generated message associated with the event; and
wherein the plurality of threads comprises one or more event processor threads, one or more connectivity threads, and one or more event handler threads, and further comprising:
using the one or more event processor threads of the single process event processor to retrieve the event and dispatch the event; and
using the one or more connectivity threads of the single process event processor to establish communication with one or more agents residing on a node where the event is to be processed; and
using the one or more event handler threads of the single process event processor to receive the event dispatched by the one or more event processor threads, and communicate the event to the one or more connectivity threads.
6. The method of claim 5, further including:
using the plurality of threads to handle failover.
7. A non-transitory computer-readable medium storing program instructions executable by a processor to perform a method comprising:
using a single process event processor to retrieve one or more jobs from a database, the single process event processor comprising a plurality of threads to handle an event;
asynchronously executing each of the plurality of threads;
connecting each of the plurality of threads to the database;
generating a message to schedule the one or more jobs on one or more computer nodes, wherein the generated message is associated with the event; and
wherein the plurality of threads comprises an event processor thread, a connectivity thread, and an event handler thread, and further comprising
using the event processor thread of the single process event processor to retrieve the event and dispatch the event; and
using the connectivity thread of the single process event processor to establish communication with an agent residing on a node where the event is to be processed; and
using the event handler thread of the single process event processor to receive the event dispatched by the event processor thread, and communicate the event to the connectivity thread.
8. The program storage device of claim 7, wherein the method further comprises:
allowing the plurality of threads to handle failover.
9. An event processor system for job scheduling and management applications, comprising:
computer memory encoded with a program of instructions, the program of instructions, when executed by a computer, being operable to cause a single process event processor operable to retrieve one or more jobs from a database and generate a message to schedule the one or more jobs on one or more computer nodes, the single process event processor comprising a plurality of threads enabled to handle an event, each of the plurality of threads executes asynchronously and is connected to the database, wherein the generated message is associated with the event; and
wherein the plurality of threads includes at least:
one or more event processor threads operable to retrieve the event and dispatch the event;
one or more connectivity threads operable to establish communication with one or more agents residing on a node where the event is to be processed;
one or more event handler threads operable to receive the event dispatched by the one or more event processor threads, the one or more event handler threads further operable to communicate the event to the one or more connectivity threads.
10. The system of claim 9, wherein the plurality of threads are enabled to handle failover.
11. The system of claim 9, further including a shadow event processor used for failover.
12. The system of claim 9, wherein the system further includes dual data servers and a tie breaker for handling failover between a primary and a secondary failover event processors.
US10/890,471 2003-07-11 2004-07-12 Event processor for job scheduling and management Active 2029-06-25 US8490096B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/890,471 US8490096B2 (en) 2003-07-11 2004-07-12 Event processor for job scheduling and management

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US48650503P 2003-07-11 2003-07-11
US10/890,471 US8490096B2 (en) 2003-07-11 2004-07-12 Event processor for job scheduling and management

Publications (2)

Publication Number Publication Date
US20050022199A1 US20050022199A1 (en) 2005-01-27
US8490096B2 true US8490096B2 (en) 2013-07-16

Family

ID=34079237

Family Applications (1)

Application Number Title Priority Date Filing Date
US10/890,471 Active 2029-06-25 US8490096B2 (en) 2003-07-11 2004-07-12 Event processor for job scheduling and management

Country Status (3)

Country Link
US (1) US8490096B2 (en)
EP (1) EP1652117A4 (en)
WO (1) WO2005008546A1 (en)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070214457A1 (en) * 2006-03-10 2007-09-13 Prabhakar Goyal System and method for automated recovery of data in a batch processing system
US7464293B2 (en) * 2006-03-10 2008-12-09 Yahoo! Inc. System and method for automated recovery after an error in a batch processing system caused by malformatted or unsupported data
US20070214142A1 (en) * 2006-03-10 2007-09-13 Prabhakar Goyal System and method for providing transaction support across a plurality of data structures
US7904435B2 (en) * 2006-03-10 2011-03-08 Yahoo! Inc. System and method for resource lock acquisition and reclamation in a network file system environment
US8719080B2 (en) * 2006-05-20 2014-05-06 Clear Channel Management Services, Inc. System and method for scheduling advertisements
US11880418B2 (en) * 2018-10-16 2024-01-23 Open Text Sa Ulc Real-time monitoring and reporting systems and methods for information access platform

Citations (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5928323A (en) 1996-05-30 1999-07-27 Sun Microsystems, Inc. Apparatus and method for dynamically generating information with server-side software objects
US5974443A (en) 1997-09-26 1999-10-26 Intervoice Limited Partnership Combined internet and data access system
US6012081A (en) * 1996-07-03 2000-01-04 Siemens Aktiengesellschaft Service and event synchronous/asynchronous manager
US6185609B1 (en) * 1997-10-24 2001-02-06 Sun Microsystems, Inc. Method, apparatus and program to provide client access to a management information service residing on a server in a computer network system
US6289334B1 (en) 1994-01-31 2001-09-11 Sun Microsystems, Inc. Apparatus and method for decomposing database queries for database management system including multiprocessor digital data processing system
US20020052954A1 (en) * 2000-04-27 2002-05-02 Polizzi Kathleen Riddell Method and apparatus for implementing a dynamically updated portal page in an enterprise-wide computer system
US6433795B1 (en) 1996-11-08 2002-08-13 America Online, Inc. System for integrating an on-line service community with a foreign service
US6542920B1 (en) 1999-09-24 2003-04-01 Sun Microsystems, Inc. Mechanism for implementing multiple thread pools in a computer system to optimize system performance
US20030154404A1 (en) 2001-08-14 2003-08-14 Smartpipes, Incorporated Policy engine for modular generation of policy for a flat, per-device database
US6694362B1 (en) * 2000-01-03 2004-02-17 Micromuse Inc. Method and system for network event impact analysis and correlation with network administrators, management policies and procedures
US6721765B2 (en) 2002-07-02 2004-04-13 Sybase, Inc. Database system with improved methods for asynchronous logging of transactions
US6725213B1 (en) * 1999-10-29 2004-04-20 Oracle International Corporation Method and mechanism for providing external procedures to a database system
US6782424B2 (en) * 2002-08-23 2004-08-24 Finite State Machine Labs, Inc. System, method and computer program product for monitoring and controlling network connections from a supervisory operating system
US6859824B1 (en) * 2000-06-30 2005-02-22 Hitachi, Ltd. Storage system connected to a data network with data integrity
US20050076106A1 (en) * 2003-09-23 2005-04-07 Jesse Hummer Asynchronous information retrieval
US7028303B2 (en) * 1999-09-17 2006-04-11 International Business Machines Corporation Method, system, and program for processing a job in an event driven workflow environment
US7028225B2 (en) * 2001-09-25 2006-04-11 Path Communications, Inc. Application manager for monitoring and recovery of software based application processes

Patent Citations (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6289334B1 (en) 1994-01-31 2001-09-11 Sun Microsystems, Inc. Apparatus and method for decomposing database queries for database management system including multiprocessor digital data processing system
US5928323A (en) 1996-05-30 1999-07-27 Sun Microsystems, Inc. Apparatus and method for dynamically generating information with server-side software objects
US6012081A (en) * 1996-07-03 2000-01-04 Siemens Aktiengesellschaft Service and event synchronous/asynchronous manager
US6433795B1 (en) 1996-11-08 2002-08-13 America Online, Inc. System for integrating an on-line service community with a foreign service
US5974443A (en) 1997-09-26 1999-10-26 Intervoice Limited Partnership Combined internet and data access system
US6185609B1 (en) * 1997-10-24 2001-02-06 Sun Microsystems, Inc. Method, apparatus and program to provide client access to a management information service residing on a server in a computer network system
US7028303B2 (en) * 1999-09-17 2006-04-11 International Business Machines Corporation Method, system, and program for processing a job in an event driven workflow environment
US6542920B1 (en) 1999-09-24 2003-04-01 Sun Microsystems, Inc. Mechanism for implementing multiple thread pools in a computer system to optimize system performance
US6725213B1 (en) * 1999-10-29 2004-04-20 Oracle International Corporation Method and mechanism for providing external procedures to a database system
US20050027845A1 (en) * 2000-01-03 2005-02-03 Peter Secor Method and system for event impact analysis
US6694362B1 (en) * 2000-01-03 2004-02-17 Micromuse Inc. Method and system for network event impact analysis and correlation with network administrators, management policies and procedures
US20020052954A1 (en) * 2000-04-27 2002-05-02 Polizzi Kathleen Riddell Method and apparatus for implementing a dynamically updated portal page in an enterprise-wide computer system
US6859824B1 (en) * 2000-06-30 2005-02-22 Hitachi, Ltd. Storage system connected to a data network with data integrity
US20030154404A1 (en) 2001-08-14 2003-08-14 Smartpipes, Incorporated Policy engine for modular generation of policy for a flat, per-device database
US7028225B2 (en) * 2001-09-25 2006-04-11 Path Communications, Inc. Application manager for monitoring and recovery of software based application processes
US6721765B2 (en) 2002-07-02 2004-04-13 Sybase, Inc. Database system with improved methods for asynchronous logging of transactions
US6782424B2 (en) * 2002-08-23 2004-08-24 Finite State Machine Labs, Inc. System, method and computer program product for monitoring and controlling network connections from a supervisory operating system
US20050076106A1 (en) * 2003-09-23 2005-04-07 Jesse Hummer Asynchronous information retrieval

Non-Patent Citations (5)

* Cited by examiner, † Cited by third party
Title
Decision to refuse a European Patent application as issued by the EPO for Application No. 04 778 165.3-2211; Ref.: HCD/J00048473EP, Jul. 18, 2012.
European Patent Office, "Communication," Application No. 04778165.3- 2211/19652117, PCT/HCD/J00048473EP, Oct. 18, 2010, 6 pages.
European Patent Office, "Communication," Application No. 04778165.3- 2211/19652117, PCT/US2004022523, Jun. 30, 2010, 6 pages.
Provision of the minutes in accordance with Rule 124(4) EPC as issued by the EPO for Application No. 04 778 165.3-2211; Ref.: HCD/J00048473EP, Jul. 18, 2012.
Summons to attend oral proceedings pursuant to Rule 115(1) EPC; Reference No. HCD/J00048473EP; Application No./Patent No. 04778165.3-2211/1652117 Mar. 15, 2012.

Also Published As

Publication number Publication date
US20050022199A1 (en) 2005-01-27
EP1652117A1 (en) 2006-05-03
EP1652117A4 (en) 2010-07-28
WO2005008546A1 (en) 2005-01-27

Similar Documents

Publication Publication Date Title
EP1654645B1 (en) Fast application notification in a clustered computing system
US7657527B2 (en) System and method for detecting termination of an application instance using locks
EP0319034B1 (en) Method of recovering failure of online control program
US7941810B2 (en) Extensible and flexible firmware architecture for reliability, availability, serviceability features
US6996745B1 (en) Process for shutting down a CPU in a SMP configuration
US20080195689A1 (en) Subscription-based management and distribution of member-specific state data in a distributed computing system
US9703638B2 (en) System and method for supporting asynchronous invocation in a distributed data grid
US9569224B2 (en) System and method for adaptively integrating a database state notification service with a distributed transactional middleware machine
JP3055566B2 (en) Ordered and reliable maintenance of interprocess relationships in distributed multiprocessors.
US9990239B2 (en) System and method for supporting cooperative notification offloading in a distributed data grid
US8490096B2 (en) Event processor for job scheduling and management
US7480816B1 (en) Failure chain detection and recovery in a group of cooperating systems
US7937611B2 (en) Method, system and machine accessible medium of a reconnect mechanism in a distributed system (cluster-wide reconnect mechanism)
US20020073409A1 (en) Telecommunications platform with processor cluster and method of operation thereof
US8914588B2 (en) System and method for supporting a self-tuning locking mechanism in a transactional middleware machine environment
US6990608B2 (en) Method for handling node failures and reloads in a fault tolerant clustered database supporting transaction registration and fault-in logic
CN116302699B (en) A control method and control system for database parallel playback
JPH01224846A (en) Process space switching control method
JPH10289215A (en) Computer system having current and spare switching function in application program unit and machine readable recording medium recording program
JP3464768B2 (en) Processor device with file load
JPH03111962A (en) Multiprocessor system
CN118540383A (en) POS payment method and terminal based on virtual routing redundancy protocol
CN119988096A (en) A method, device, equipment and medium for fault recovery of securities trading system
Hong et al. Run-time Software Upgrading Framework for Mission Critical Network Applications
JPH06161782A (en) Control system for multiprocessing

Legal Events

Date Code Title Description
AS Assignment

Owner name: COMPUTER ASSOCIATES THINK, INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DAVIS, BRADFORD C.;REEL/FRAME:016635/0340

Effective date: 20040708

AS Assignment

Owner name: CA, INC., NEW YORK

Free format text: MERGER;ASSIGNOR:COMPUTER ASSOCIATES THINK, INC.;REEL/FRAME:030214/0902

Effective date: 20120327

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12