US8302088B2 - Analysis of effects of a software maintenance patch on configuration items of a CMDB - Google Patents

Analysis of effects of a software maintenance patch on configuration items of a CMDB Download PDF

Info

Publication number
US8302088B2
US8302088B2 US12/251,489 US25148908A US8302088B2 US 8302088 B2 US8302088 B2 US 8302088B2 US 25148908 A US25148908 A US 25148908A US 8302088 B2 US8302088 B2 US 8302088B2
Authority
US
United States
Prior art keywords
cmdb
manifest
maintenance patch
cis
software components
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.)
Expired - Fee Related, expires
Application number
US12/251,489
Other versions
US20100095273A1 (en
Inventor
Brian Robert Matthiesen
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.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
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 International Business Machines Corp filed Critical International Business Machines Corp
Priority to US12/251,489 priority Critical patent/US8302088B2/en
Assigned to INTERNATIONAL BUSINESS MACHINES CORPORATION reassignment INTERNATIONAL BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MATTHIESEN, BRIAN ROBERT
Priority to CN2009101795170A priority patent/CN101727477B/en
Publication of US20100095273A1 publication Critical patent/US20100095273A1/en
Application granted granted Critical
Publication of US8302088B2 publication Critical patent/US8302088B2/en
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/21Design, administration or maintenance of databases
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • G06F16/2365Ensuring data consistency and integrity

Definitions

  • the invention disclosed and claimed herein generally pertains to a method and system for analyzing effects of a software maintenance patch on respective configuration items in a configurable managed environment, such as a configuration management database (CMDB). More particularly, the invention pertains to a method of the above type wherein a description of the software maintenance patch and the products or other elements that it targets are compared with the contents of the CMDB, in order to identify configuration items contained therein that will be impacted or affected by the maintenance patch.
  • CMDB configuration management database
  • Configuration management is a process for identifying, controlling and tracking the hardware, software and other components of one or more configurable systems in a configurable managed environment, such as an Information Technology organization.
  • Components included in a configurable system are referred to as configuration items (CIs).
  • the configuration management process includes performing tasks, such as identifying CIs and their relationships with other CIs, and adding them to a configuration management database that generally contains detailed information, for each CI listed therein.
  • a CMDB is a database that contains all relevant details for each CI, such as relationships between CIs, state or status and historical information.
  • a related CMDB product of International Business Machines Corporation (IBM) is known as the Configuration and Change Management Database (CCMDB).
  • a software maintenance patch generally refers to one or more software updates or upgrades for debugging, fixing or enhancing specified software components.
  • a software maintenance patch includes a set of software updates or fixes, and may also be referred to as a fix pack.
  • fix pack when a software maintenance patch is applied to the intended software components of a data processing system or the like, relationships between the intended components and other components of the system are not fully understood or appreciated. Accordingly, application of the software maintenance patch can produce results which are not intended or expected, and may also not be desired.
  • the system usefully can be a configurable managed system associated with a CMDB.
  • Embodiments of the invention provide a method, a system and a computer program product for analyzing the effect of a software maintenance patch on configuration items of a CMDB.
  • One embodiment directed to a method, is associated with a CMDB containing information that relates to configuration items (CIs) included in one or more managed configurable systems.
  • the method includes the step of generating a manifest that defines a target system, and contains a description of a maintenance patch disposed to update one or more specified software components.
  • the method further includes using information contained in the manifest to search the CMDB, in order to detect each configurable system in the CMDB that corresponds to the definition of the target system, and also contains at least one CI that includes at least one of the specified software components. For a given CI that includes one or more of the specified software components, an identification is made of every other CI in the CMDB that would be affected, if the maintenance patch was used to update each specified software component of the given CI.
  • FIG. 1 is a schematic diagram showing a configurable managed system in which an embodiment of the invention may be used.
  • FIG. 2 is a block diagram showing a computer or data processing system for implementing an embodiment of the invention.
  • FIG. 3 is a schematic diagram illustrating a Maintenance Delivery Manifest for an embodiment of the invention.
  • FIG. 4 is a flow chart showing selected steps for a method comprising an embodiment of the invention.
  • FIG. 5 is a schematic diagram depicting the screen of a User Interface that shows an example of results provided by an embodiment of the invention.
  • the present invention may be embodied as a system, method or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
  • the computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium.
  • the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CDROM), an optical storage device, a transmission media such as those supporting the Internet or an intranet, or a magnetic storage device.
  • a computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory.
  • a computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
  • the computer-usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave.
  • the computer usable program code may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc.
  • Computer program code for carrying out operations of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages.
  • the program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
  • the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
  • LAN local area network
  • WAN wide area network
  • Internet Service Provider for example, AT&T, MCI, Sprint, EarthLink, MSN, GTE, etc.
  • These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • These computer program instructions may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
  • the computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • a configurable managed system 100 that includes a number of interrelated configuration items (CIs).
  • CIs interrelated configuration items
  • Well known types of CIs include desktop computers, servers and computer clients, which are exemplified in FIG. 1 by servers 102 and 104 , and by clients 106 and 108 .
  • the hardware CIs of system 100 may contain operating systems, application programs and other software components that are also CIs.
  • Respective CIs of configurable system 100 can be selectively connected to one another by means of a network 110 , which may, for example, comprise the Internet or a LAN.
  • system 100 provided with a CMDB 112 , with which embodiments of the invention may be used, and further provided with a point product 114 .
  • the point product is a component that monitors or provides management services for the as of system 100 , and furnishes data concerning respective CIs to CMDB 112 .
  • information pertaining to CIs, wherein the CIs include hardware, software, and monitoring applications, is stored in CMDB 112 .
  • FIG. 1 further shows a computer work station, comprising a management station 116 , for use by a Change Manager or other administrator or user associated with configurable managed system 100 .
  • Management station 116 is operable to establish and change relationships between respective CIs.
  • Management station 116 is provided with a user interface, as further indicated at FIG. 2 , and may be operated by a user to install software maintenance patches, as described above, on software components that comprise or are included in CIs that are associated with CMDB 112 .
  • Management station 116 may also be operated to carry out embodiments of the invention, as described herein.
  • FIG. 1 shows only a single system 100 associated with CMDB 112 , a number of other systems may also include CIs and use CMDB 112 to retain information pertaining to those CIs.
  • FIG. 2 there is shown a block diagram of a generalized data processing system 200 which may be used to implement management station 116 .
  • Data processing system 200 exemplifies a computer, in which code or instructions for implementing the processes of the present invention may be located.
  • Data processing system 200 usefully employs a peripheral component interconnect (PCI) local bus architecture, although other bus architectures may alternatively be used.
  • FIG. 2 shows a processor 202 and main memory 204 connected to a PCI local bus 206 through a Host/PCI bridge 208 .
  • PCI bridge 208 also may include an integrated memory controller and cache memory for processor 202 .
  • LAN local area network
  • SCSI small computer system interface
  • host bus adapter 210 provides a connection for hard disk drive 218 , and also for CD-ROM drive 220 .
  • Expansion bus interface 214 provides a connection for user interface elements, such as a keyboard and mouse adapter 222 , modem 224 , and additional memory 226 .
  • An operating system runs on processor 202 and is used to coordinate and provide control of various components within data processing system 200 shown in FIG. 2 .
  • the operating system may be a commercially available operating system such as Windows XP, which is available from Microsoft Corporation. Instructions for the operating system and for applications or programs are located on storage devices, such as hard disk drive 220 , and may be loaded into main memory 204 for execution by processor 202 .
  • users applying a software maintenance patch or fix pack to intended systems or other components generally desire to know what effects, if any, the patch may have beyond the intended components.
  • a document or like entity is generated that describes the content and semantics of the software maintenance patch.
  • This document or other entity is referred to herein as a Maintenance Delivery Manifest (MDM), or simply “manifest”, and usefully comprises an Extension Markup Language (XML) based text file, such as the Maintenance Delivery Markup Language (MDML), or other standardized language.
  • MDM may be constructed by means of a conventional text editor, or possibly by using a specialized tool.
  • the MDM is generated or supplied by the vendor of the software patch.
  • the MDM could be prepared by users of the patch.
  • the MDM describes the intended patch targets, that is, the particular software components or CIs to which the software maintenance patch is directed, in order to update such components or correct defects thereof.
  • These descriptions comprising a set of target descriptors, is in a language and in terms that will be readily understood by a CMDB, such as CMDB 112 , which contains information pertaining to the CIs.
  • CMDB such as CMDB 112
  • the MDM could use language and standards of a type currently used by CMDB's to provide common or standardized object models to represent respective CIs.
  • the MDM includes descriptors for the following types of data elements, in a standardized form: Fix pack name and content; Target of the fix pack in terms known to the CMDB; Affected product names and part numbers; Fix pack prerequisites; and Solutions and Authorized Program Application Requests (APAR) contained in the fix pack.
  • a software maintenance patch will be typically targeted to software components that are contained in systems which have certain characteristics. Accordingly, these characteristics can be used as prerequisites to distinguish between systems listed in the CMDB that may contain targeted components, and other systems to which the patch definitely does not apply.
  • the software maintenance patch could apply to a component of the particular type that was the product of one vendor, but would not apply to the same type of component that was the product of a different vendor.
  • the MDM further includes prerequisites for distinguishing between components or CIs contained in the CMDB that have been supplied by different vendors. These prerequisites can also be used to distinguish between systems and components to which the patch is and is not applicable, respectively.
  • component part number Another prerequisite included in the MDM is component part number. This prerequisite is readily searchable in the CDMB, in order to locate components to which the patch pertains. It is anticipated that this prerequisite will become increasingly important as a universal part numbering system is developed, wherein each part number will uniquely identify a specific component and will additionally identify the vendor of the component.
  • an MDM as described above comprising principal sections 302 - 306 .
  • the MDM refers to a patch comprising an Identity Manager Windows AD Adapter.
  • Section 302 provides an identification and description of the software maintenance patch, and includes the patch name, the patch identification number and the name of the patch vendor. This section further describes the particular APAR fixes that the patch provides.
  • Section 304 of the MDM indicates the prerequisites, as described above, for the systems or other products on which components or CIs targeted by the software maintenance patch may be found.
  • Section 304 provides the name or names of such products, and also provides their respective part numbers.
  • the platform on which respective products are run is also provided.
  • This section may additionally include the vendor names of respective products.
  • Section 306 identifies the target CIs of respective systems, that is, the CIs which are to be updated or corrected by the software maintenance patch.
  • FIG. 3 shows that the targeted CIs include both a target t 1 and a target t 2 .
  • Target section 306 further indicates that one or more specified software components such as ⁇ C 1 >- ⁇ C 3 > are included with each target.
  • the MDM provides a rigorous description of both the software maintenance patch and the target CIs to which the patch applies. This description facilitates the search of the CMDB, to identify and locate targeted CIs that are contained therein. The description also facilitates an impact analysis, to determine the effects on other CIs resulting from application of the maintenance patch to the targeted CIs.
  • a user generates or creates an MDM as described above.
  • the contents of the MDM are loaded for processing, such as by operation of management station 116 . That is, the MDM is bound to or combined with the contents of the CMDB.
  • the MDM prerequisites are compared with the CMDB contents, in order to initially identify or locate those systems listed in the CMDB that may include CIs intended to be targets of the software maintenance patch. Prerequisite information contained in the MDM could be searched in the CMDB, in order to locate such systems.
  • the MDM contains target descriptors in textual form.
  • target descriptors of the MDM are compared with textual descriptions in the CMDB of CIs contained therein, that are included in each of the systems identified at step 406 .
  • these descriptions may comprise standards-based vendor-independent descriptions or identifiers. This comparison identifies target CIs in such systems, that is, CIs or software components of the CIs to which the software maintenance patch is applicable.
  • an analysis is carried out, in regard to a particular identified CI, in order to identify other CIs or objects contained in the CMDB that would be affected or impacted if the software maintenance patch was used to update a software component of the particular CI.
  • Such analysis could be carried out, for example, by means of a CMBD that comprises the CCMDB product of IBM, referred to above.
  • the CCMDB may also be operated to create a report, as shown by step 412 , that indicates the impact on other CIs or objects of applying the maintenance patch to the particular CI.
  • Such report would usefully identify each affected CI, and would also describe the anticipated effect thereon, as the result of applying the patch to the particular CI.
  • FIG. 4 shows the method thereof coming to an end following step 412 .
  • step 412 could be followed by an additional step that updated the CMDB to reflect the new maintenance level of each identified target system.
  • a plug-in module could be used with management station 116 to implement one or more steps of the above method.
  • FIG. 5 there is shown the screen 500 of a User Interface or the like, that displays an example of results provided by an embodiment of the invention.
  • the embodiment uses the CCMDB product referred to above to function as the CMDB.
  • Patch contents are displayed as item 502 , and a column 504 contains CMDB objects or components.
  • the corresponding vendor, current revision level and types of impact of the patch are displayed at columns 506 , 508 and 510 , respectively.
  • each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s).
  • the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.
  • the invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements.
  • the invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
  • the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system.
  • a computer-usable or computer readable medium can be any tangible apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
  • the medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium.
  • Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk.
  • Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
  • a data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus.
  • the memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
  • I/O devices including but not limited to keyboards, displays, pointing devices, etc.
  • I/O controllers can be coupled to the system either directly or through intervening I/O controllers.
  • Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks.
  • Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.

