System and Method for Updating Network Computer Systems
An update system configured to provide software updates, software patches and/or other data packets to one or more computer systems via a network is disclosed. The update system may interact with a network management system, such as an enterprise management system, to distribute data packets and gather configuration information. The update system may generate and send commands to the network management system. The network management system may carry out the commands to distribute data packets and/or gather configuration information.
This application is a continuation application of U.S. patent application Ser. No. 10/242,309 entitled “SYSTEM AND METHOD FOR ENHANCED SOFTWARE UPDATING AND REVISION” filed by Aderton, et al. on Sep. 12, 2002. The above-referenced application is hereby incorporated by reference as if fully set forth herein.
BACKGROUND OF THE INVENTION1. Field of the Invention
Embodiments disclosed herein generally relate to the field of control of computer networks. More particularly, the present invention relates to a system and method for controlling distribution of data packets to one or more computer systems coupled to a network of computers.
2. Description of the Related Art
It has become quite common for organizations to have computer networks spanning large areas and/or including a large number of computer systems. For example, many government, commercial and educational organizations have networks that include hundreds of computers distributed over very large areas. Some of these networks are literally global. The number and distribution of computer systems on such networks makes managing them a difficult and resource intensive task. On top of this difficulty is the increased need for security in many networks. Both the increase in hostile code (e.g., viruses, worms, etc.) and the prevalence of attacks on networks by individuals (e.g., hackers) cause network security to be a high priority in many organizations.
In addition to security concerns, organizations managing a network may desire to have some control over software applications that are installed on computers coupled to the network. Such control may be desirable to ensure software compatibility, licensing control, etc.
Several categories of software tools have been created to help administrators (including network administrators and system or desktop systems administrators) deal with the challenge of configuration management over networks. Some such tools are commonly referred to as enterprise management systems (EMS) or network management systems. An EMS may allow an administrator to control a computer system remotely. Thus, the EMS may allow the administrator to determine the configuration of the computer system. The EMS may also allow the administrator to alter the configuration. For example, the administrator may be able to remotely install software onto a computer system. An EMS may also assist an administrator in overseeing network access functions.
Another category of software tools is the patch management system. Patch management systems are designed to assist an administrator in distributing one or more software updates, or patches, to a number of computer systems substantially simultaneously. The software update process is often done in the background so that a user of the computer system is not affected by the update. Patch management systems may be divided into two categories, agent based and non-agent based. An agent based patch management system requires that an agent application, associated with the patch management system, be installed on each computer system that the patch management system will be updating. In a large network, installing an agent on each computer may be very time consuming and resource intensive. Non-agent based systems do not require an agent; rather, they gather information regarding the computers coupled to the network remotely. This may be problematic at times if the network is not relatively static. Changes in the network may cause the non-agent based patch management system to be unable to access one or more computers on the network.
SUMMARY OF THE INVENTIONIn an embodiment, a method of providing data packets to a plurality of computer systems coupled to a network may include providing a network management system on the network. The network management system may include one or more agent programs on one or more computer systems coupled to the network. An agent program may be configured to receive commands from a network management system server and to implement received commands on the computer system. An update system may also be provided on the network. The update system may be configured to issue commands to the network management system for execution on the network management system server or on one or more computer systems coupled to the network. The update system may be configured by a user to identify one or more data packets and to associate one or more data packets with one or more computer systems. One or more commands may be generated in the update system and sent from the update system to the network management system. In response to one or more commands, the network management system may install one or more data packets on one or more computer systems coupled to the network. The network management system may utilize functions available to the network management system server and/or one or more network management system agents to install the data packet(s). In an embodiment, a log file may be stored on a computer system which lists commands received by the computer system from the update system via the network management system.
In some embodiments, the update system may also be configured to generate one or more commands, which cause the network management system to determine configuration information regarding one or more computer systems coupled to the network. Configuration information may include hardware and/or software configuration information. For example, the update system may also invoke functions of the network management system to determine whether one or more data packets were installed properly by the network management system.
In an embodiment, configuration information may be determined by scanning one or more computer systems coupled to the network using a scanning agent. Configuration information may be compared to a software list. Comparison of configuration information to the software list may be used to determine whether a data packet should be sent to a particular computer system or group of computer systems. The comparison may also be used to determine whether prohibited software applications are present on a computer system. The configuration information may be stored in a memory for use in making decisions and generating status reports. In certain embodiments, no additional software (e.g., agent applications) need to be installed on a computer system coupled to the network in order to execute the update system. In some embodiments, the update system may send its own scanning agent via the network management system to one or more computer systems coupled to the network. For example, the update system scanning agent may be used to provide a secondary verification of whether a data packet was installed properly by the network management system. In some of such embodiments, the update system scanning agent may not persist on computer systems to which it was sent after providing scanning information to the update system. For example, the update system scanning agent may be deleted from the computer systems.
An update system, in one embodiment, may allow a user to assign one or more computer systems coupled to the network to one or more groups. In such embodiments, data packets to be distributed may be associated with one or more computer systems and/or one or more groups.
An update system may be configured to send a data packet to a computer system based on one or more configured rules (or criteria). For example, a criterion may depend on whether one or more files having specified parameters exist on the computer system. In another example, a criterion may depend on whether one or more software applications having specified parameters exist on the computer systems. In another example, a criterion may depend on whether the registry file of the computer system meets specified parameters. Other examples may include whether an operating system of the computer systems meets specified parameters, whether a specified time has elapsed, whether an allowed number of attempts to send the data packet has been met, etc.
In an embodiment, one or more data packets may be provided in a memory associated with a network management system server. An update system may also be provided. The update system may be configured to provide one or more data packets to one or more computer systems on the network. The update system may attempt to place one or more data packets on one or more of the computer systems. After attempting to place one or more data packets on one or more computers, the update system may determine whether one or more of the placement attempts were successful (e.g., by scanning one or more computer systems). If one or more placement attempts were unsuccessful, the update system may determine if an allowed number of unsuccessful placement attempts for at least one computer system has been met. If the allowed number of unsuccessful placement attempts for at least one computer system has been met, the computer system may be inhibited from logging on to the network. If the computer system is in use, the computer system may be forcibly logged of the network.
In another embodiment, an update system may determine if one or more data packets are present on one or more computer systems (e.g., by scanning one or more computer systems). The update system may select one or more computer systems to which one or more additional data packets should be sent. For example, one or more computer systems may be sent additional data packets based on the configuration of the receiving computer system, a group to which the receiving computer system is assigned in the update system, etc. One or more additional data packets may be sent to one or more selected computers systems. A determination may be made as to whether one or more additional data packets were received and loaded onto one or more computer systems.
Other objects and advantages of the invention will become apparent upon reading the following detailed description and upon reference to the accompanying drawings in which:
While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present invention as defined by the appended claims.
Embodiments described herein provide methods, systems, and carrier media for distributing data packets to one or more computer systems coupled to a network of computers.
One or more local area networks (LANs) 104 may be coupled to WAN 102. A LAN 104 is a network that spans a relatively small area. Typically, a LAN 104 is confined to a single building or a group of buildings. Each node (i.e., individual computer system or device) on a LAN 104 preferably has its own CPU with which it executes programs, and each node is able to access data and devices anywhere on the LAN 104. The LAN 104 thus allows many users to share devices (e.g., printers) as well as data stored on file servers. The LAN 104 may be characterized by any of a variety of types of topology (i.e., the geometric arrangement of devices on the network), of protocols (i.e., the rules and encoding specifications for sending data, and whether the network uses a peer-to-peer or client/server architecture), and of media (e.g., twisted-pair wire, coaxial cables, fiber optic cables, radio waves, etc.).
Each LAN 104 includes a plurality of interconnected computer systems and optionally one or more other devices: for example, one or more workstations 110a, one or more personal computers 112a, one or more portable computer devices (e.g., laptop or notebook computer systems 114), one or more server computer systems 116, and one or more network printers 118. As used herein, a “server” refers to a computer program that, during execution, provides services to other computer programs executing in the same or other computer systems. The computer system on which a server program is executing may also be referred to as a server, though it may contain a number of server and client programs. In the client/server model, a server is a program that awaits and fulfills requests from client programs in the same or other computer systems. The LAN 104 may be coupled to other computer systems and/or other devices and/or other LANs through WAN 102.
One or more mainframe computer systems 120 may be coupled to WAN 102. As shown, mainframe 120 may be coupled to a storage device or file server 124 and mainframe terminals 122a, 122b, and 122c. Mainframe terminals 122a, 122b, and 122c may access data stored in the storage device or file server 124 coupled to or included in mainframe computer system 120.
WAN 102 may also include computer systems which are connected to WAN 102 individually and not through a LAN 104: as illustrated, for purposes of example, a workstation 110b and a personal computer 112b. For example, WAN 102 may include computer systems which are geographically remote and connected to each other through the Internet. As used herein, the term “network” includes a LAN 104 or a WAN 102.
Computer system 150 preferably includes or is in communication with a memory medium on which computer programs according to various embodiments may be stored. The term “memory medium” is intended to include an installation medium, e.g., a CD-ROM, DVD, or floppy disks 160, a computer system memory such as DRAM, SRAM, EDO RAM, Rambus RAM, etc., or a non-volatile memory such as a magnetic media, e.g., a hard drive, or optical storage. The memory medium may include other types of memory as well, or combinations thereof. In addition, the memory medium may be located in a first computer in which the programs are executed, or may be located in a second different computer which connects to the first computer over a network connection 159. In the latter instance, the second computer may provide the program instructions to the first computer for execution. Computer system 150 may take various forms, including a personal computer system, a mainframe computer system, a workstation, a network appliance, an Internet appliance, a personal digital assistant (PDA), a television system or another device. In general, the term “computer system” may be broadly defined to encompass any device having a processor which executes instructions from a memory medium. Additionally, a “computer system” may generally describe hardware and software components that in combination may allow execution of computer programs. Computer programs may be implemented in software, hardware, or a combination of software and hardware.
In an embodiment, a network may include one or more software applications that may be used by a network administrator to monitor and/or control various aspects of one or more computer systems coupled to the network. As used herein, one or more software applications that enable a user to monitor and/or control one or more computer systems on a network may be referred to as a “network management system.” Network management systems are also known in the art by various other names including: configuration management systems and enterprise management systems. Network management systems may include, but are not limited to applications and application suites such as: Configuration Manager available from the Tivoli Software Group of IBM Corporation of Austin, Tex.; by-Control available from Bindview Corporation of Houston, Tex.; System Management Server available from Microsoft Corporation of Redmond, Wash.; and UniCenter available from Computer Associates International, Inc. of Islandia, N.Y.
Generally, a network management system (NMS) may include one or more applications installed on one or more server computers. Portions of a NMS installed on one or more servers may provide an interface used by an administrator to operate the NMS. Additionally portions of a NMS installed on one or more servers may provide monitoring and control functions which interface with one or more agent applications (hereinafter “agents”) installed on one or more computer systems coupled to the network. As used herein an “agent” refers to an application installed on a first computer system which receives commands, executes commands on the first computer system and/or sends information regarding the first computer system to one or more second computer systems. For example, the second computer system may be a server. The agent may interact with an application on the server computer system to provide monitoring and/or control functionality over the first computer system to a user via the server.
In an embodiment, a NMS may interact with one or more other applications to provide data packets to one or more computer systems coupled to the network. As used herein, a “data packet” refers to a computer file in any format. Examples of data packets may include, but are not limited to: executable files, text files, graphics files, software patches and other data and application files. For example, a NMS may interact with one or more other applications to provide software updates and/or software patches to one or more computer systems coupled to a network. A process of providing software patches and/or software updates may include, but is not limited to:
-
- registration of hardware and/or software assets of one or more computer systems;
- auditing of one or more computer systems to discover existing hardware and software configuration;
- comparing discovered software against a master control list (“MCL”) of software;
- determining whether a software version of one or more discover software applications is the desired version of the software based on the MCL;
- installing one or more software updates or software patches onto one or more computer system; and
- verifying that one or more software updates or software patches where installed correctly on one or more computer systems.
As used herein, a software application or application suite which interacts with a NMS to provide data packets to one or more computer systems of a network may be referred to as an “update system.” By interacting with an existing network management system an update system may not require installation of any agents of its own on computer systems within the network. Thus, the update system may be installed on a server coupled to the network and utilize agents of the NMS to implement various functions, such as those described above. Such an embodiment may save time on large networks where installing software on individual computer systems may be cumbersome and expensive due to the distribution of the computer systems, the number of computer systems, the variety of computer systems, the variety of operating systems and/or the variety of network environments.
In an embodiment, an update system may be installed on a computer system coupled to a network. The update system may be installed on a computer system that has access to the network management system (“NMS”). For example, the update system may be installed on a server used to execute the NMS. As used herein, a server computer system upon which the NMS may be executed is referred to as a “network management system server.” The update system may generate commands and send the commands to the NMS to install one or more data packets on one or more computer systems coupled to the network.
In an embodiment, the update system may be user configurable via a user interface.
In an embodiment, a user interface of an update system may provide a settings screen to allow a user to configure interfaces between portions of the update system, interfaces between the update system and the network management system and other system wide update parameters.
In an embodiment, settings screen 400 may also include a NMS tab 404 for configuring an interface between the update system and a network management system, as depicted in
NMS configuration screen 600 may include a NMS settings tab 602. NMS settings tab 602 may allow a user to specify directory path and name options for accessing the NMS. NMS configuration screen 600 may also include a database settings tab 604 for configuring access information regarding one or more databases utilized by the NMS. One or more tabs may also be provided for configuring options of the NMS that may be utilized by the update system. For example, debug options tab 606 may be utilized to set debug options for the NMS to use when providing data packets to one or more computer systems.
In an embodiment, update system settings screen 400 may include one or more additional tabs for configuring update system options. For example, a thresholds tab 406 may be provided, as depicted in
Other threshold values may also by be set by the user. For example, a number of installation attempts before notification may be established by the user. The number of installation attempts threshold 702 may determine how many times the update system will try to send a data packet to a particular computer system before alerting the user that there is a problem in sending the data packet. The notification may be via an active messaging system (e.g., email, pager notification, etc.) or via a passive notification such as applying a color code to the computer system in reports requested by the user. Additionally, number of installation attempts threshold 702 may be used to determine whether other actions should be taken. For example, if a computer system has met or exceeded number of installation attempts threshold 702 the update system may inhibit access to the network via the computer system. Alternately, a user of the computer system may be inhibited from logging on to the computer system or network. For example, in an embodiment, the computer system may be logged off of the network. The computer system may not be allowed to log on to the network until the data packet has been successfully installed.
An update system settings screen 400 may include one or more tabs for configuring update system access options. For example, a users/passwords tab 408 may be provided. Settings screen 400 may also include one or more tabs for configuring user options of one or more tools accessible via the update system. For example, in an embodiment, one or more commercially available software applications may be accessible from within the update system. As depicted in
The update system may be utilized to configure options related to distributing one or more data packets to one or more computer systems. A number of user interface screens may be available to the user for configuring distribution options. A number of embodiments of distribution configuration screens are discussed below. The specific layout and features illustrate ways that distribution configuration screens may be organized.
In an embodiment, a master control list (MCL) may be associated with an update system. An MCL may identify data packet names, versions, version dates and/or other identifying information regarding data packets expected to be encountered on computer systems coupled to the network. The MCL may further indicate whether one or more data packets are allowed or prohibited. The update system may provide an interface for maintaining the MCL, as depicted in
A close up view of identification section 802 is shown in
A data packet described on data packet management screen 800 may be added to the master control list. Data packets already present on the MCL may also be edited in data packet management screen 800. For example, a data packet to be edited may be selected in a list window 808. Data related to the data packet may be displayed in the sections previously discussed.
In an embodiment, data packet management screen 800 may include a view window 810. View window 810 may allow the user to select from several sets of data to view. Selections available to the user in view window 810 may include, but are not limited to: master control list 812, known data packets 814, prohibited data packets 816 and unknown data packets 818. Master control list selection 812 may allow the user to view data packets identified on the master control list. Known data packets selection 814 may allow the user to view all known data packets identified on the network during a scan of the network. As used herein a “known” data packet refers to a data packet that is present on a list of recognized data packets available to the scanning application. Prohibited data packets selection 816 may allow a user to view data packets on the network that are identified in a prohibited data packets list. Unknown data packets selection 818 may allow the user to view data packets that were detected during a scan of the network, but which do not appear on the list of recognized data packets available to the scanning application.
Known data packets selection 814, prohibited data packets selection 816 and unknown data packets selection 818 may be collectively referred to as audit selections since information presented in these views is acquired by auditing (or scanning) the network. Selecting an audit selection may cause an audited data packets screen 1200 to be displayed, as depicted in
In an embodiment, an audit selection category of a data packet may be changed by selecting the data packet in audit list window 1202 and selecting a menu option. For example, an unknown data packet may be added to the list of recognized data packets available to the scanning application. Similarly, a data packet may be added to the MCL or prohibited data packets list by selecting an appropriate menu option. If a version of a data packet desired to be distributed to one or more computer systems is identified in audit list window 1202, the data packet may be assigned to one or more computer systems by selecting an appropriate menu option. To assign a selected data packet for distribution to one or more computer systems, a data packet manager screen 800 as previous discussed may be displayed. Data acquired during the network audit may be pre-populated into appropriate portions of the opened data packet manager screen.
In an embodiment, an icon may be associated with various types of data packets displayed. That is, known data packets may be indicated by a first icon, unknown data packets by a second icon, etc. Changing the audit selection category of a data packet may cause the associated icon to be changed as well.
In an embodiment, an update system may allow computer systems coupled to a network to be assigned to management groups. For example, as depicted in
Using group manager screen 1300, the user may assign one or more computer systems to one or more groups. In an embodiment, computer systems may be assigned to groups according to criteria determined by the user. For example, a computer system may be assigned to a group according to computer system parameters such as operating system, hardware configuration, location, etc. In another example, computer systems may be assigned to groups according to arbitrary criteria determined by the user or in any other manner deemed appropriate by the user to form a hierarchy of groups. Additionally, in some embodiments, subgroups may be formed within groups. Names and/or other descriptive information may be assigned to each group or subgroup to assist the user in determining which computers systems are likely to be assigned to each group.
In an embodiment, group manager screen 1300 may include a view window 1312. View window 1312 may allow the user to arrange data displayed in group manager screen 1300 in a desired manner. Selections available to the user in the group manager screen view window may include, but are not limited to: group by nodes 1314 and group by assigned data packets 1316.
A “group by nodes” view of a group manager screen is depicted in
Assigned data packets window 1502 may display data packets in the order they are scheduled to be installed on the selected group or subgroup. Thus, the first data packet listed is the next data packet to be installed on the selected group or subgroup. The user may change the scheduled order by dragging and dropping or by using a pull down menu selection available by selecting a data packet. Thus, if a more urgently needed data packet (e.g., a security patch) is currently scheduled last, the user may drag and drop the more urgent data packet to the first position, or select a change order menu option to move the more urgent data packet forward.
In an embodiment, the user may select an assigned data packet to review details regarding the data packet. For example,
From group manager screen 1300, the user may set various parameters associated with groups and/or subgroups. For example, a group/subgroup pull down menu 1700, similar to the one depicted in
Several scheduling options may also be available to the user. For example, the user may select group schedule and configuration option 1710 to view configuration information regarding the selected group or subgroup. Selecting group schedule and configuration option 1710 may also display the schedule for sending one or more data packets to computer systems assigned to the group or subgroup. Group schedule and configuration option 1710 may allow the user to specify a date range during which the update system is to attempt to send data packets to the selected group or subgroup. Alternately, the user may be able to specify a frequency at which the update system will attempt to send data packets to the selected group or subgroup. For example, the update system may attempt to send data packets to a group or subgroup on a daily, weekly, monthly or other basis. The user may also be able to specify a particular time within the established frequency that data packets should be sent. For example, data packets may be sent daily between 1 a.m. and 2 a.m. In another example, data packets may be sent weekly on Sunday mornings. Group schedule and configuration option 1710 may also allow a user to disable an update schedule configured for the group or subgroup. This feature may be useful if the schedule needs to be bypassed temporarily, but the user does not want to configure a new schedule or loose the old schedule. Group schedule and configuration option 1710 may also allow the user to configure options related to how users of computers systems assigned to the selected group or subgroup perceive receiving sent data packets. For example, the update system may be configured to send the data packets entirely in the background. In such a case, users of computer systems receiving data packets from the update system may not be notified in any way that the data packets are being received. Alternately, the update system may cause a window to be displayed on computers systems assigned to the group or subgroup to notify users of the computer systems when data packets are being received. An additional configuration options that may be available via group schedule and configuration option 1710 is a client debugging option. Turning on the client debugging option may cause a log file to be written on computer systems assigned to the group or subgroup when the updated system is sending data packets to them. The log file may be useful to assist a network administrator in identifying problems if one or more data packets are not installed correctly onto one or more computer systems by the update system.
Another option that may be available on group/subgroup pull down menu 1700 is a verification interval option 1712. Verification interval option 1712 may allow a user to set a frequency and/or time period during which computer systems assigned to the selected group or subgroup will be scanned. As used herein, “scanning” a computer system refers to determining configuration information regarding the computer system. For example, scanning may collect information such as, but not limited to: hardware configuration and/or software configuration. Hardware configuration may include information such as type of processor, hardware assets coupled to the computer system (e.g., mouse, keyboard and/or monitor type), memory available to the computer system, etc. Software configuration may include information such as name, version and/or version date of software applications on the computer system. Software configuration may also include information regarding data files (e.g., graphics files, text files, etc.) present on the computer system. Settings available via verification interval option 1712 may allow the user to specify that computer systems assigned to the group or subgroup should be scanned after the passing of a specified number of minutes, hours, days, etc. or when a user of a computer system logs in to the computer system.
In an embodiment, group/subgroup pull down menu 1700 may also give the user of the update system the option to initiate a scan of computer systems assigned to the group or subgroup immediately. For example, Run hotfix analyzer for group option 1714 may immediately initiate a scan of computer systems assigned to the group or subgroup using the HotFix utility available from Microsoft Corp. of Redmond, Wash.
As previously mentioned, a list of options similar to group/subgroup pull down menu 1700 may be available to the user by selecting an individual node rather than a group or subgroup. One difference between the options available for a node and the options available for a group or subgroup may be an option to review results of scanning a computer system. Scanning data is typically most useful on an individual computer basis. Therefore, a scan results option may only be available in a node pull down menu. However, in certain embodiments, a scanning program may be used that provides information at the group or subgroup level. In such cases, a review scan results option may be available at the group/subgroup level.
Also within the group manager view, a user may select an assigned data packet to view a pull down menu of options related to the selected data packet. For example, in an embodiment, options available in a data packet pull down menu may include a “force update now” option. A “force update now” option may immediately initiate sending one or more selected data packets to computer systems assigned to one or more groups or subgroups. The force update now option may be particularly useful for very high priority data packets such as security patches and/or virus definitions for virus protection software.
As previously mentioned, a node tab 1310 may allow a user to view information related to individual computer systems (i.e., nodes) coupled to a network. An embodiment of a node manager screen 1800 is depicted in
Node manager screen 1800 may include a nodes window 1802 and a configuration window 1804, as well as one or more windows previously described (e.g., list window 808 and hierarchy window 1306). Nodes window 1802 may display a list of computer systems. The list of computer systems displayed may depend on one or more selections made in hierarchy window 1306. For example, if no group or subgroup is selected in hierarchy window 1306, then nodes window may display computer systems coupled to the network that are not assigned to any group or subgroup. However, if a group or subgroup is selected in hierarchy window 1306, then computer systems assigned to the selected group or subgroup may be displayed in nodes window 1802. Each node identified in nodes window 1802 may be associated with an icon. The icon displayed may depend on whether or not the associated node has been assigned to a group or subgroup. Thus, a first icon may indicate a node that is not assigned to any group or subgroup; whereas, a second icon may indicate that a node has been assigned to a group or subgroup.
Configuration window 1804 may display information related to the hardware and/or software configuration of a computer system selected in nodes window 1802. For example, configuration window 1804 may display configuration information including, but not limited to: hardware devices coupled to the computer system, operating system(s) present on the computer system and one or more data packets present on the computer system. Configuration information may be determined based on scanning one or more computer systems as previously described. In an embodiment, configuration window 1804 may selectively display configuration information based on a user defined configuration. For example, configuration window 1804 may only display known data packets, unknown (e.g., unrecognized) data packets, prohibited data packets, and/or allowed (e.g., not prohibited) data packets. In yet another embodiment, configuration window 1804 may display a desired and/or expected configuration of one or more computer systems. For example, a desired configuration may include information regarding data packets assigned to, but not yet installed on, a computer system. Similarly, an expected configuration may include information from a MCL regarding current or expected versions of various data packets.
In an embodiment, node manager screen 1800 may allow a user to assign one or more nodes to groups or subgroups. For example, one or more nodes may be selected. The selected node(s) may be assigned to groups/subgroups by dragging and dropping them. Alternately, a pull down menu may allow selected nodes to be assigned to groups/subgroups. In yet another example, a pull down menu associated with a group or subgroup may cause an add nodes screen 1900 to be displayed as depicted in
In an embodiment, add nodes screen 1900 may allow the user to search for nodes meeting specified criteria. Results of the search may be displayed in a results window 1902. The user may then assign one or more computer systems identified in results window 1902 to the group or subgroup the user selected when the add nodes screen was opened. In an embodiment, the user may select an “add all” button 1904 to assign all of the computer systems identified in results window 1902 to the group or subgroup. Alternately, the user may select one or more computer systems in results window 1902 and select an “add selected” button 1906 to add only the selected computer systems to the group or subgroup.
In an embodiment, if a computer system that is already assigned to a group or subgroup is selected to be assigned to another group or subgroup, the user may be notified that the selected computer system is already assigned to a group or subgroup. The user may then be asked to confirm the assignment of the selected computer system to the selected group or subgroup. Similarly, in an embodiment, the user may be inhibited from deleting a non-empty group or subgroup. That is only groups or subgroups with no subgroups or nodes assigned may be deleted.
In an embodiment, node manager screen 1800, group manager screen 1300 and/or data packet management screen 800 may be used to assign a data packet to one or more computer systems or one or more groups of computer systems. For example, a data packet may be selected in list window 808 and dragged and dropped to a desired computer system in nodes window 1802 or to a desired group or subgroup in hierarchy window 1306. Data packets assigned to computer systems or groups of computer systems may be represented in nodes window 1802 and/or hierarchy window 906 to provide ready confirmation of data packets assigned to various computer systems and/or groups.
After assigning a data packet to at least one computer system an assigned data packets window 2002 may be added to the manager screen currently in use (e.g., node manager screen 1800, group manager screen 1300, or data packet manager screen 800).
In an embodiment, node manager screen 1800 may include a view window 1806. View window 1806 may allow the user arrange data displayed in node manager screen 1800 in a desired manner. Selections available to the user in the node manager view window may include, but are not limited to: all nodes view 1808, groupless nodes view 1810, and disabled nodes view 1812. As the name implies, all nodes view 1808 may cause all nodes (i.e., computer systems) of the network to be listed regardless of the status of the node. Groupless nodes view 1810 may cause only nodes that are not assigned to any group or subgroup to be listed. Disabled nodes view 1812 may cause nodes that have been disabled to be listed.
Other view options may be available to the user in node manager screen 1800. For example, window selection buttons 1814, 1816, 1818 and 1820 at the bottom of node manager screen 1800 may enable the user to change the windows presented in node manager screen 1800. All windows selection 1820 may present all of the windows previous described in the node manager screen 1800 as depicted in
In an embodiment, an update system may provide one or more reports to the user regarding update system activities and/or status. Reports provided via the update system may include color coding of status information as previously described regarding
Various embodiments further include receiving or storing instructions and/or data implemented in accordance with the description herein upon a carrier medium. Suitable carrier media include memory media or storage media such as magnetic or optical media, e.g., disk or CD-ROM, as well as transmission media or signals such as electrical, electromagnetic, or digital signals, conveyed via a communication medium such as networks and/or a wireless link.
Although the systems and methods of the present invention have been described in connection with several embodiments, the invention is not intended to be limited to the specific forms set forth herein, but on the contrary, it is intended to cover such alternatives, modifications, and equivalents as can be reasonably included within the spirit and scope of the invention as defined by the appended claims.
Claims
1-113. (canceled)
114. An update system comprising:
- a network interface configured to: receive, from the server, client configuration information associated with a plurality of client computer systems; and communicate a message to the server;
- a memory configured to store: a list of data packet entries, each data packet entry comprising: first information identifying a data packet; second information indicating which client computer systems of the plurality of client computer systems should have the data packet installed; and one or more conditions for the installation of the data packet. the client configuration information; and
- a processor configured to: select a data packet to install on a client computer system based on a comparison of the client configuration information to the second information; determine that a client computer system of the plurality of client computer systems meets the one or more conditions associated with the data packet based on the client configuration information; generate the message in response to the determination that the client computer system meets the one or more conditions, the message comprising a command requesting the server to communicate the data packet to an agent application installed on the client computer system; and verify that the data packet was successfully installed on the client computer systems.
115. The update system of claim 114, wherein the processor is further configured to:
- determine an installation status of the data packet on two or more client computer systems of the plurality of client computer systems; and
- generate a view for display to a user, the view providing a graphical representation of the installation status.
116. The update system of claim 114, wherein:
- the data packet comprises a software patch associated with a client software program; and
- the client configuration information comprises information indicating whether the software patch is installed on a client computer system.
117. The update system of claim 114, wherein the one or more conditions comprise one or more of the following:
- a condition that a client software program is installed on the client computer system;
- a condition that a client software program is not installed on the client computer system;
- a condition that a version of an operating system is installed on the client computer system; and
- a condition associated with content of a system registry of a client computer system.
118. The update system of claim 114, wherein:
- the memory is further configured to store group data associating one or more client computer systems with a group; and
- the processor is further configured to: assign the one or more client computer systems to the group based on one or more portions of the client configuration information; and generate a view for display to a user, the view providing a graphical depiction of the one or more client computer systems assigned to the group.
119. The update system of claim 118, wherein:
- the interface is further configured to receive user input selecting a subset of the plurality of client computer systems; and
- the processor is further configured to assign the one or more client computer systems to the group based on the user input.
120. The update system of claim 114, wherein the server comprises a computer program executed by the processor of the update system.
121. The update system of claim 114, wherein the server comprises a computer program executed by a processor of a computer system remote from the update system.
122. The update system of claim 114, wherein:
- the memory is further configured to store the data packet; and
- the message further comprises the data packet.
123. The update system of claim 114, wherein the processor is further configured to:
- identify one or more prohibited data packets present on a client computer system based on a comparison of the configuration information to the list; and
- generate a view for display to a user, the view depicting the one or more prohibited data packets.
124. The update system of claim 114, wherein the client configuration information comprises:
- hardware information identifying one or more hardware components of a client computer system;
- data packet information indicating whether the data packet is installed on the client computer system; and
- operating system information indicating a version of an operating system installed on the client computer system
125. A non-transitory computer-readable medium comprising logic that, when executed by a processor, is operable to:
- access client configuration information comprising: hardware information identifying one or more hardware components of a client computer system; data packet information indicating whether the data packet is installed on the client computer system; and operating system information indicating a version of an operating system installed on the client computer system;
- access a control list comprising a plurality of data packet entries, each data packet entry comprising: a data packet identifier; and one or more conditions associated with a data packet;
- determine that the client computer system meets the one or more conditions associated with the data packet based on the client configuration information;
- install the data packet on the client computer system in response to the determination that the client computer system meets the one or more conditions associated with the data packet; and
- verify that the data packet was successfully installed on the client computer system.
126. The medium of claim 125, wherein the data packet comprises a software patch associated with a client software program installed on the client computer system.
127. The medium of claim 125, wherein the installation of the data packet on the client computer system is triggered by a command from a server remote from the client computer system.
128. The medium of claim 125, wherein the one or more conditions comprise one or more of the following:
- a condition that a client software program is installed on the client computer system;
- a condition that a client software program is not installed on the client computer system;
- a condition that a version of an operating system is installed on the client computer system; and
- a condition associated with content of a system registry of a client computer system.
129. The medium of claim 125, wherein the client computer system is assigned to a group based on the client configuration information.
130. The medium of claim 125, wherein the client computer system is assigned to a group based on input from a user.
131. The medium of claim 125, wherein the logic, when executed by the processor, is further operable to determine the client configuration information at a plurality of scheduled times.
132. The medium of claim 125, wherein the logic, when executed by the processor, is further operable to determine audit information associated with the computer system, the audit information comprising information identifying one or more unknown data packets on the client computer system.
133. The medium of claim 125, wherein the logic, when executed by the processor, is further operable to determine audit information associated with the computer system, the audit information comprising information identifying one or more prohibited data packets on the client computer system.
134. An update system comprising:
- a network interface configured to: receive, from the server, client configuration information associated with a plurality of client computer systems; receive input from a user; and communicate a message to the server;
- a memory configured to store: the client configuration information; and a list of software patch entries, each entry associated with a software patch and comprising: first information identifying the software patch; and second information identifying which client computer systems of the plurality of client computer systems should have the software patch installed; and
- a processor configured to: identify one or more software patches to be installed on one or more client computer systems of the plurality of client computer systems based on the client configuration information and the list of software patch entries; generate a view for display to a user, the view identifying the one or more software patches; process the input from the user, the input requesting installation of the one or more software patches; generate the message in response to the input, the message comprising a command requesting the server to communicate the one or more software patches to an agent application installed on each of the one or more client computer systems; determine an installation status of the one or more software patches on the one or more client computer systems; generate a view for display to a user, the view providing a graphical representation of the installation status.
Type: Application
Filed: Feb 8, 2013
Publication Date: Sep 19, 2013
Inventors: Harry Aderton (Eatontown, NJ), Richard Aderton (Little Silver, NJ), Prakash Patel (Iselin, NJ), John Reckeweg (Toms River, NJ), Gary Rietmann (Manahawkin, NJ)
Application Number: 13/763,363
International Classification: G06F 9/445 (20060101);