1. Field of the Invention
The invention disclosed and claimed herein generally pertains to a method for providing assistance in decision making in a configurable managed environment or system, that includes a configuration management database (CMDB) and configuration items (CI). More particularly, the invention pertains to a method of the above type for providing assistance in determining whether or not to make a change in the system that would affect one or more of the CIs. Even more particularly, the invention pertains to a method of the above type for computing a confidence level representing the probability that information provided by the CMDB is accurate. The Change Manager also gets the information on the impact of the proposed change.
2. Description of the Related Art
Configuration management is a critical process responsible for identifying, controlling and tracking all versions of hardware, software, documentation, and other inanimate components of a configurable managed environment, such as an Information Technology organization. The goal of configuration management is to ensure that only authorized components, referred to as configuration items (CIs), are used in the configurable managed environment, and that all changes to CIs are recorded and tracked throughout the life cycle of the component. The configuration management process includes performing tasks such as identifying CIs and their relationships, and adding them to the CMDB. The CMDB is a database that contains all relevant details for each CI, such as relationships between CIs, state or status, and historical information. Some examples of CIs are Computer System, Application Server etc. The data and relationships in the CMDB are used by a system manager, referred to as a Change Manager, for making changes in the configurable managed environment or system, wherein the changes generally will affect one or more of the configuration items. A definition of the Change Manager, provided by the Information Technology Infrastructure Library (ITIL), is set forth hereinafter.
The CMDB nominally contains the latest information of the above type for all CIs, such as the states and relationships thereof. Information about respective CIs is referred to herein as configuration item data (CID). In a configurable managed environment, as events occur that change the states or relationships of respective CIs, the CMDB must be synchronized accordingly. That is, the CMDB must be updated, so that the data contained therein will represent the new CID, that is, new realities of the CIs. However, in a configurable managed environment of the above type, multiple point products are commonly present that create and change relationships among the CIs. Such point products are described hereinafter in further detail, and may, for example, comprise devices such as the Tivoli Configuration Manager (TCM), a product of International Business Machines Corporation. The multiple point products are also commonly used to report changed conditions of the CIs to the CMDB.
Because the CMDB receives CI change data from different point products, it can happen that data received from the different point products, in regard to the same CIs, will be in conflict. Moreover, delays of varying lengths may occur between actual changes of CI conditions, and the reporting of such changed conditions to the CMDB. As a result, a typical CMDB that is being populated with data from multiple point product sources cannot be kept in synchronization with the actual real world condition of all CIs, since it is virtually impossible to keep CID synchronization up to date.
In a configurable managed environment or system, Change Managers make systems management decisions based on the state and relationships of the CIs, as shown by information in the CMDB. Some changes to the environment are trivial, while other changes can have serious consequences. For example, a change such as disabling a monitoring service on a hardware CI will usually be of low impact, while deleting a software component from a server for a change management operation can have serious consequences. However, as discussed above, CMDB information available to the Change Manager is likely to contain inaccuracies, even though such information is to be used as the basis for making changes. Accordingly, it would be desirable to provide the Change Manager with a tool that could serve as an aid in determining whether or not to make certain changes that affect CIs. The tool would take into account both the possibility of inaccurate CMDB information, and the comparative impact of the proposed change and provide information on the probability of a given change being successful or a failure.
In association with a CMDB containing information that relates to configuration items (CIs) in a configurable managed system, wherein a change station is provided to make respective changes, a method is provided for determining whether to allow a particular change that would affect at least one of the CIs. The method comprises the steps of acquiring information from the CMDB pertaining to CIs that would be affected by the particular change, and processing the acquired information to compute a confidence level indicating the probability that the acquired information is correct. A particular change is then allowed to be made in the configurable system only if the confidence level is no less than a pre-specified minimum value.
The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
Referring to
Referring further to
Since information is supplied to CMDB 112 from multiple product point sources, it frequently happens that two or more sources send information to the CMDB that all pertains to the same CI. Also, if the CI includes a number of different configurable elements, information sent to the CMDB for the CI may include data representing the value or state of each element. For example, if the CI comprises a computer component having a hard drive, data stored in the CMDB for the CI could include a value indicating the hard drive storage capacity.
Change station 110 is operable by the Change Manager or other user to establish and change relationships between respective CIs. Accordingly, change station 110 is provided with a user interface as further indicated at
Referring to
Referring further to
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
The CI data reported from multiple products is in a standard form, and the CI information from all the products is consolidated into a single CI data item. As discussed above, it is likely that at any given time, at least some of the data stored in the CMDB for a particular CI will not be accurate. This is due in part to delay between an actual change in the condition or state of a CI, and the reporting of the change to the CMDB. Inaccuracies can also result from conflicts in information pertaining to a CI that is reported to the CMDB by different point products. Thus, when the Change Manager is tasked with making a proposed change to the configurable managed system 100, wherein the change will affect one or more CIs, change station 110 can be used to implement a procedure in accordance with the embodiment of the invention, as illustrated by
Referring to
At step 304, information stored in the CMDB for one of the identified CIs is selected or acquired from the CMDB, wherein the acquired information is relevant to the proposed change. For example, the proposed change could require loading an application into the hard drive of a particular CI, so that it would be necessary to know the available capacity of the hard drive. While the CMDB might contain reports listing information for a number of elements of the particular CI, only the value of hard drive capacity would be pertinent to the proposed change. Step 304 would be carried out for all of the CIs identified at step 302.
It will be appreciated that in some situations a particular source of information will have such authority, relative to competing sources, that the conflicting data from the other competing sources will not be considered. For example, Service Advertising Protocol (SAP) is a service for managing server assets in a system. When a server is first brought into the system, SAP makes a record of the server model and serial number, and of the operating system placed therein. A year later, a point product conducts a scan and indicates that a different operating system is in the server. The SAP is an authoritative system, but its information can be out of date, if the operating system was changed but the SAP was not informed of the change. On the other hand, the point product can perform a scan to correctly identify the operating system, at the time such information is requested. Accordingly, the point product data will simply be accepted over the data from SAP.
As a further example for illustrating the embodiment of
More generally, where there are discrepancies or disagreements between multiple reports in the CMDB for a CI or CI element, weights are assigned to the CI based on one or more criteria. These criteria can include the number of times a CI has been read by other CIs, the number of times a CI has been written to or updated by other CIs, the number of relationships that a CI has with other CIs, as shown by information in the CMDB, and how recently a CI was last accessed or updated.
Moreover, if one report for a CI element is several years old and another report is very recent, the more recent report will be given significantly higher weight. Generally, a weight can be determined on the basis of a known update or synchronization by a point product source, or can be based on a reported revision level, patch level or update level, giving greater weight to the most recent of such events. A weight can also be based on the date of a report or most recent report update, or on the frequency of access to the report.
After weighting the accuracy of the information for each of the CIs, such as by using one or more of the weighting approaches described above, one of the sources may appear to be so much more reliable than all others that the data from such source will be selected as the correct data. Otherwise, it is necessary to compute an over-all confidence level, as shown by step 308 of
Confidence Level=(X*No. of writes to the CI)/(Y*No. of CI Relationships)
where X and Y are constants. Thus, confidence level is increased by increasing the number of writes to the CR, and decreased by decreasing the number of relationships.
As a further example, it is proposed that the configurable managed system 100 be changed by loading a specified software application into the hard drive of a server, wherein both the application software and the server are CIs of system 100. To perform this task, the server hard drive must have enough available capacity to accommodate the size of the application. From steps 304 and 306 discussed above, change station 110 has determined that the application requires X MB of storage, with an 80% weighting that this information is correct. Similarly, change station 110 has determined that the hard drive of the server has available storage capacity of X MB, with a 70% weighting that this information is accurate. Accordingly, change station 110 carries out step 308 of
At step 310, it is necessary to select the minimum acceptable value of confidence level (CLmin) for the proposed change. This value could be predetermined for a possible or prospective change to a CI, and would correspond to the comparative amount of harm that would result if the change was carried out based on information found to be incorrect. In one embodiment, a table would be preconfigured to list a number of specified changes that could be made to system 100. The table would further list the minimum confidence level values needed to allow respective listed changes to be made. The table (not shown) could reside in the CMBD, or elsewhere in system 100. The determination of confidence level would generally be based on heuristics, or knowledge based on experience. It could also be based on collected historical data, that was continually updated.
For the above example, an inability to load the software application into the server would be a comparatively adverse consequence for system 100. Accordingly, the minimum confidence level to allow this proposed task to proceed is usefully predetermined to be 70%. Such value would therefore be selected from the table by change station 110, in accordance with step 310 of
The following are examples of changes that a Change Manager could execute, after finding that the confidence level was at or above the minimum acceptable value:
As a further feature, an embodiment of the invention can be configured to provide notice to a user, when a confidence level is found to be below the acceptable minimum. Also, a Change Manager may be authorized in certain situations to execute a change, even when the confidence level is less than the acceptable minimum value. For example, notwithstanding a low confidence level, the Change Manager may be willing to risk possible inaccuracies, where action is necessary to avoid hacking or the loss of important data.
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.
This application is a continuation of application Ser. No. 11/627,398, filed Jan. 26, 2007, status abandoned.
Number | Name | Date | Kind |
---|---|---|---|
5914879 | Wang et al. | Jun 1999 | A |
6128730 | Levine | Oct 2000 | A |
6385770 | Sinander | May 2002 | B1 |
6704737 | Nixon et al. | Mar 2004 | B1 |
6804632 | Orenstein | Oct 2004 | B2 |
6832346 | Cross | Dec 2004 | B2 |
6968540 | Beck et al. | Nov 2005 | B2 |
6988056 | Cook | Jan 2006 | B2 |
7051243 | Helgren et al. | May 2006 | B2 |
7072936 | Sturtevant et al. | Jul 2006 | B2 |
7080168 | Dasgupta et al. | Jul 2006 | B2 |
7177870 | Jokela et al. | Feb 2007 | B2 |
7254522 | Tsalakopoulos | Aug 2007 | B2 |
7334226 | Ramachandran et al. | Feb 2008 | B2 |
7343623 | Ross | Mar 2008 | B2 |
7500234 | Hatasaki | Mar 2009 | B2 |
7747987 | Akarte et al. | Jun 2010 | B1 |
7756828 | Baron et al. | Jul 2010 | B2 |
7765094 | Bodden et al. | Jul 2010 | B2 |
7783973 | Banavar et al. | Aug 2010 | B2 |
7913227 | Aikens et al. | Mar 2011 | B2 |
7926031 | Faihe et al. | Apr 2011 | B2 |
20020133541 | Sturtevant et al. | Sep 2002 | A1 |
20020184247 | Jokela et al. | Dec 2002 | A1 |
20020199194 | Ali | Dec 2002 | A1 |
20030018451 | Sullivan et al. | Jan 2003 | A1 |
20030061132 | Yu, Sr. et al. | Mar 2003 | A1 |
20030110012 | Orenstein | Jun 2003 | A1 |
20030130887 | Nathaniel | Jul 2003 | A1 |
20030204791 | Helgren et al. | Oct 2003 | A1 |
20040002880 | Jones | Jan 2004 | A1 |
20040039917 | Ross | Feb 2004 | A1 |
20040143600 | Musgrove et al. | Jul 2004 | A1 |
20040162887 | Dillon et al. | Aug 2004 | A1 |
20040220782 | Cook | Nov 2004 | A1 |
20050015388 | Dasgupta et al. | Jan 2005 | A1 |
20050065839 | Benson et al. | Mar 2005 | A1 |
20050071838 | Hatasaki | Mar 2005 | A1 |
20050097150 | McKeon et al. | May 2005 | A1 |
20050097547 | Ramachandran et al. | May 2005 | A1 |
20050144022 | Evans | Jun 2005 | A1 |
20050210048 | Beres et al. | Sep 2005 | A1 |
20060004875 | Baron et al. | Jan 2006 | A1 |
20060031371 | Uthe | Feb 2006 | A1 |
20060101421 | Bodden et al. | May 2006 | A1 |
20060149501 | Tsalakopoulos | Jul 2006 | A1 |
20060161879 | Lubrecht et al. | Jul 2006 | A1 |
20070203952 | Baron et al. | Aug 2007 | A1 |
20070234331 | Schow et al. | Oct 2007 | A1 |
20070239700 | Ramachandran | Oct 2007 | A1 |
20080140778 | Banavar et al. | Jun 2008 | A1 |
20080183690 | Ramachandran | Jul 2008 | A1 |
20090012997 | Rajaraman et al. | Jan 2009 | A1 |
20090019046 | Coley et al. | Jan 2009 | A1 |
20090248596 | Matsumoto et al. | Oct 2009 | A1 |
20100095273 | Matthiesen | Apr 2010 | A1 |
20100185658 | Kowalski | Jul 2010 | A1 |
Entry |
---|
H. Madduri et al.,“A configuration management database architecture in support of IBM Service Management”,[0nline], 2007, pp. 441-457, [Retrieved from Internet on Jan. 29, 2013, <http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.113.3729&rep=rep1 &type=pdf>. |
Vincenzo Amcroila et al., “The evolution of configuration management and version control” ,[Online], Software Engineering Journal, Nov. 1990, pp. 303-310, [Retrived from Internet on Jan. 29, 2013, <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=61744>. |
C. Word et al., “Integrated change and configuration management”, [Online], IBM System Journal, 2007, pp. 459-478, [Retrieved froma Internet on Jan. 29, 2013], <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=5386575>. |
Hagen Volzer et al., “A Tool for Subsystem Configuration Management”, [Online] , The University of Queessland Australia, Mar. 18, 2002, pp. 1-11, [Retrieved from Internet on Jan. 29, 2013], <http://itee.uq.edu.au/˜pal/SVRC/tr02-07.pdf>. |
Madduri et al., “A Configuration Management Database Architecture in Support of IBM Service Management”, 2007, pp. 1-17. <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=5386571>. |
Amcroila et al., “The Evolution of Configuration Management and Version Control”, Software Engineering Journal, Nov. 1990, pp. 303-310. <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=61744>. |
Word et al., “Integrated Change and Configuration Management”, IBM System Journal, 2007, pp. 1-20. <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=5386575>. |
Kunz et al., “Fast Detection of Communication Patterns in Distributed Executions”, Proceding Cascon 1997, pp. 1-263. <http://delivery.acm.org/10.1145/790000/782022/p12kunz.pdf?key1=782022&key2=0647473031&coll=DL&dl=ACM&ip=151.207.242.4&CFID=19577917&CFTOKEN=62294010>. |
Elnaffar, “A Methodology for Auto-recognizing DBMS Workloads”, IBM Canada, 2002, pp. 1-15. <http://delivery.acm.org/10.1145/790000/782117/p2elnaffar.pdf?key1=782117&key2=3957473031&coll=DL&dl=ACM&ip=151.207.242.4&CFID=19577917&CFTOKEN=62294010>. |
Volzer et al., “A Tool for Subsystem Configuration Management”, The University of Queessland Australia, Mar. 18, 2002, pp. 1-11. <http://itee.uq.edu.au/˜pal/SVRC/tr02-07.pdf>. |
Bezenchek et al., “A Data Structure for Representing Aggregate Data”, IEEE, 1996, pp. 22-31. |
“Service Management Functions, Configuration Management”, Microsoft TechNet, Updated: Mar. 26, 2004, pp. 1-26. http://www.microsoft/com/technet/itsolutions/cits/mo/smf/smfcfgmg.mspx. |
Mueller, “Taking the Configuration Management Database to the Next Level: The Federated Data Model”, Computerworld, Apr. 18, 2005, pp. 1-4. http://www.computerworld.com/printthis/2005/0,4818,101081,00.html. |
Lee et al., “Integrated Configuration Management System (ICMS) for Computer System Development” Innovation in Technology Management—The Key to Global Leadership. PICMET '97; Portland International Conference on Management and Technology, Jul. 27-31, 1997, pp. 472-475. |
Coster, “Configuration Management: How it Applies to Expert Systems”, Project Management, Costing and Quality Assurance, IEE Colloquium on Oct. 28, 1988, pp. 4/1-4/4. |
USPTO Office Action for U.S. Appl. No. 11/627,398 dated Dec. 8, 2010. |
USPTO Notice of Allowance for U.S. Appl. No. 11/627,398 dated May 2, 2011. |
Number | Date | Country | |
---|---|---|---|
20110239191 A1 | Sep 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11627398 | Jan 2007 | US |
Child | 13159114 | US |