Abstract

Embodiments of the invention provide a method, a system and a computer program product for analyzing the effect of a software maintenance patch on configuration items of a CMDB. One embodiment, directed to a method, is associated with a CMDB containing information that relates to configuration items (CIs) included in one or more managed configurable systems. The method includes the step of generating a manifest that defines a target system, and contains a description of a maintenance patch disposed to update one or more specified software components. The method further includes using information contained in the manifest to search the CMDB, in order to detect each configurable system in the CMDB that corresponds to the definition of the target system, and contains at least one CI that includes at least one of the specified software components. For a given CI that includes at least one of the specified software components, an identification is made of every other CI in the CMDB that would be affected, if the maintenance patch was used to update each specified software component of the given CI.

Description

BACKGROUND OF THE INVENTION
1. Field of the Invention
The invention disclosed and claimed herein generally pertains to a method and system for analyzing effects of a software maintenance patch on respective configuration items in a configurable managed environment, such as a configuration management database (CMDB). More particularly, the invention pertains to a method of the above type wherein a description of the software maintenance patch and the products or other elements that it targets are compared with the contents of the CMDB, in order to identify configuration items contained therein that will be impacted or affected by the maintenance patch.
2. Description of the Related Art
Configuration management is a process for identifying, controlling and tracking the hardware, software and other components of one or more configurable systems in a configurable managed environment, such as an Information Technology organization. Components included in a configurable system are referred to as configuration items (CIs). The configuration management process includes performing tasks, such as identifying CIs and their relationships with other CIs, and adding them to a configuration management database that generally contains detailed information, for each CI listed therein. A CMDB is a database that contains all relevant details for each CI, such as relationships between CIs, state or status and historical information. A related CMDB product of International Business Machines Corporation (IBM) is known as the Configuration and Change Management Database (CCMDB).
A software maintenance patch, as such term is used herein, generally refers to one or more software updates or upgrades for debugging, fixing or enhancing specified software components. Typically, a software maintenance patch includes a set of software updates or fixes, and may also be referred to as a fix pack. Frequently, when a software maintenance patch is applied to the intended software components of a data processing system or the like, relationships between the intended components and other components of the system are not fully understood or appreciated. Accordingly, application of the software maintenance patch can produce results which are not intended or expected, and may also not be desired. The system usefully can be a configurable managed system associated with a CMDB.
When a software maintenance patch is applied to a system, it is quite common for a system administrator to rely on personal experience in gauging or anticipating the likely impact of the patch on components of the system. Alternatively, the administrator may rely on others in his/her organization who are deemed to have relevant experience. System administrators may also rely on release notes, which are commonly supplied by software vendors to describe the content and applicability of the software maintenance deliverables that the vendors provide. However, this type of documentation tends to be unstructured and ambiguous, and often does not provide a sufficient basis for evaluating the necessity and risk of using the associated maintenance patch. The risks may be particularly significant, when performing critical system maintenance activities. Generally, all of the above information sources can be inadequate for use in maintenance evaluation, in view of the complex interrelations among components that are currently found in enterprise information systems infrastructures.
In addition, currently available maintenance installation tools, for use in installing software maintenance patches into CIs of a CMDB, are quite limited at best. For example, a system may contain a number of CIs that are all of the same type, but some of the CIs are products of a different vendor than other CIs. As a result, a tool or program for installing software maintenance patches in the CIs will typically be proprietary to only one of the vendors, and will not work for the CIs of other vendors. At present, there is generally no standard model for maintenance installation tools, for use in applying software maintenance patches and the like, which can be used across the products of different vendors.
BRIEF SUMMARY OF THE INVENTION
Embodiments of the invention provide a method, a system and a computer program product for analyzing the effect of a software maintenance patch on configuration items of a CMDB. One embodiment, directed to a method, is associated with a CMDB containing information that relates to configuration items (CIs) included in one or more managed configurable systems. The method includes the step of generating a manifest that defines a target system, and contains a description of a maintenance patch disposed to update one or more specified software components. The method further includes using information contained in the manifest to search the CMDB, in order to detect each configurable system in the CMDB that corresponds to the definition of the target system, and also contains at least one CI that includes at least one of the specified software components. For a given CI that includes one or more of the specified software components, an identification is made of every other CI in the CMDB that would be affected, if the maintenance patch was used to update each specified software component of the given CI.
BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS
FIG. 1 is a schematic diagram showing a configurable managed system in which an embodiment of the invention may be used.
FIG. 2 is a block diagram showing a computer or data processing system for implementing an embodiment of the invention.
FIG. 3 is a schematic diagram illustrating a Maintenance Delivery Manifest for an embodiment of the invention.
FIG. 4 is a flow chart showing selected steps for a method comprising an embodiment of the invention; and
FIG. 5 is a schematic diagram depicting the screen of a User Interface that shows an example of results provided by an embodiment of the invention.
DETAILED DESCRIPTION OF THE INVENTION
As will be appreciated by one skilled in the art, the present invention may be embodied as a system, method or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
Any combination of one or more computer usable or computer readable medium(s) may be utilized. The computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a non-exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CDROM), an optical storage device, a transmission media such as those supporting the Internet or an intranet, or a magnetic storage device. Note that the computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory. In the context of this document, a computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer-usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave. The computer usable program code may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc.
Computer program code for carrying out operations of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
The present invention is described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions.
These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer program instructions may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
Referring to FIG. 1, there is shown a configurable managed system 100 that includes a number of interrelated configuration items (CIs). Well known types of CIs include desktop computers, servers and computer clients, which are exemplified in FIG. 1 by servers 102 and 104, and by clients 106 and 108. While not shown, the hardware CIs of system 100 may contain operating systems, application programs and other software components that are also CIs. Respective CIs of configurable system 100 can be selectively connected to one another by means of a network 110, which may, for example, comprise the Internet or a LAN.
Referring further to FIG. 1, there is shown system 100 provided with a CMDB 112, with which embodiments of the invention may be used, and further provided with a point product 114. The point product is a component that monitors or provides management services for the as of system 100, and furnishes data concerning respective CIs to CMDB 112. Thus, information pertaining to CIs, wherein the CIs include hardware, software, and monitoring applications, is stored in CMDB 112.
FIG. 1 further shows a computer work station, comprising a management station 116, for use by a Change Manager or other administrator or user associated with configurable managed system 100. Management station 116 is operable to establish and change relationships between respective CIs. Management station 116 is provided with a user interface, as further indicated at FIG. 2, and may be operated by a user to install software maintenance patches, as described above, on software components that comprise or are included in CIs that are associated with CMDB 112. Management station 116 may also be operated to carry out embodiments of the invention, as described herein.
While FIG. 1 shows only a single system 100 associated with CMDB 112, a number of other systems may also include CIs and use CMDB 112 to retain information pertaining to those CIs.
Referring to FIG. 2, there is shown a block diagram of a generalized data processing system 200 which may be used to implement management station 116. Data processing system 200 exemplifies a computer, in which code or instructions for implementing the processes of the present invention may be located. Data processing system 200 usefully employs a peripheral component interconnect (PCI) local bus architecture, although other bus architectures may alternatively be used. FIG. 2 shows a processor 202 and main memory 204 connected to a PCI local bus 206 through a Host/PCI bridge 208. PCI bridge 208 also may include an integrated memory controller and cache memory for processor 202.
Referring further to FIG. 2, there is shown a local area network (LAN) adapter 212, a small computer system interface (SCSI), a host bus adapter 210, and an expansion bus interface 214 respectively connected to PCI local bus 206 by direct component connection. SCSI host bus adapter 210 provides a connection for hard disk drive 218, and also for CD-ROM drive 220. Expansion bus interface 214 provides a connection for user interface elements, such as a keyboard and mouse adapter 222, modem 224, and additional memory 226.
An operating system runs on processor 202 and is used to coordinate and provide control of various components within data processing system 200 shown in FIG. 2. The operating system may be a commercially available operating system such as Windows XP, which is available from Microsoft Corporation. Instructions for the operating system and for applications or programs are located on storage devices, such as hard disk drive 220, and may be loaded into main memory 204 for execution by processor 202.
In an embodiment of the invention, users applying a software maintenance patch or fix pack to intended systems or other components generally desire to know what effects, if any, the patch may have beyond the intended components. As a first step in achieving this objective, a document or like entity is generated that describes the content and semantics of the software maintenance patch. This document or other entity is referred to herein as a Maintenance Delivery Manifest (MDM), or simply “manifest”, and usefully comprises an Extension Markup Language (XML) based text file, such as the Maintenance Delivery Markup Language (MDML), or other standardized language. The MDM may be constructed by means of a conventional text editor, or possibly by using a specialized tool. In some embodiments of the invention, the MDM is generated or supplied by the vendor of the software patch. In other embodiments, such as where the patch is an application written in-house, the MDM could be prepared by users of the patch.
The MDM describes the intended patch targets, that is, the particular software components or CIs to which the software maintenance patch is directed, in order to update such components or correct defects thereof. These descriptions, comprising a set of target descriptors, is in a language and in terms that will be readily understood by a CMDB, such as CMDB 112, which contains information pertaining to the CIs. For example, the MDM could use language and standards of a type currently used by CMDB's to provide common or standardized object models to represent respective CIs. Usefully, the MDM includes descriptors for the following types of data elements, in a standardized form: Fix pack name and content; Target of the fix pack in terms known to the CMDB; Affected product names and part numbers; Fix pack prerequisites; and Solutions and Authorized Program Application Requests (APAR) contained in the fix pack. Also, a software maintenance patch will be typically targeted to software components that are contained in systems which have certain characteristics. Accordingly, these characteristics can be used as prerequisites to distinguish between systems listed in the CMDB that may contain targeted components, and other systems to which the patch definitely does not apply.
Moreover, for a targeted system component of a particular type, the software maintenance patch could apply to a component of the particular type that was the product of one vendor, but would not apply to the same type of component that was the product of a different vendor. Accordingly, the MDM further includes prerequisites for distinguishing between components or CIs contained in the CMDB that have been supplied by different vendors. These prerequisites can also be used to distinguish between systems and components to which the patch is and is not applicable, respectively.
Another prerequisite included in the MDM is component part number. This prerequisite is readily searchable in the CDMB, in order to locate components to which the patch pertains. It is anticipated that this prerequisite will become increasingly important as a universal part numbering system is developed, wherein each part number will uniquely identify a specific component and will additionally identify the vendor of the component.
Referring to FIG. 3, there is shown an MDM as described above comprising principal sections 302-306. As an illustrative example, the MDM refers to a patch comprising an Identity Manager Windows AD Adapter. Section 302 provides an identification and description of the software maintenance patch, and includes the patch name, the patch identification number and the name of the patch vendor. This section further describes the particular APAR fixes that the patch provides.
Section 304 of the MDM indicates the prerequisites, as described above, for the systems or other products on which components or CIs targeted by the software maintenance patch may be found. Section 304 provides the name or names of such products, and also provides their respective part numbers. The platform on which respective products are run is also provided. This section may additionally include the vendor names of respective products.
Section 306 identifies the target CIs of respective systems, that is, the CIs which are to be updated or corrected by the software maintenance patch. FIG. 3 shows that the targeted CIs include both a target t1 and a target t2. Target section 306 further indicates that one or more specified software components such as <C1>-<C3> are included with each target.
It is to be emphasized that the MDM, as illustrated by FIG. 3, provides a rigorous description of both the software maintenance patch and the target CIs to which the patch applies. This description facilitates the search of the CMDB, to identify and locate targeted CIs that are contained therein. The description also facilitates an impact analysis, to determine the effects on other CIs resulting from application of the maintenance patch to the targeted CIs.
Referring to FIG. 4, there are shown selected steps of a method comprising an embodiment of the invention. At step 402, a user generates or creates an MDM as described above. At step 404 the contents of the MDM are loaded for processing, such as by operation of management station 116. That is, the MDM is bound to or combined with the contents of the CMDB. At step 406, the MDM prerequisites are compared with the CMDB contents, in order to initially identify or locate those systems listed in the CMDB that may include CIs intended to be targets of the software maintenance patch. Prerequisite information contained in the MDM could be searched in the CMDB, in order to locate such systems.
As described above, the MDM contains target descriptors in textual form. At step 408, target descriptors of the MDM are compared with textual descriptions in the CMDB of CIs contained therein, that are included in each of the systems identified at step 406. Usefully, some or all of these descriptions may comprise standards-based vendor-independent descriptions or identifiers. This comparison identifies target CIs in such systems, that is, CIs or software components of the CIs to which the software maintenance patch is applicable.
At step 410, an analysis is carried out, in regard to a particular identified CI, in order to identify other CIs or objects contained in the CMDB that would be affected or impacted if the software maintenance patch was used to update a software component of the particular CI. Such analysis could be carried out, for example, by means of a CMBD that comprises the CCMDB product of IBM, referred to above. Following this analysis, the CCMDB may also be operated to create a report, as shown by step 412, that indicates the impact on other CIs or objects of applying the maintenance patch to the particular CI. Such report would usefully identify each affected CI, and would also describe the anticipated effect thereon, as the result of applying the patch to the particular CI.
FIG. 4 shows the method thereof coming to an end following step 412. As an option, however, step 412 could be followed by an additional step that updated the CMDB to reflect the new maintenance level of each identified target system.
In one embodiment, a plug-in module could be used with management station 116 to implement one or more steps of the above method.
Referring to FIG. 5, there is shown the screen 500 of a User Interface or the like, that displays an example of results provided by an embodiment of the invention. The embodiment uses the CCMDB product referred to above to function as the CMDB. Patch contents are displayed as item 502, and a column 504 contains CMDB objects or components. For each item in column 504, the corresponding vendor, current revision level and types of impact of the patch are displayed at columns 506, 508 and 510, respectively.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
The invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements. In a preferred embodiment, the invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
Furthermore, the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer readable medium can be any tangible apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk. Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers.
Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.
The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.

