AU2001281598A1 - A network component management system - Google Patents
A network component management systemInfo
- Publication number
- AU2001281598A1 AU2001281598A1 AU2001281598A AU8159801A AU2001281598A1 AU 2001281598 A1 AU2001281598 A1 AU 2001281598A1 AU 2001281598 A AU2001281598 A AU 2001281598A AU 8159801 A AU8159801 A AU 8159801A AU 2001281598 A1 AU2001281598 A1 AU 2001281598A1
- Authority
- AU
- Australia
- Prior art keywords
- execution
- management system
- scheduler
- network
- engine
- 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.)
- Abandoned
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
- G06F9/5072—Grid computing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Mathematical Physics (AREA)
- Telephonic Communication Services (AREA)
- Multi Processors (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Small-Scale Networks (AREA)
- Maintenance And Management Of Digital Transmission (AREA)
- Computer And Data Communications (AREA)
Description
A NETWORK COMPONENT MANAGEMENT SYSTEM
Field of the Invention
The present invention relates to a management system, and in particular to a system for managing a network of nodes or devices wherein the behaviour of individual nodes or devices may be controlled by configurable parameters. More specifically, the system interprets and schedules business rules in order to manage complex systems. For example, the system may be used to manage a telecommunications network, in which individual exchanges represent the configurable nodes.
Background of the Invention
The dynamic management of systems with complex scheduling requirements can be particularly challenging. For example, telecommunications networks need to respond to the rapidly changing demands of the network, and exchange switches need to be continually reconfigured according to dynamically changing loads, physical path availability and route costs. The complex interdependencies and needs of heterogeneous components of a network, and the continual expansion of the network, make this an extremely difficult task. The management of such systems may be defined by a set of business rules which define all of the steps necessary to manage the system. These business rales typically require interactions between a number of diverse systems, including human beings. This makes it difficult to manage business operations in an integrated fashion. Furthermore, it may not be straightforward to change the business rales once they have been defined without reprogramming and coordinating a large number of interacting systems. It is desired, therefore, to provide a system for managing complex systems by scheduling and executing business rales, or at least to provide a useful alternative.
Summary of the Invention
In accordance with the present invention there is provided a management system for a network of components, including: an interface for use in selecting at least one operation to be performed on at least one component of said network, and creating a request that said operation be executed; an engine for processing said request and executing said at least one operation; and a scheduler for scheduling execution of said at least one operation by said engine, based on resource constraints of said network.
The present invention also provides a scheduler for scheduling execution of rule requests by a rules engine, based on resources required by each request and an estimated time that each resource is required.
The present invention also provides a management system for network components, including: a rales engine for executing a rule to perform an operation on at least one of said components, and adapted to save an execution state of the engine during execution of a rule and send a notification concerning resuming execution of the rule; and a scheduler for receiving said notification and causing resumption of execution of said rale at said execution state.
The present invention also provides a management system for a network of components, including: a rales engine for executing a rule defining an operation to be performed on at least one of said components, said engine being adapted to detect process exceptions, and in response, save the state of execution of said rule; and an interface for examining and adjusting said execution state and allowing continued execution of said rule.
The present invention also provides a programming language, stored on computer readable storage medium, for defining business rules, including commands for transmitting and receiving data from network nodes.
The present invention also provides a component management system, including: a rales engine for interpreting change requests and executing component change modules to submit changes to respective components; and a scheduler for controlling the timing of execution of said component change modules.
The present invention also provides a management system for a network of components, including: an engine for processing a request for at least one operation to be performed on at least one component of said network; and a scheduler for scheduling execution of said at least one operation by said engine, based on resource availability.
Brief Description of the Drawings
A preferred embodiment of the present invention is hereinafter described, by way of example only, with reference to the accompanying drawings, wherein:
Figure 1 is a schematic diagram of a preferred embodiment of a management system connected to network components;
Figure 2 is a schematic diagram of the message flow in the management system;
Figure 3 is a schematic diagram of components of the management system; and
Figure 4 is a schematic diagram of components of a real-time part of the system.
Detailed Description of Preferred Embodiments of the Invention
Many real-world systems require the coordination and scheduling of events or processes. The management of such systems can be extremely challenging if the processes execute concurrently and have complex interdependencies.
A prime example of such a system is a telecommunications network. These networks are built around switching systems which accept a variety of different data types and protocols from heterogeneous network nodes and route them to other network nodes. They may also provide data, protocol and signalling conversion, information database services, advanced intelligent network features, and transaction-based accounting and billing. Switching systems should respond rapidly to changing conditions, including data load (eg, to distribute traffic evenly across different data links), link availability, and route cost (eg, selecting the cheapest route to a given destination). Due to changes in the requirements of a network, the network data within exchanges must be continually modified. Within the applicant's network, some 3000 such network data changes are designed and implemented each month, giving rise to approximately 10000 exchange data changes per month. Moreover, telecommunications networks generally include a variety of switching systems from different vendors with different data requirements. Managing these heterogeneous systems in an efficient, reliable and responsive manner is an extremely complex task.
A management system 2, as shown in the Figures, includes a rules engine 4 and a scheduler 6. The rules engine 4 is able to execute a number of business operations defined in a set of rules developed according to a structured business rule language. The engine 4 includes an interpreter 64 to process the rules of the language, and other components described below. The rules engine 4 operates with the scheduler 6, which manages the scheduling of a large, scalable, number of elements 10 and other activities required by the business rales. In conjunction with the rales applied to the rules engine 4, the scheduler 6 allocates time slots for activities and manages priorities where necessary.
For the example of a telecommunications network, network configuration activities may be broken down into a number of steps which can be defined by a set of rales. Rule dependencies can be defined to ensure that configuration activities occur in the correct order, and the configuration process can be automatically executed by the system. Using a rule-based approach to network management provides a number of benefits, including the ability to
easily modify existing rales or add new ones without the need to modify the system itself or to rely on specialised technical staff. On occasions where network field staff need to intervene or control certain events in an interactive manner, this can be accommodated by providing an interactive interface to the rule-based system which allows field staff to interact with or coordinate certain rules.
A Business Management System (BMS) 2 is a software and hardware implementation of the management system which is used to manage a telecommunications network, including network elements 10 in particular switching systems, as shown in Figure 1. The network may use a diverse array of equipment, such as Nortel DMS, Ericsson AXE and Alcatel System 12 switching systems.
The BMS 2 takes design level requests for changes to the network (Job Requests) and automatically performs the business process required to implement the change within the affected exchanges. This involves the generation and loading of the necessary exchange commands, possible interaction with installation staff, and interaction with other systems. Because the business process for implementing network data changes, and even the types of changes that can be performed, are continually evolving, the BMS 2 provides a highly stractured but flexible mechanism for defining the processing performed for each type of network data change (Job Request Type) it supports.
The BMS 2 is based on the rales engine 4 that executes a formally specified business process for each type of network data change. The business process can be changed and refined without changes to the BMS 2 application itself. The rales engine 4 has a range of facilities for interaction with exchanges, the outside world and other information technology (IT) systems, thus giving business process definers considerable flexibility in the definition and refinement of the business process used for each type of network data change (Job Request Type).
The BMS 2 also provides the scheduler 6 that manages the execution of all data changes so that they meet their required by dates, given restrictions on the use of exchange access ports, and the types of data that can be changed at various times during the day.
The BMS 2 provides HTML user interfaces, available over the Internet and/or an Intranet 12, for staff 14 creating Job Requests, and the field staff 28 that interact with the application while performing installation activity. The more complex business rale exception handling interface is supported by a Java applet 'windows' interface.
The specification of the business processes is performed within or outside the BMS 2 with the resulting business rules being loaded into a BMS database 62.
As shown in Figure 2, the BMS 2 has two major components: a client-server system 5 for handling user interaction, and a real-time system 3 that communicates with exchange switches 30 via mediation computer systems 7. The client-server system 5 uses HTML and Java interfaces to communicate over an Intranet or Internet 12 to real-time operators 18, job request operators 14 and rale developers 16, as shown in the table below. The system supports large numbers (eg, 500) of concurrent users by using Java multi-threading and a CORBA logical three-tier architecture. CORBA is also used to interface the client-server system 5 with the real-time system 3.
Table 1
The real-time system 3 includes the rales engine 4 and the scheduler 6, and provides the core functionality for implementation of the rales. The real-time system 3 dynamically responds to a number of external and internal inputs, including job completion, responses from external systems, job scheduling activities, and network elements. The system architecture is based upon a multi-CPU concurrent processing environment, and is designed to run continually.
The business rules which the BMS 2 uses to manage the network are software modules written in a BMS language by rule developers 16. These modules constitute a library of available business operations, and are used to manage the network, and in particular the network elements 10. The BMS 2 manages network elements 10 in response to Job Requests sent to the BMS 2 by the Job Request operators 14. The Job Requests indicate which business operation from the library is to be run, and what data is to be supplied. For example, a business rale for the telecommunications network might be "Add new route between exchanges". The input data for this request would specify which exchanges are affected, the type of route and the number of circuits to be provided by the route, and scheduling information such as the time window in which the operation must be carried out. Concurrency and exclusivity requirements of this rule with other business rales is specified by the business rale as a property of the business rale itself.
The rules engine 4 processes the Job Requests submitted by Job Request operators 14 using data from a variety of sources, including customer data 24, routing data 26, and data from other reference databases 20. When a job is submitted, the scheduler 6 checks whether the constraints of the job can be satisfied. This requires use of the 'estimates', which are estimated times required for particular business operations to complete. If the timing requirements of the job correspond to the minimum lead time requirements of the business
process, then the system accepts and commences execution of the request, using a Job Module.
To provide stractured rale implementation, and to support other operator determined functions, rules are stractured in the BMS 2 as layered 'module' types. The business rale modules contain high level rules for managing the network elements 10, but are not specific to any particular vendor or technology. Job Modules invoke a number of subtasks called Exchange Job Modules (EJ modules) which implement operations specific to individual switches in order to realise the initial job request.
A Job Module commences execution when a request is accepted by the system. Job modules contain the highest level definition of a business process. Typically a Job Module validates the input data for the request (calling validation modules to do so), determines what exchanges (network nodes) should be affected, creates an instance of execution of the business rale module for each affected exchange (network node) specifying what lower level business operation should be performed on each (that is, what Exchange Job module should be executed), waits for these to all reach completion, performs any clean up work and then completes. In the "Add route between exchanges" example, the Job Module would check that the two exchanges exist, check that the route type applies to them, and create an instance of the interpreter 64 to perform the work on each.
Exchange Job (EJ) modules contain the highest level definition of the business process to be performed on an individual exchange (network node). It would typically lodge estimates for each of the necessary resources including exchange access time, then call the required Fundamental Exchange Operation (FEO) Modules to interact with any field operators installing the physical equipment and enter the exchange or node commands to configure the new equipment. EJs lodge their set of resource requirements and necessary data for each at the beginning of the business process, then as the business process executes they ask for each of the resources that they declared they would use at the beginning. If the resource is
available immediately execution continues else it stops and waits for the scheduler to grant the resource.
FEO Modules define the business process for the individual operations that can be performed on the exchanges (network node). These are discrete business level operations that are used by Exchange Job modules to achieve the required business function. For example, Set route supervision, Configure route multiplexer, Enable route, etc.
Support modules define low level support operations that are used by a variety of different modules in the system. These are typically called by many other modules to perform routine tasks, such as extract the 10th parameter from this list of parameters.
Validation Modules are used to perform validation typically on input data, but can be used on any other sort of data within the system. These perform checks on the information and raise an exception if it does not comply with the requirements of the checks performed.
The BMS language provides a flexible and versatile way to implement business processes, including telecommunications support and communication with other jobs and systems that are concurrently running within the BMS system. The BMS language is powerful, yet is sufficiently simple to allow rale developers with basic programming skills to create new modules. The language supports a small number of data types (including arrays), conditional branching, looping, functions, variables and variable substitution into text strings. The latter is important because data is ultimately sent to switches as text strings. The language also supports interactivity, such as the ability to request and accept data from a terminal. The ability to postpone execution of the remainder of a module is also supported. Since the defined business process may encounter an error during execution (for example, the connection to the node fails), the BMS 2 is adapted to allow operators to view the current point of execution within the business process and perform a range of corrective actions including shifting the point of execution and changing the data being used by the business process. Errors are detected by the engine 4 as a process exception, and in response, the
engine 4 saves the execution state of the rale for the process. The state may then be examined and adjusted using an operator interface. A number of built-in functions are also provided to transfer data between the real-time system 3 and the switches. Further details of the BMS language are provided in the Appendix.
The scheduling of job modules can be extremely complex. For example, EJ interdependencies need to be correctly handled, and a number of exchange jobs may need to be loaded into their respective switches within a specified timeframe. Some jobs may even have to run concurrently across the network, or there may be embargo periods for one or more network elements. The scheduler 6 supports such flexible job scheduling, providing Implement After and Implement By dates. Profiles and Constraints are set for individual or groups of network elements to specify when jobs of various types can be implemented, including concurrent execution requirements. Users can interact with the scheduler 6 to determine suitable time windows. The scheduler 6 also provides 'time lapse protection' to ensure that network element configuration changes have adequate time to settle before further changes are made.
The set of modules that make up the real-time system 3 and the dominant data flow interactions are shown in Figure 4. The real-time system 3 includes the scheduler 6 and all of the components of the rales engine 4.
A Job Request manager 58 of the system 3 manages the creation and user interface initiated life cycle state transitions of the Job Requests, Job Modules, Exchange Job Modules. It also manages "long held" transactions implemented within the system 3. The state changes made by the manager 58 are persisted in the database 62.
The scheduler module 6 is responsible for a number of high level functions, such as maintaining the proposed schedule of execution for all non-complete Exchange Jobs. This schedule is based on the scheduling profile defined for each of the exchanges, the estimates submitted by each of the Exchange Jobs, and other scheduling constraints. Estimates provide the expected duration of an operation or type of operation to be performed as defined by the
BMS language. The scheduler module 6 initiates the execution of Exchange Jobs by creating Inteφreter instances 64 in accordance with the current schedule for that exchange, and determines the effects of proposed changes to the current schedule. The scheduler 6 also detects cases where Exchange Jobs will not be implemented by their required Implement By date and time based on the proposed schedule.
Completion of each business process requires execution of the corresponding high level module or rule. Most modules cannot be executed without having to wait for various services to take place or for access to exchanges or other resources. Thus, execution of the module is broken into multiple "execution sessions" during which the inteφreter 64 is actually executing module code. Execution of a module typically requires a number of execution sessions separated by periods of time waiting for other events to take place.
The scheduler 6 assumes that execution of module code that does not require resources takes no time.Thus only waiting for, and execution of, code using resources requires consideration in the scheduling process. Table 2 describes the language elements, corresponding to resources, that are considered in the scheduling process, the parameters that determine when they can be scheduled, and how long should be allowed for them.
At the beginning of its business rule, Exchange Jobs create an estimate for each of the resources required to complete the required business process. The scheduler 6 constructs the predicted schedule from these estimates.
Table 2
When execution of the module requires any of the estimated resources, it requests the resource giving the estimate entry number returned when the estimate was created. If execution must wait for the resource to become available, the resource estimate is moved to a Requested State and execution suspended until the scheduler grants use of the resource. The resource estimate state is updated allowing the schedule to reflect the actual remaining resource estimates required for the Exchange Job.
A parser 66 is responsible for checking module code syntax and building all the necessary intermediate module code and data structures required for execution of the intermediate module code by the Inteφreter 64. The Inteφreter 64 is a key element of the system, and is responsible for executing intermediate module code implementing all of the functions invoked from the executed module. Each inteφreter module instance 64 executes a single module, but concurrent execution of a number of inteφreter instances allows many individual modules to be executed simultaneously. Although the inteφreter 64 is normally invoked by the scheduler 6, it may also be run independently. This provides the ability to execute module code interactively under the control of real-time operators 18 using debugging facilities such as set execution point, step, inspect variable contents, etc. Static module tests may be generated by interacting with the Inteφreter 64, providing a mechanism for testing a single module in isolation from other modules, production database records, the exchanges, and external systems.
As shown in Table 3 below, the BMS system 2 provides interfaces 68, 70, 72 to a number of external systems 7, 20 over TCP/IP, using application services such as HTTP, FTP, and SMTP, along with IBM's proprietary MQ (Message Queue) for high-level middleware interfaces.
Table 3
These external systems 7, 20 include a Code Routing Information System (CRIS) 17, which supplies data to the BMS system 2 to assist in the generation of exchange data. The BMS system 2 distributes tasks to operations field staff via an Activity Information Management System (AIMS) 15. As an example, this is used to request field staff to change exchange backup disks. A Circuit Commissioning System (CIRCOM) 19 interface is provided to allow external systems to create Job Requests. The BMS system 2 also communicates with a Charge Record Maintenance System (CHARMS) 21 to manage transaction-based billing. The actual switch data is sent to exchanges via a Network Element Manager (NEM) 23. A NEM interface 68 is responsible for all communications between the Inteφreter 64 and the NEM system 23, and intermediate systems (such as NECH, NEAS and NART) may be used to transfer the communications.
An External Services module 70 is responsible for supporting the external services required by the Inteφreter instances 64. It creates and transmits service requests and then monitors for the corresponding responses. Once a response is received, the scheduler 6 is notified so that the associated Exchange Job can resume execution. The External Services module 70 incoφorates interfaces for a SMTP Email Gateway 40, FTP gateway, and IBM's proprietary MQ (message queue) for the middleware interfaces. A system input interface 72 supports MQ to allow other systems, such as CIRCOM 19 and CRIS 17, to create Job Requests.
A Reporting module 74 is responsible for generating reports. Operators have a defined set of reports from which they can select. To request a report, the operator specifies the report type and the time interval to be included. The BMS system 2 prepares the report and makes it available for collection via the HTTP interface within 24 hours. The 24 hour response time for
reports allows the BMS system 2 to run the report at a time when it will not impact system performance, rather than when the operator requests it.
A Schedule variations module 76 handles the creation and submission of the Job Requests that record, or, in some cases, implement, temporary variations to a predetermined schedule.
A data access module 78 provides access to the database 62 for all components of the realtime System 3. This ensures that all database access code is contained in a single module rather than spread throughout other modules, and ensures the transactional integrity of all database accesses by providing complete transactions that can be called by other modules.
In addition to the client-server system 5 and the real-time system 3, the BMS system 2, as shown in Figure 3, also includes an Integration Management System (IMS) 60 and the database 62. The client-server system 5 uses the NetDynamics Application Server platform from Sun Microsystems to provide user interfaces to client workstations via HTTP. For Java user interfaces, the remote method calls to the NetDynamics business objects are implemented using HOP (Internet Inter-Orb Protocol) encapsulated by HTTP. Within the NetDynamics environment framework, the client-server system 5 utilises business and data objects to separate the business logic from the data access functionality, providing a logical three tier application architecture with the presentation layer provided by the client workstation using both HTML and Java applets. The client-server system 5 provides interfaces for interacting purely with the database 62 for the creation and maintenance of the controlling data of the system. The user interfaces that allow operators to interact with the real-time functions, such as scheduling and management of exception conditions during the execution of Job Requests, use the services of the real-time system 3. These are accessed via the Integration Management System (IMS) 60 which makes the real-time system 3 appear to the client-server system 5 as a set of business objects.
While many facilities of the real-time system 3 are controlled by rales and data held by the database 62 that can be maintained by the client-server system 5, the database 62 is not used
as a real-time communication mechanism between the client-server 4 and real-time 3 systems. Real-time interaction between these two major sub-systems is provided by the Integration Management System (IMS) 60. Because the real-time system 3 operates outside the NetDynamics environment, a bridge from the HTTP/HTML Java domain within NetDynamics to the CORBA/C++ domain of the real-time system 3 is required. The IMS 60 provides this bridging point.
The IMS 60 is implemented within the NetDynamics environment as one or more NetDynamics PAC adaptor objects. PAC adaptors are the facility within NetDynamics which provides access to business functionality that is implemented outside the NetDynamics environment.
While a number of the real-time system modules implement functionality that is accessed by the client-server system 5, the real-time system modules run and perform processing activities without direct initiation from the user interface. This independence from the user interface forces this set of business functionality to be implemented outside the NetDynamics environment. NetDynamics environment processing commences with a HTTP request and completes when the HTTP response is given.
The core hardware of the real-time system 3 is a Sun Microsystems Enteφrise 4500 server with six 366 MHz Ultrasparc CPUs. The system includes 2 gigabytes of RAM and approximately 60 gigabytes of (SCSI-3) disk storage, configured in mirrored disk pairs.
Many modifications will be apparent to those skilled in the art without departing from the scope of the present invention as herein described with reference to the accompanying drawings.
APPENDS: BMS LANGUAGE
1. BMS Processing Library
This library provides procedures and functions for performing BMS specific operations.
1.1 Resource Estimates
Resource estimates allow BMS to schedule the usage of resources that will be required by jobs. Before resources are used an estimate must be submitted specifying the type of resource that is required and any relevant details for the resource type. Resource estimates have the following information.
(i) A unique identifier
(ii) The resource type
(iii) Any related information to the resource type.
1.1.1 General description of the scheduling process
Completion of each Exchange Job requires execution of its corresponding module. Most modules cannot be executed without having to wait for various external events to take place or for access to exchanges or other resources. Thus execution of the module is broken into multiple "execution sessions".
An "execution session" is when the BMS language inteφreter is actually executing the module code. Execution of a module typically requires a number of execution sessions separated by periods of time spent waiting for other events to take place.
The BMS scheduling process assumes that execution of module code that does not require external resources takes no time and thus only waiting for and execution of, code using these resources requires consideration in the scheduling process.
As the execution of a Module reaches the point requiring access to any of the estimated resources, it makes a request for the resource detailing the corresponding estimate entry number from the estimate. The making of such a request moves the corresponding entry to the Requested state.
The Schedule is initially populated with the best estimate of the pattern of resource usage. This should be updated if more accurate estimates must be made during execution. The adequacy of this scheduling process relies on the quality of the estimates and the relatively sparse nature of the schedule. To assist in estimate quality improvement, the comparisons of estimated values to actual used values are kept for analysis.
Estimates are submitted using the EstimateCreate procedure and can be updated with the EstimateGetDetails and Estimate Update procedures (eg. When the language module is able to provide a better estimate for the amount of time it will require an exchange connection for). Resource estimates are known uniquely by their estimate identifier, which cannot be modified other than through estimate library calls.
During the processing of the job, the state of resources will change to reflect the current state of execution and resources still required by the job. This is facilitated by storing a "resource state" whose value will be changed automatically by calling language constructs or library calls which use the estimate. The valid values for resource state are described in Table 1.
Table 1 - Resource State
1.1.2 EstimateCreate
1.1.2.1 Synopsis
This procedure is used to declare a single estimate. Details of the parameters and their specific appUication to each resource is given in the associated section as specified in Table 2.
1.1.2.2 Interface
EstimateCreate(WRITE Estimateld : ESTIMATE; ResourceType, IterationCount, SessionType, ConcurrencyType, ExpectedDuration, TimeoutValue, FollowOnPeriod : VAR)
Table 2
1.1.2.3 Estimate Use Contexts
Function names are shown in italics in the following table.
Table 3 - Estimate Use Contexts
The following table shows the parameters applicable to each Resource Constant.
Table 4 - Resource Type Parameters
1.1.3 EstimateGetDetails
1.1.3.1 Synopsis
This procedure will return the current estimate settings for the estimate specified by Estimateld. Any fields which are not required for the estimate resource type specified will return the empty string, "".
1.1.4 EstimateUpdate
1.1.4.1 Synopsis
This procedure will update the current values for the estimate specified by Estimateld.
1.2 Exchange Commands
These procedures are invoked within an active Exchange Session
1.2.1 ExchCmd
1.2.1.1 Synopsis
This procedure sends a command to the exchange using the current exchange connection and returns the exchange's response to the command. The characters that get sent to the exchange will only contain valid characters in the language and the text formatting constants TAB and NEWLINE.
1.2.3 ExchCmdReturnErr
1.2.2.1 Synopsis
This procedure sends a command to the exchange using the current exchange connection and returns the exchange's response to the command. If an error occurs as a result of the exchange command, execution continues and the module developer
should test for and handle the error. On occasions the spontaneous output of SYSTEM RESTART or ERROR INTERRUPT will be returned and must be handled.
1.2.3 ExchGetSpontaneous
1.2.3.1 Synopsis
This procedure returns any spontaneous output from the exchange. It is used for expected spontaneous output.
The following values can be returned from the exchange when querying for spontaneous output.
(i) SYSTEM RESTART
(ii) ERRORINTERRUPT
(iii) Any other exchange ouput without a pending command.
1.2.4 ExchSessionDetails
1.2.4.1 Synopsis
This procedure returns the current Exchange Session details.
1.2.5 ExchSessionModify
1.2.5.1 Synopsis
This procedure updates the current Exchange Session details.
1.3 Interactive Session
Interaction with the operator during an interactive session is provided through the procedures ISStepValue and ISStepSelection.
1.3.1 ISStepValue
1.3.1.1 Synopsis
This procedure is used in an interactive session block to display information to and request a response from the operator. The operator response is provided through Value.
1.3.2 ISStepSelection
1.3.2.1 Synopsis
This procedure is used in a interactive session block to display information and request a response from the operator. The operator response is provided from the selection of an option from a fixed list, OptionList. Empty string elements in OptionList will not be displayed.
1.4 Services
These library functions & procedures support the interaction between the Exchange Job, external systems and organisations.
1.4.4 ServiceRequest
1.4.1.1 Synopsis
This function is called to request the specified service. Once the request has been made execution will continue (The inteφreter does not wait for a response from the external system). A unique service identifier is returned by the call. This is used to obtain the reply using ServiceGetReply.
1.4.2 ServiceGetReply
1.4.2.1 Synopsis
This procedure places the service response data for the request, ServiceReguestld, into ResponseData. If the service request has not completed when this procedure is called, execution will suspend until the service request is completed or the timeout is exceeded.
1.4.3 ServiceGetReplyReturnErr
1.4.3.1 Synopsis
This procedure places the service response data for the request, ServiceRequestld, into ResponseData. If the service request has not completed when this procedure is called, execution will suspend until the service request is completed or the timeout is exceeded. If the timeout specified in Estimateld is exceeded, result will be set to SERVICE ΠMEOUT and ResponseData will be undefined.
1.5 Accessing Stored Exchange Data
1.5.1 AttribGetValue
1.5.1.1 Synopsis
This function is called to return attribute data that is stored for an exchange. If AttributeName exists but has no value for the specified exchange, the empty string is returned.
1.5.2 AttribExchList
1.5.2.1 Synopsis
This function returns a list of exchanges which have a specified attribute set to the value, AttributeValue.
1.5.3 AttribSetValue
1.5.3.1 Synopsis
This procedure sets the value that is stored for an exchange attribute.
1.5.4 AttribDelValue
1.5.4.1 Synopsis
This procedure deletes an exchange attribute.
1.6 Exception handling
1.6.1 ExceptionCondition
1.6.1.1 Synopsis
The effect of ExceptionCondition depends on the contents of the Exception parameter, the Job Request state, and whether the Job Request was submitted by an operator or an external system. Table 5 shows the conditions and corresponding actions.
In normal use Validation Modules only call ExceptionCondition if validation has failed, and Job Modules call it with exception set to TRUE once all validation checks have been successfully performed.
Job Request state Submitted By Control Action
Validation Operator FALSE The Validation Result HTML page is displayed to the operator. This page indicates that validation was successful, and displays message. The operator may proceed with or withdraw the Job Request. An execution history record is created.
Validation Operator TRUE The Validation Result HTML page is displayed to the operator. This page indicates that validation failed, and displays message. The operator acknowledges the page and the Job Request is withdrawn. An execution history record is created.
Validation External FALSE The Job Request is moved to the System submitted state, the External System is notified that the Job Request has been accepted and execution continues. An execution history record is created.
Validation External TRUE The Job Request is withdrawn, the System External System is notified that the Job Request was rejected and execution terminates. An execution history record is created.
Any state except All sources FALSE Execution continues. No execution validation history record is created.
Any state except AU sources TRUE An execution exception is validation generated. An execution history record is created and the Exchange Job state reason is set to message.
Table 5 - Job Request Exception Actions
1.6.2 ExceptionSetState
1.6.2.1 Synopsis
This procedure sets the state that an Exchange Job enters if it encounters an exception.
1.6.3 ExeeptionGetState
1.6.3.1 Synopsis
This function returns the exception state.
1.7 Synchronisation
If an action must be performed by one Exchange Job (or set of Exchange Jobs) before other actions are performed by another Exchange Job (or set of Exchange Jobs) then synchronisation can be performed using the synchronisation procedures. Initialisation of the synchronisation service involves a call to SynchroniseSet specifying a unique identifier and the number of Exchange Jobs that will "wait" for synchronisation. Once the synchronisation counter has been setup, each Exchange Job can call SynchroniseWait to cause execution to pause until the number of Exchange Jobs specified have all called SynchroniseWait.
To prevent accidental access to the same synchronisation counter from other jobs that are running in the BMS system (including other jobs using the same job module), each synchronisation counter is identified by Job Request Id, Exchange Job Id and a name.
Table 6 shows how these two calls are used to ensure that re-routing of numbers can only occur once the number range has been setup on the destination system.
Table 7 shows the execution sequence of each Exchange Job using synchronisation.
Table 6 - Synchronisation Example Psuedo-Code
Table 7 - Synchronisation Example Possible Execution
1.7.1 SynchroniseSet
1.7.1.1 Synopsis
This procedure sets the synchronisation counter specified by JobRequestld, ExchangeName and SynchroniseName by Number.
1.7.2 SynchroniseWait
1.7.2.1 Synopsis
This procedure decrements the synchronisation counter specified by JobRequestld, ExchangeName and SynchroniseName and if the counter reaches zero allows all Exchange Jobs waiting on the counter to resume execution.
Shared Data
The Shared Data facilities enable the transfer of data between Exchange Jobs within the BMS system. Typical use of these procedures is for one Exchange Job to extract some data from an exchange or external system and write the data to a shared data area for another Exchange Job to read. The Exchange Job waiting for the data will park until the data becomes available at which time it will resume execution.
To transfer information between Exchange Jobs one must know the Job Request identifier and exchange name of the other and both must know the name of the data item. This interaction can be sourced from external systems entry data or other sources.
To prevent accidental access to the same shared data from other jobs that are running in the BMS system (including other jobs using the same job module), each piece of share data is identified by Job Request Id, Exchange Job Id and a name.
Claims (31)
1. A management system for a network of components, including: an interface for use in selecting at least one operation to be performed on at least one component of said network, and creating a request that said operation be executed; an engine for processing said request and executing said at least one operation; and a scheduler for scheduling execution of said at least one operation by said engine, based on resource constraints of said network.
2. A management system as claimed in claim 1, including a data store having a rule defining said operation.
3. A management system as claimed in claim 2, wherein said engine generates an execution instance for said operation using said rule, in response to said request.
4. A management system as claimed in claim 1, wherein said request includes scheduling information for executing said operation and for use by said scheduler.
5. A management system as claimed in claim 1, including interfaces for communicating with said network components.
6. A management system as claimed in claim 5, wherein the network components include network switches.
7. A management system as claimed in claim 6, wherein the network switches are distributed over an area, such as a city, state, region or country.
8. A management system as claimed in claim 1, including a client server system providing said interface and a real-time system providing said engine, said scheduler and interfaces for said components.
9. A management system as claimed in claim 8, including a data store having a rule defining said operation, and accessible by said client server system and said real-time system.
10. A management system as claimed in claim 1, wherein said engine includes a manager to control the state of said requests, a parser to parse a request to generate at least one execution instance to perform said operation, and an inteφreter to execute said at least one execution instance, under the control of said scheduler.
11. A management system as claimed in claim 1, including a rule defining said operation and resource requirements for said operation.
12. A management system as claimed in claim 1, wherein said scheduler schedules execution of said requests by instances of said engine when resources for execution of said instances are available.
13. A management system as claimed in claim 1, including a data store having data representing said resource constraints, and wherein said scheduler is adapted to access said data.
14. A scheduler for scheduling execution of rale requests by a rules engine, based on resources required by each request and an estimated time that each resource is required.
15. A scheduler as claimed in claim 14, wherein said estimated times are defined by said rales.
16. A scheduler as claimed in claim 14, wherein said scheduler sets allowable time windows for execution of said requests.
17. A scheduler as claimed in claim 14, wherein said scheduler determines scheduling conflicts between said requests.
18. A scheduler as claimed in claim 14, wherein said scheduler monitors said requests to determine estimated completion times and reschedule said request.
19.- A rules engine for executing rales interactively to allow the input and output of variables, and allow users to select from a set of defined inputs.
20. A management system for network components, including:
"a rules engine for executing a rale to perform an operation on at least one of said components, and adapted to save an execution state of the engine during execution of a rale and send a notification concerning resuming execution of the rule; and a scheduler for receiving said notification and causing resumption of execution of said rule at said execution state.
21. A management system for a network of components, including: a rules engine for executing a rale defining an operation to be performed on at least one of said components, said engine being adapted to detect process exceptions, and in response, save the state of execution of said rule; and an interface for examining and adjusting said execution state and allowing continued execution of said rule.
22. A management system as claimed in claim 21, wherein said interface is adapted to set the execution point of said rale, and to examine change variables of said rale.
23. A programming language, stored on computer readable storage medium, for defining business rules, including commands for transmitting and receiving data from network nodes.
24. A programming language as claimed in claim 23, including commands for sending and receiving messages between user interfaces and a network component management system.
25. A management system as claimed in claim 1, wherein said interfaces include a messaging interface for sending and receiving messages to user interfaces.
26. A management system as claimed in claim 25, wherein said user interfaces are HTTP interfaces.
27. A management system for a network of components, including: a rules engine as claimed in claim 19; and a scheduler as claimed in any one of claims 14 to 18.
28. A management system as claimed in claim 27, further including a programming language as claimed in claim 23 or 24.
29. A component management system, including: a rales engine for inteφreting change requests and executing component change modules to submit changes to respective components; and a scheduler for controlling the timing of execution of said component change modules.
30. A component management system as claimed in claim 29, including an interface for generating said change requests.
31. A management system for a network of components, including: an engine for processing a request for at least one operation to be performed on at least one component of said network; and a scheduler for scheduling execution of said at least one operation by said engine, based on resource availability.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
AU2001281598A AU2001281598A1 (en) | 2000-08-25 | 2001-08-24 | A network component management system |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
AUPQ9681A AUPQ968100A0 (en) | 2000-08-25 | 2000-08-25 | A management system |
AUPQ9681 | 2000-08-25 | ||
PCT/AU2001/001060 WO2002017113A1 (en) | 2000-08-25 | 2001-08-24 | A network component management system |
AU2001281598A AU2001281598A1 (en) | 2000-08-25 | 2001-08-24 | A network component management system |
Publications (1)
Publication Number | Publication Date |
---|---|
AU2001281598A1 true AU2001281598A1 (en) | 2002-03-04 |
Family
ID=3823735
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
AUPQ9681A Abandoned AUPQ968100A0 (en) | 2000-08-25 | 2000-08-25 | A management system |
AU2001281598A Abandoned AU2001281598A1 (en) | 2000-08-25 | 2001-08-24 | A network component management system |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
AUPQ9681A Abandoned AUPQ968100A0 (en) | 2000-08-25 | 2000-08-25 | A management system |
Country Status (6)
Country | Link |
---|---|
US (1) | US20040057454A1 (en) |
EP (1) | EP1327198A1 (en) |
AU (2) | AUPQ968100A0 (en) |
CA (1) | CA2420702A1 (en) |
CZ (1) | CZ2003563A3 (en) |
WO (1) | WO2002017113A1 (en) |
Families Citing this family (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030227878A1 (en) * | 2002-06-07 | 2003-12-11 | Krumm-Heller Alexander Michael | Apparatus and method for automatically and dynamically reconfiguring network provisioning |
KR100604604B1 (en) * | 2004-06-21 | 2006-07-24 | 엘지엔시스(주) | Method for securing system using server security solution and network security solution, and security system implementing the same |
US8095437B2 (en) * | 2005-09-02 | 2012-01-10 | Honda Motor Co., Ltd. | Detecting missing files in financial transactions by applying business rules |
US8540140B2 (en) * | 2005-09-02 | 2013-09-24 | Honda Motor Co., Ltd. | Automated handling of exceptions in financial transaction records |
US8099340B2 (en) * | 2005-09-02 | 2012-01-17 | Honda Motor Co., Ltd. | Financial transaction controls using sending and receiving control data |
US7757269B1 (en) | 2006-02-02 | 2010-07-13 | Mcafee, Inc. | Enforcing alignment of approved changes and deployed changes in the software change life-cycle |
US8620994B2 (en) * | 2006-02-23 | 2013-12-31 | Qualcomm Incorporated | System and method for scheduling content updates in a content-based application |
US7895573B1 (en) | 2006-03-27 | 2011-02-22 | Mcafee, Inc. | Execution environment file inventory |
US9424154B2 (en) | 2007-01-10 | 2016-08-23 | Mcafee, Inc. | Method of and system for computer system state checks |
US8332929B1 (en) * | 2007-01-10 | 2012-12-11 | Mcafee, Inc. | Method and apparatus for process enforced configuration management |
US8925101B2 (en) | 2010-07-28 | 2014-12-30 | Mcafee, Inc. | System and method for local protection against malicious software |
US8938800B2 (en) | 2010-07-28 | 2015-01-20 | Mcafee, Inc. | System and method for network level protection against malicious software |
US9112830B2 (en) | 2011-02-23 | 2015-08-18 | Mcafee, Inc. | System and method for interlocking a host and a gateway |
US9594881B2 (en) | 2011-09-09 | 2017-03-14 | Mcafee, Inc. | System and method for passive threat detection using virtual memory inspection |
US8713668B2 (en) | 2011-10-17 | 2014-04-29 | Mcafee, Inc. | System and method for redirected firewall discovery in a network environment |
US8739272B1 (en) | 2012-04-02 | 2014-05-27 | Mcafee, Inc. | System and method for interlocking a host and a gateway |
US8973146B2 (en) | 2012-12-27 | 2015-03-03 | Mcafee, Inc. | Herd based scan avoidance system in a network environment |
CN105580023B (en) | 2013-10-24 | 2019-08-16 | 迈克菲股份有限公司 | The malicious application of agency's auxiliary in network environment prevents |
CN106326102A (en) * | 2015-07-06 | 2017-01-11 | 阿里巴巴集团控股有限公司 | Test method and apparatus |
CN107634957B (en) * | 2017-09-29 | 2021-08-10 | 深圳迪贝守望信息技术有限公司 | Protocol agent-based real-time data and file operation pre-saving method and system |
Family Cites Families (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5093794A (en) * | 1989-08-22 | 1992-03-03 | United Technologies Corporation | Job scheduling system |
FR2679351B1 (en) * | 1991-07-15 | 1995-01-27 | Bull Sa | OPERATING SYSTEM FOR A UNIVERSAL DEVICE FOR COUPLING A COMPUTER BUS TO A SPECIFIC LINK OF A NETWORK. |
US5983004A (en) * | 1991-09-20 | 1999-11-09 | Shaw; Venson M. | Computer, memory, telephone, communications, and transportation system and methods |
US5414845A (en) * | 1992-06-26 | 1995-05-09 | International Business Machines Corporation | Network-based computer system with improved network scheduling system |
US5491796A (en) * | 1992-10-23 | 1996-02-13 | Net Labs, Inc. | Apparatus for remotely managing diverse information network resources |
US5729688A (en) * | 1993-09-29 | 1998-03-17 | Fujitsu Limited | Network element managing system |
US5751967A (en) * | 1994-07-25 | 1998-05-12 | Bay Networks Group, Inc. | Method and apparatus for automatically configuring a network device to support a virtual network |
US5872928A (en) * | 1995-02-24 | 1999-02-16 | Cabletron Systems, Inc. | Method and apparatus for defining and enforcing policies for configuration management in communications networks |
US6069894A (en) * | 1995-06-12 | 2000-05-30 | Telefonaktiebolaget Lm Ericsson | Enhancement of network operation and performance |
US5671361A (en) * | 1995-09-28 | 1997-09-23 | University Of Central Florida | Priority rule search technique for resource constrained project scheduling |
JPH09153912A (en) * | 1995-11-30 | 1997-06-10 | Nippon Telegr & Teleph Corp <Ntt> | Method and system for information service |
US6009274A (en) * | 1996-12-13 | 1999-12-28 | 3Com Corporation | Method and apparatus for automatically updating software components on end systems over a network |
US6026440A (en) * | 1997-01-27 | 2000-02-15 | International Business Machines Corporation | Web server account manager plug-in for monitoring resources |
US5938736A (en) * | 1997-06-30 | 1999-08-17 | Sun Microsystems, Inc. | Search engine architecture for a high performance multi-layer switch element |
US6141759A (en) * | 1997-12-10 | 2000-10-31 | Bmc Software, Inc. | System and architecture for distributing, monitoring, and managing information requests on a computer network |
US6505228B1 (en) * | 1998-07-22 | 2003-01-07 | Cisco Technology, Inc. | Dynamic determination of execution sequence |
CA2342241A1 (en) * | 1998-08-31 | 2000-03-09 | Cabletron Systems, Inc. | Method and apparatus for managing data for use by data applications |
US6301613B1 (en) * | 1998-12-03 | 2001-10-09 | Cisco Technology, Inc. | Verifying that a network management policy used by a computer system can be satisfied and is feasible for use |
US7386586B1 (en) * | 1998-12-22 | 2008-06-10 | Computer Associates Think, Inc. | System for scheduling and monitoring computer processes |
US6680933B1 (en) * | 1999-09-23 | 2004-01-20 | Nortel Networks Limited | Telecommunications switches and methods for their operation |
US20010044840A1 (en) * | 1999-12-13 | 2001-11-22 | Live Networking, Inc. | Method and system for real-tme monitoring and administration of computer networks |
US20020004843A1 (en) * | 2000-07-05 | 2002-01-10 | Loa Andersson | System, device, and method for bypassing network changes in a routed communication network |
US20020143929A1 (en) * | 2000-12-07 | 2002-10-03 | Maltz David A. | Method and system for collection and storage of traffic data from heterogeneous network elements in a computer network |
-
2000
- 2000-08-25 AU AUPQ9681A patent/AUPQ968100A0/en not_active Abandoned
-
2001
- 2001-08-24 AU AU2001281598A patent/AU2001281598A1/en not_active Abandoned
- 2001-08-24 EP EP01959981A patent/EP1327198A1/en not_active Withdrawn
- 2001-08-24 US US10/362,680 patent/US20040057454A1/en not_active Abandoned
- 2001-08-24 WO PCT/AU2001/001060 patent/WO2002017113A1/en not_active Application Discontinuation
- 2001-08-24 CZ CZ2003563A patent/CZ2003563A3/en unknown
- 2001-08-24 CA CA002420702A patent/CA2420702A1/en not_active Abandoned
Also Published As
Publication number | Publication date |
---|---|
EP1327198A1 (en) | 2003-07-16 |
WO2002017113A1 (en) | 2002-02-28 |
AUPQ968100A0 (en) | 2000-09-21 |
CZ2003563A3 (en) | 2004-02-18 |
CA2420702A1 (en) | 2002-02-28 |
US20040057454A1 (en) | 2004-03-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20040057454A1 (en) | Network component management system | |
US5826239A (en) | Distributed workflow resource management system and method | |
US5937388A (en) | System and method for performing scalable distribution of process flow activities in a distributed workflow management system | |
US6041306A (en) | System and method for performing flexible workflow process execution in a distributed workflow management system | |
US6983317B1 (en) | Enterprise management system | |
US5870545A (en) | System and method for performing flexible workflow process compensation in a distributed workflow management system | |
US6243862B1 (en) | Methods and apparatus for testing components of a distributed transaction processing system | |
US20020019844A1 (en) | Method and system for network-distributed computing | |
CN111506412A (en) | Distributed asynchronous task construction and scheduling system and method based on Airflow | |
US20050025303A1 (en) | High availability multi-tenant feature | |
US20010016867A1 (en) | Framework system and method for testing server performance | |
JPH10260825A (en) | Collaboration of module type application | |
US20100121904A1 (en) | Resource reservations in a multiprocessor computing environment | |
US6141679A (en) | High performance distributed transaction processing methods and apparatus | |
CN112199353A (en) | Data processing method and electric power customer service platform | |
Christophides et al. | Beyond discrete e-services: Composing session-oriented services in telecommunications | |
CN116016531A (en) | Batch shutdown processing method and device | |
WO2022087581A1 (en) | Quantifying usage of robotic processs automation related resources | |
EP4024761A1 (en) | Communication method and apparatus for multiple management domains | |
US20100122261A1 (en) | Application level placement scheduler in a multiprocessor computing environment | |
US9323509B2 (en) | Method and system for automated process distribution | |
CN115056234A (en) | RPA controller scheduling method and system based on event driving and infinite state machine | |
Shokri et al. | Architecture of ROAFTS/Solaris: A Solaris-based middleware for real-time object-oriented adaptive fault tolerance support | |
Kusek et al. | Mobile agent based software operation and maintenance | |
Mania et al. | Developing performance models from nonintrusive monitoring traces |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
MK5 | Application lapsed section 142(2)(e) - patent request and compl. specification not accepted |