Claims (20)

1. In association with a configuration management database (CMDB) containing information that relates to configuration items (CIs) included in one or more managed configurable systems, a computer implemented method comprising the steps of:
generating a manifest that defines a target system, and contains a description of a software maintenance patch disposed to update one or more specified software components of the target system;
using information contained in the manifest to search the CMDB, in order to detect each configurable system in the CMDB that corresponds to said target system, and contains at least one CI that includes at least one of said specified software components;
said manifest includes a set of descriptors that respectively describe elements of said target system, and said descriptors comprise one or more system prerequisites, wherein said prerequisites are used to search said CMDB to identify a first system, that includes one of said specified software components, and
for a given CI that includes at least one of said specified software components, identifying every other CI in the CMDB that would be affected by the software maintenance patch if the software maintenance patch was used to update each specified software component of the given CI.
2. The method of claim 1, wherein:
said method includes generating an impact analysis report that discloses each of said identified CIs, and further discloses an anticipated effect on each identified CI if the maintenance patch is used to update respective specified software components of said CMDB.
3. The method of claim 1, wherein:
said manifest comprises a document that describes the content and semantics of the software maintenance patch, said descriptors include one or more Authorized Program Application Requests (APARs), and said CMDB is searched by comparing each of said descriptors with descriptions of respective elements of said configurable systems, said element descriptions being respectively contained in the CMDB, and at least some of the descriptions comprising standards-based vendor-independent descriptions or identifiers, selectively.
4. The method of claim 3, wherein:
CIs in said CMDB contain at least one product of a particular type that may be supplied by any of two or more different vendors, and said manifest includes descriptors that uniquely identify each CI that contains said product of said particular type which has been supplied by a particular one of said vendors.
5. The method of claim 4, wherein:
said product of said particular type supplied by one of said vendors is uniquely identified and distinguished from said product of said particular type supplied by other of said vendors by a part number that is included in a part numbering system common to all of said vendors.
6. The method of claim 1, wherein:
said manifest includes prerequisites for use in distinguishing between CIs to which said software maintenance patch is and is not applicable, respectively.
7. The method of claim 1, wherein:
said manifest includes a description of the contents of said software maintenance patch.
8. The method of claim 1, wherein:
said manifest specifies the respective specified software components which will be affected by said software maintenance patch, and further indicates the effects of said software maintenance patch on the respective components.
9. The method of claim 8, wherein:
the effects of said software maintenance patch include at least updating a respective component, and correcting defects thereof, selectively.
10. The method of claim 1, wherein:
a plug-in module is used to implement one or more steps of said method.
11. In association with a configuration management database (CMDB) containing information that relates to configuration items (CIs) included in one or more managed configurable systems, a computer program product stored in a non-transitory computer readable medium comprising:
instructions for generating a manifest that defines a target system, and contains a description of a software maintenance patch disposed to update one or more specified software components of the target system;
instructions for using information contained in the manifest to search the CMDB, in order to detect each configurable system in the CMDB that corresponds to of said target system, and contains at least one CI that includes at least one of said specified software components;
said manifest includes a set of descriptors that respectively describe elements of said target system, and said descriptors comprise one or more system prerequisites, wherein said prerequisites are used to search said CMDB to identify a first system, that includes one of said specified software components, and
for a given CI that includes at least one of said specified software components, instructions for identifying every other CI in the CMDB that would be affected the software maintenance patch if the software maintenance patch was used to update each specified software component of the given CI.
12. The computer program product of claim 11, wherein:
said method includes generating an impact analysis report that discloses each of said identified CIs, and further discloses an anticipated effect on each identified CI if the maintenance patch is used to update respective specified software components of said CMDB.
13. The computer program product of claim 11, wherein:
said manifest comprises a set of descriptors that respectively describe elements of said target system, said descriptors including one or more system prerequisites, wherein said prerequisites are used to search said CMDB to identify a first system that includes one of said specified software components, and said CMDB is searched by comparing each of said descriptors with descriptions of respective elements of said configurable systems, said element descriptions being respectively contained in the CMDB.
14. The computer program product of claim 11, wherein:
said manifest includes prerequisites for use in distinguishing between CIs to which said software maintenance patch is and is not applicable, respectively, and said manifest includes a description of the contents of said software maintenance patch.
15. The computer program product of claim 11, wherein:
said manifest comprises an XML-based text file.
16. In association with a configuration management database (CMDB) containing information that relates to configuration items (CIs) included in one or more managed configurable systems, a computer apparatus comprising a non-transitory computer readable medium, and further comprising:
a component for generating a manifest that defines a target system, and contains a description of a software maintenance patch disposed to update one or more specified software components of the target system;
a component for using information contained in the manifest to search the CMDB, in order to detect each configurable system in the CMDB that corresponds to of said target system, and contains at least one CI that includes at least one of said specified software components;
said manifest includes a set of descriptors that respectively describe elements of said target system, and said descriptors comprise one or more system prerequisites, wherein said prerequisites are used to search said CMDB to identify a first system, that includes one of said specified software components, and
for a given CI that includes at least one of said specified software components, a component for identifying every other CI in the CMDB that would be affected by the software maintenance patch if the software maintenance patch was used to update each specified software component of the given CI.
17. The apparatus of claim 16, wherein:
said apparatus includes a component for generating an impact analysis report that discloses each of said identified CIs, and further discloses an anticipated effect on each identified CI if the maintenance patch is used to update respective specified software components of said CMDB.
18. The apparatus of claim 16, wherein:
said manifest comprises a set of descriptors that respectively describe elements of said target system, said descriptors including one or more system prerequisites, wherein said prerequisites are used to search said CMDB to identify a first system that includes one of said specified software components, and said CMDB is searched by comparing each of said descriptors with descriptions of respective elements of said configurable systems, said elements descriptions being respectively contained in the CMDB.
19. The apparatus of claim 16, wherein:
said manifest includes prerequisites for use in distinguishing between CIs to which said software maintenance patch is and is not applicable, respectively, and said manifest includes a description of the contents of said software maintenance patch.
20. The apparatus of claim 16, wherein:
said manifest comprises an XML-based text file.
US12/251,489 2008-10-15 2008-10-15 Analysis of effects of a software maintenance patch on configuration items of a CMDB Expired - Fee Related US8302088B2 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US12/251,489 US8302088B2 (en) 2008-10-15 2008-10-15 Analysis of effects of a software maintenance patch on configuration items of a CMDB
CN2009101795170A CN101727477B (en) 2008-10-15 2009-10-12 Method and device for analysis of effects of a software maintenance patch on configuration items of a cmdb

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US12/251,489 US8302088B2 (en) 2008-10-15 2008-10-15 Analysis of effects of a software maintenance patch on configuration items of a CMDB

Publications (2)

Publication Number Publication Date
US20100095273A1 US20100095273A1 (en) 2010-04-15
US8302088B2 true US8302088B2 (en) 2012-10-30

Family

ID=42100051

Family Applications (1)

Application Number Title Priority Date Filing Date
US12/251,489 Expired - Fee Related US8302088B2 (en) 2008-10-15 2008-10-15 Analysis of effects of a software maintenance patch on configuration items of a CMDB

Country Status (2)

Country Link
US (1) US8302088B2 (en)
CN (1) CN101727477B (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8713554B1 (en) * 2012-09-14 2014-04-29 Emc Corporation Automated hotfix handling model
US8924935B1 (en) 2012-09-14 2014-12-30 Emc Corporation Predictive model of automated fix handling
US20150039360A1 (en) * 2013-07-31 2015-02-05 Yahoo! Inc. Dependency management for enterprise computing
US9026996B2 (en) 2007-01-26 2015-05-05 International Business Machines Corporation Providing assistance in making change decisions in a configurable managed environment
US9632922B2 (en) 2014-02-28 2017-04-25 International Business Machines Corporation Workload mapper for potential problem areas using modules and defect data
US11729057B1 (en) 2022-02-07 2023-08-15 The Bank Of New York Mellon Application architecture drift detection system

Families Citing this family (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8712973B2 (en) * 2006-04-11 2014-04-29 International Business Machines Corporation Weighted determination in configuration management systems
WO2010027477A1 (en) * 2008-09-02 2010-03-11 Belarc, Inc. System and method for software usage discovery
US8799436B2 (en) * 2009-07-14 2014-08-05 International Business Machines Corporation System and method for automated configuration control, audit verification and process analytics
GB2503486A (en) * 2012-06-28 2014-01-01 Ibm Managing changes to files
CN103870349B (en) * 2012-12-18 2017-06-23 中国银联股份有限公司 For the configuration management device and method of data handling system
US9626176B2 (en) * 2013-09-13 2017-04-18 Microsoft Technology Licensing, Llc Update installer with technical impact analysis
US9665359B2 (en) 2013-09-13 2017-05-30 Microsoft Technology Licensing, Llc Automatically resolving conflicts after installation of selected updates in a computer system
US10026064B2 (en) 2013-09-13 2018-07-17 Microsoft Technology Licensing, Llc Automatically recommending updates based on stored lifecycle information
US9830142B2 (en) 2013-09-13 2017-11-28 Microsoft Technology Licensing, Llc Automatic installation of selected updates in multiple environments
AU2015369780B2 (en) * 2014-12-22 2018-01-04 Servicenow, Inc. Auto discovery of configuration items
US20170337055A1 (en) * 2016-05-23 2017-11-23 International Business Machines Corporation Summarized illustrative representation of software changes
CN108200111B (en) * 2016-12-08 2021-01-05 中国移动通信集团山西有限公司 Resource configuration information updating method and device and resource interface equipment
US10606583B2 (en) 2017-12-08 2020-03-31 International Business Machines Corporation Software change tracking and management
CN113946592B (en) * 2021-12-21 2022-03-22 湖南天云软件技术有限公司 Configuration management database updating method, device, equipment, medium and program product

Citations (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5084813A (en) * 1988-04-20 1992-01-28 Kabushiki Kaisha Toshiba Rule based system for synthesizing a program suited for a target system in response to an input target system specification
US6237020B1 (en) * 1996-10-01 2001-05-22 International Business Machines Corporation Task-oriented automatic distribution of software
US6301707B1 (en) * 1997-09-30 2001-10-09 Pitney Bowes Inc. Installing software based on a profile
US20030025732A1 (en) * 2001-07-31 2003-02-06 Prichard Scot D. Method and apparatus for providing customizable graphical user interface and screen layout
US20030046675A1 (en) * 1996-06-07 2003-03-06 William Cheng Automatic updating of diverse software products on multiple client computer systems
US6615166B1 (en) * 1999-05-27 2003-09-02 Accenture Llp Prioritizing components of a network framework required for implementation of technology
US6704737B1 (en) * 1999-10-18 2004-03-09 Fisher-Rosemount Systems, Inc. Accessing and updating a configuration database from distributed physical locations within a process control system
US20040210653A1 (en) * 2003-04-16 2004-10-21 Novadigm, Inc. Method and system for patch management
US20050071838A1 (en) * 2003-09-30 2005-03-31 Keisuke Hatasaki System-updating method and computer system adopting the method
US20050097547A1 (en) * 2003-10-30 2005-05-05 International Business Machines Corporation Autonomic auto-configuration using prior installation configuration relationships
US20050228798A1 (en) * 2004-03-12 2005-10-13 Microsoft Corporation Tag-based schema for distributing update metadata in an update distribution system
US20050278342A1 (en) 2004-06-14 2005-12-15 Microsft Corporation System and method for auditing a network
US20060004875A1 (en) * 2004-05-11 2006-01-05 Microsoft Corporation CMDB schema
US20060010434A1 (en) * 2004-07-07 2006-01-12 Wolfgang Herzog Providing customizable configuration data in computer systems
US7051327B1 (en) * 2001-05-08 2006-05-23 Gateway Inc. System for providing data backup and restore with updated version by creating data package based upon configuration data application data and user response to suggestion
US20060117310A1 (en) * 2004-11-24 2006-06-01 Microsoft Corporation Method and system for analyzing the impact of a software update
US20060122937A1 (en) * 2003-03-10 2006-06-08 Cyberscan Technology, Inc. Universal method for submitting gaming machine source code software to a game certification laboratory
US20060123040A1 (en) * 2004-12-03 2006-06-08 International Business Machines Corporation Algorithm for automated enterprise deployments
US20060225032A1 (en) 2004-10-29 2006-10-05 Klerk Adrian D Business application development and execution environment
US7222349B1 (en) * 2003-06-30 2007-05-22 Veritas Operating Corporation External device support for device abstraction layer
US20070157192A1 (en) * 2005-12-30 2007-07-05 Dorothea Hoefler Software maintenance management
US20070169079A1 (en) * 2005-11-08 2007-07-19 Microsoft Corporation Software update management
US20070234331A1 (en) * 2006-01-06 2007-10-04 Sun Microsystems, Inc. Targeted automatic patch retrieval
US20070239700A1 (en) * 2006-04-11 2007-10-11 Ramachandran Puthukode G Weighted Determination in Configuration Management Systems
US20080125878A1 (en) * 2006-08-23 2008-05-29 International Business Machines Corporation Method and system to detect application non-conformance
US20080183690A1 (en) * 2007-01-26 2008-07-31 Ramachandran Puthukode G Method for providing assistance in making change decisions in a configurable managed environment
US20090271698A1 (en) * 2008-04-23 2009-10-29 Alcatel Lucent System reporter-repository auditor
US7822785B2 (en) * 2006-06-30 2010-10-26 International Business Machines Corporation Methods and apparatus for composite configuration item management in configuration management database
US7831325B1 (en) * 2005-04-18 2010-11-09 Hewlett-Packard Development Company, L.P. Computing estimated performance of a software application in a target system
US7913227B2 (en) * 2007-02-28 2011-03-22 International Business Machines Corporation Methods and apparatus for management of configuration item lifecycle state transitions
US7926031B2 (en) * 2007-04-18 2011-04-12 Hewlett-Packard Development Company, L.P. Configuration management database and system

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060004832A1 (en) * 2004-06-10 2006-01-05 Langsford Richard G Enterprise infrastructure management appliance

Patent Citations (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5084813A (en) * 1988-04-20 1992-01-28 Kabushiki Kaisha Toshiba Rule based system for synthesizing a program suited for a target system in response to an input target system specification
US20030046675A1 (en) * 1996-06-07 2003-03-06 William Cheng Automatic updating of diverse software products on multiple client computer systems
US6237020B1 (en) * 1996-10-01 2001-05-22 International Business Machines Corporation Task-oriented automatic distribution of software
US6301707B1 (en) * 1997-09-30 2001-10-09 Pitney Bowes Inc. Installing software based on a profile
US6615166B1 (en) * 1999-05-27 2003-09-02 Accenture Llp Prioritizing components of a network framework required for implementation of technology
US6704737B1 (en) * 1999-10-18 2004-03-09 Fisher-Rosemount Systems, Inc. Accessing and updating a configuration database from distributed physical locations within a process control system
US7051327B1 (en) * 2001-05-08 2006-05-23 Gateway Inc. System for providing data backup and restore with updated version by creating data package based upon configuration data application data and user response to suggestion
US20030025732A1 (en) * 2001-07-31 2003-02-06 Prichard Scot D. Method and apparatus for providing customizable graphical user interface and screen layout
US20060122937A1 (en) * 2003-03-10 2006-06-08 Cyberscan Technology, Inc. Universal method for submitting gaming machine source code software to a game certification laboratory
US20040210653A1 (en) * 2003-04-16 2004-10-21 Novadigm, Inc. Method and system for patch management
US7222349B1 (en) * 2003-06-30 2007-05-22 Veritas Operating Corporation External device support for device abstraction layer
US20050071838A1 (en) * 2003-09-30 2005-03-31 Keisuke Hatasaki System-updating method and computer system adopting the method
US20050097547A1 (en) * 2003-10-30 2005-05-05 International Business Machines Corporation Autonomic auto-configuration using prior installation configuration relationships
US20050228798A1 (en) * 2004-03-12 2005-10-13 Microsoft Corporation Tag-based schema for distributing update metadata in an update distribution system
US20060004875A1 (en) * 2004-05-11 2006-01-05 Microsoft Corporation CMDB schema
US20050278342A1 (en) 2004-06-14 2005-12-15 Microsft Corporation System and method for auditing a network
US20060010434A1 (en) * 2004-07-07 2006-01-12 Wolfgang Herzog Providing customizable configuration data in computer systems
US20060225032A1 (en) 2004-10-29 2006-10-05 Klerk Adrian D Business application development and execution environment
US20060117310A1 (en) * 2004-11-24 2006-06-01 Microsoft Corporation Method and system for analyzing the impact of a software update
US20060123040A1 (en) * 2004-12-03 2006-06-08 International Business Machines Corporation Algorithm for automated enterprise deployments
US7831325B1 (en) * 2005-04-18 2010-11-09 Hewlett-Packard Development Company, L.P. Computing estimated performance of a software application in a target system
US20070169079A1 (en) * 2005-11-08 2007-07-19 Microsoft Corporation Software update management
US20070157192A1 (en) * 2005-12-30 2007-07-05 Dorothea Hoefler Software maintenance management
US20070234331A1 (en) * 2006-01-06 2007-10-04 Sun Microsystems, Inc. Targeted automatic patch retrieval
US20070239700A1 (en) * 2006-04-11 2007-10-11 Ramachandran Puthukode G Weighted Determination in Configuration Management Systems
US7822785B2 (en) * 2006-06-30 2010-10-26 International Business Machines Corporation Methods and apparatus for composite configuration item management in configuration management database
US20080125878A1 (en) * 2006-08-23 2008-05-29 International Business Machines Corporation Method and system to detect application non-conformance
US20080183690A1 (en) * 2007-01-26 2008-07-31 Ramachandran Puthukode G Method for providing assistance in making change decisions in a configurable managed environment
US20110239191A1 (en) * 2007-01-26 2011-09-29 International Business Machines Corporation Method for Providing Assistance in Making Change Decisions in a Configurable Managed Environment
US7913227B2 (en) * 2007-02-28 2011-03-22 International Business Machines Corporation Methods and apparatus for management of configuration item lifecycle state transitions
US7926031B2 (en) * 2007-04-18 2011-04-12 Hewlett-Packard Development Company, L.P. Configuration management database and system
US20090271698A1 (en) * 2008-04-23 2009-10-29 Alcatel Lucent System reporter-repository auditor

Non-Patent Citations (8)

* Cited by examiner, † Cited by third party
Title
C. Word et al., "Integrated change and configuration management",[Online], IBM System Journal, 2007, pp. 459-478, [Retrieved from Internet on Jun. 20, 2012], . *
C. Word et al., "Integrated change and configuration management",[Online], IBM System Journal, 2007, pp. 459-478, [Retrieved from Internet on Jun. 20, 2012], <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=5386575>. *
H. Madduri et al. "A configuration management database architecture in support of IBM Service Management", [Online], 2007, pp. 441-457, [Retrived from Internet on Jun. 20, 2012], . *
H. Madduri et al. "A configuration management database architecture in support of IBM Service Management", [Online], 2007, pp. 441-457, [Retrived from Internet on Jun. 20, 2012], <http://ieeexplore.ieee.org/stamp/stamp.jsp ?tp=&arnumber=5386571>. *
Thoma Kunz et al., "Fast Detection of Communication Patterns in Distributed Executions",[Online], Proceding Cascon 1997, pp. 1-263, [Retrieved from Internet on Jun. 20, 2012] . *
Thoma Kunz et al., "Fast Detection of Communication Patterns in Distributed Executions",[Online], Proceding Cascon 1997, pp. 1-263, [Retrieved from Internet on Jun. 20, 2012] <http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.86.5228&rep=rep1&type=pdf>. *
Vincenzo Ambriola et al., "The Evolution of Configuration Management and Version Control" [Online], May 22, 1996, pp. 1-16, [Retrieved from Internet on Jun. 20, 2012], . *
Vincenzo Ambriola et al., "The Evolution of Configuration Management and Version Control" [Online], May 22, 1996, pp. 1-16, [Retrieved from Internet on Jun. 20, 2012], <http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.36.9203&rep=rep1&type=pdf>. *

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9026996B2 (en) 2007-01-26 2015-05-05 International Business Machines Corporation Providing assistance in making change decisions in a configurable managed environment
US8713554B1 (en) * 2012-09-14 2014-04-29 Emc Corporation Automated hotfix handling model
US8924935B1 (en) 2012-09-14 2014-12-30 Emc Corporation Predictive model of automated fix handling
US20150039360A1 (en) * 2013-07-31 2015-02-05 Yahoo! Inc. Dependency management for enterprise computing
US9632922B2 (en) 2014-02-28 2017-04-25 International Business Machines Corporation Workload mapper for potential problem areas using modules and defect data
US9658948B2 (en) 2014-02-28 2017-05-23 International Business Machines Corporation Workload mapper for potential problem areas using modules and defect data
US11729057B1 (en) 2022-02-07 2023-08-15 The Bank Of New York Mellon Application architecture drift detection system

Also Published As

Publication number Publication date
CN101727477B (en) 2012-09-05
US20100095273A1 (en) 2010-04-15
CN101727477A (en) 2010-06-09

Similar Documents

Publication Publication Date Title
US8302088B2 (en) Analysis of effects of a software maintenance patch on configuration items of a CMDB
CN100576172C (en) A kind of method of determining that function point changes that changes by code analysis
US9063808B2 (en) Deploying a package for a software application
US9417865B2 (en) Determining when to update a package manager software
US8631390B2 (en) Archiving a build product
US9116597B1 (en) Information management software
US9026996B2 (en) Providing assistance in making change decisions in a configurable managed environment
US9513902B2 (en) Automated code coverage measurement and tracking per user story and requirement
US20160306612A1 (en) Determining errors and warnings corresponding to a source code revision
US20120159443A1 (en) System and method for reducing test effort by object risk analysis
US9086942B2 (en) Software discovery by an installer controller
US9317258B2 (en) Dynamic validation of models using constraint targets
US8438576B2 (en) Generating and using constraints associated with software related products
US20110161931A1 (en) Automated stream-based change flows within a software configuration management system
US9256827B2 (en) Portable data management using rule definitions
US20140344006A1 (en) Analytics based service catalog management
US9052966B1 (en) Migrating code from a source format to a target format
CN111654495B (en) Method, apparatus, device and storage medium for determining traffic generation source
JP2008009861A (en) System configuration management method
US8782626B2 (en) Search suggestions for static code analysis
US8479163B2 (en) Simplifying maintenance of large software systems
US20160062790A1 (en) Design analysis of data integration job
US20090259986A1 (en) Class selectable design sharing
JP2006294019A (en) Generic software requirement analyzer
KR20190020363A (en) Method and apparatus for analyzing program by associating dynamic analysis with static analysis

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION,NEW YO

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MATTHIESEN, BRIAN ROBERT;REEL/FRAME:021682/0779

Effective date: 20081013

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MATTHIESEN, BRIAN ROBERT;REEL/FRAME:021682/0779

Effective date: 20081013

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Expired due to failure to pay maintenance fee

Effective date: 20201030