SYSTEM AND METHOD FOR HARDWARE AND SOFTWARE MONITORING WITH INTEGRATED RESOURCE ACQUISITION
A method, system, and network providing hardware and software inventorying and monitoring provide the status of a local network of interconnected information technology devices. A user downloads and installs a local network monitoring software program from an online source onto a host computer system. The local network monitoring software system initiates an inventory of all information technology devices associated with said local network of information technology devices. Also, the local network monitoring software determines the operational status of the information technology devices and the status of software programs installed on the information technology devices. The results of the inventory and status determinations are presented to the host computer system. The presented information permits the user of said host computer system to initiate maintenance and support actions for the information technology devices in response to the operational status and status of software programs using the local network monitoring software.
This application is a continuation of U.S. application Ser. No. 16/412,643 filed May 15, 2019, which is a continuation of U.S. application Ser. No. 15/364,122 filed Nov. 29, 2016, now U.S. Pat. No. 10,313,204, which is a continuation of U.S. application Ser. No. 14/558,444 filed Dec. 2, 2014, now U.S. Pat. No. 9,509,577, which is a continuation of U.S. application Ser. No. 12/041,480 filed Mar. 3, 2008, now abandoned, which claims priority of U.S. Provisional Application No. 60/892,831, filed Mar. 2, 2007.
All the fore-mentioned applications are hereby incorporated by reference in their entirety.
FIELDThe present disclosure relates in general to the field of software, and more particularly to information technology management software.
BACKGROUNDExisting information technology (IT) management software packages have several shortcomings. Existing IT management software packages are often complicated. Often, such software packages are geared toward professional IT personnel in large businesses, neglecting small and medium sized businesses. While the presentation of large amounts of information may be beneficial in certain contexts, it is often unnecessary and overwhelming for less sophisticated IT management personnel.
Existing IT management software packages may not integrate important data into a single interface. One IT management software package may be more effective for managing one issue, while another may be more effective for another issue. An IT manager may need to review many disparate sources of information in order to effectively manage the IT infrastructure. Common management issues are often mixed with the less commonly encountered issues, making it tedious and time consuming to filter the common issues from the less common issues.
Accordingly, there is a need for an IT management software package that addresses the shortcomings of existing IT management software noted above.
There is a further need for an IT management software package that is easy to use, integrated and directed to common IT management issues.
SUMMARYIn one aspect, embodiments disclosed herein relate to a system for hardware and software monitoring with integrated resource acquisition.
In another aspect, the present disclosure provides a method, system, and network providing hardware and software inventorying and monitoring provide the status of a local network of interconnected information technology devices. A user downloads and installs a local network monitoring software program from an online source onto a host computer system. The local network monitoring software system initiates an inventory of all information technology devices associated with said local network of information technology devices. Also, the local network monitoring software determines the operational status of the information technology devices and the status of software programs installed on the information technology devices. The results of the inventory and status determinations are presented to the host computer system. The presented information permits the user of said host computer system to initiate maintenance and support actions for the information technology devices in response to the operational status and status of software programs using the local network monitoring software.
Other aspects and advantages of the disclosure will be apparent from the following description and the appended claims.
The features, nature, and advantages of the disclosed subject matter may become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout and wherein:
Preferred embodiments of the present disclosure are illustrated in the drawings, like numbers being used to refer to like and corresponding parts of the various drawings.
The disclosed subject matter related to IT management software. Features of the disclosed subject matter include the ability to inventory a network, run an IT help desk, monitor a network for trouble, report on a network, troubleshoot issues on a network, collaborate with IT professionals, and provide feedback for software improvement.
The disclosed subject matter allows for an inventory of all hardware, software and other assets on a network. The software allows for discovery of the Windows, Mac, and Linux PCs and servers, routers, printers and any other IP-based devices on your network. All relevant technical data plus the software, patches and services on each machine may be gathered. Other data such as number of licenses, purchase price and physical location may also be added. Other assets such as mobile phones and office furniture may also be added. All of this information may be gathered without the use of agents. All inventory information may be stored locally and securely on the network, avoiding any concerns about sensitive information being communicated over the internet.
On the bottom half 122 of the screen, the General tab 212, Installed On tab 214, Not Installed tab 216, and Notes tab 218 are useful in managing licenses. For license compliance, a user may input the number of licenses available for a given software package. In the event that the number of installed versions of software exceeds the number of available licenses, an alert may be issued, indicating that the threshold for license compliance has been crossed. This may be a very powerful tool for a user to take to management to request purchases of additional required licenses. In addition, it may be useful for a user to be able to ensure that for a volume license, the same key is being used for each instance of installed software.
An IT administrator may also need to manage things that are not easily detectable on a network. In that case, there is a ‘User Defined’ category.
The disclosed subject matter also provides for an information technology (IT) help desk. Daily projects and user requests may be managed from one interface. A ticket may be created upon discovery of a network asset that requires attention while browsing a network. Clients may submit tickets with attachments via email or the Web and may then view the status of those tickets online. Tickets may be assigned across an IT team or attached to hardware on the network. Reports may be run on the tickets to easily view due dates and which assets (or even departments) cause the most issues.
An internal help desk may greatly reduce the amount of time spent tracking work and responding to users and also makes it easy to report on the amount of time spent doing IT related activities. In one embodiment, the presently disclosed software is pre-configured with several of the most commonly used help desk options.
An administrator may create a help request within the presently disclosed software using the New Ticket tab 308.
In one embodiment, help desk tab 302 allows an administrator to select the tickets to be viewed 316 as unassigned tickets, open tickets, closed tickets, past due tickets, all tickets, tickets assigned to that administrator and tickets where a purchase is required. Further, an administrator may make changes to a help desk request and correspond with a user using the features available on the bottom half of the screen 306.
The disclosed subject matter provides for reports for sharing IT information. Reports may include software installed on machines, disk usage across the network, trouble tickets recently created, among others. Further, custom reports may be created using a simple interface. Reports may be published or exported to PDF or Excel. Useful custom reports may be shared with other users.
Note that the Public column 406 may be used to mark a report as available to other users. For example, a supervisor or accounting personnel may need to view reports regularly. Making a report public allows such a user to view the report from within the software of the disclosed subject matter.
The disclosed subject matter may also be used to monitor a network for trouble. A user may view, and set up alerts for, Windows events that occur across the environment for easily detecting, diagnosing and troubleshooting issues that disrupt a network. Further, the disclosed subject matter allows for automatic identification of PCs and servers with low disk space, the presence of unwanted software on the network, the status of anti-virus updates, printers with low toner and ink levels, and offline servers. Email alerts may be used for notification of potential issues. Further, valuable monitors are all consolidated in one centralized location.
A monitor is any condition which can be automatically evaluated by the software of the present disclosure. In one embodiment, the default monitors include Disk Space 512 (amount of free disk space), Online/Offline Status 514 (online/offline status for a device or group of devices), Anti-Virus 516 (when anti-virus software is present and up to date), and Troublesome Software 518 (when specified software is removed or installed, including Google desktop and WeatherBug).
To add a new monitor, a user may click ‘Add’ 520. For example, an administrator may want to monitor when a new version of Microsoft Office Outlook is installed or uninstalled. This will result in an alert being fired in the event that Microsoft Outlook is installed or uninstalled. This is a powerful way of monitoring an environment without the need for manually checking each system in the environment.
The disclosed subject matter allows the user to report on the network. The software allows the user to see software installed on machines, disk usage, and trouble tickets. Custom reports can be created and published so that others in the network can be informed of network updates, and issues. Reports may then be exported in file formats such as PDF and Excel. Finally, the user can share and receive report templates from other users of the software.
The disclosed subject matter allows a user to troubleshoot issues on the network. When problems arise, the software allows for identification of cause and resolution of the problem. For example, a user may see what software is running on a machine causing it to run slowly. A remote control tool may be launched from within the software. Two machines may be compared to determine what settings are different. The software allows for pinging a machine to see if it is online and running a traceroute to identify the flow of data. Further, the software allows a user to identify when a server is running out of capacity.
A user may troubleshoot a workstation with an issue by comparing that workstation with another workstation that is working correctly. The Compare tab allows a side by side comparison of a first machine versus a second machine. The software highlights in red any difference found in hardware, configuration, software, services or hotfixes. A user may also perform remote administration of machines via the Remote Control tab. The software uses two methods of remote control including Microsoft's Remote desktop protocol and VNC screen-sharing protocol.
The disclosed subject matter allows a user to become a virtual extension of the software development team. A user may request and vote on new features, view other users' ratings of features, submit feedback on existing features, and preview upcoming releases.
The asset context engine 554 allows a user to view the network assets on an individual, group or global basis and generate reports, flags and alerts.
The event context engine 558 provides a user with insight into the system, such as access to critical or proprietary information, web-server activity as a security measure, or general activity of personnel after business hours.
The workflow context engine 556 is a smart engine providing the user with information based on the processes that user is currently running. The workflow context engine 556 analyzes the current work by the user and presents this data through the data pivoting interface. For instance, if an end of year inventory program is running, the workflow content engine 556 may direct the user to websites where identified or needed computer or network hardware, software or peripherals and be researched and purchased. Additionally the workflow content engine 556 may simply drive advertisements to the user relating to the user's perceived needs. The data pivoting will be further discussed later in the disclosure.
The collection engine 580 provides the user with server proxy, finder, watcher and third party functionality as aspects of the present disclosure. Engines 578 and 580 may be employed jointly in a network or separately. In a typical installation, engine 580 will be installed at multiple sites in a distributed network 582 or in a network that has several firewalls or security measures, downstream of them and then to provide retrieved information to the application engine 578. Although an IT administrator may change these settings, typically the application dynamically determines the appropriate IP addresses, domain names or other information required to gather the information.
This initial information may also include, any required security passwords or logins required to access some or all of the systems on the network. At step 604 the network settings are obtain as well as checking of the domain name and the DNS lookup in both directions. Any DNS errors found are aggregated into a top level view so that they later may be corrected by the IT administrator if desired.
An identifier for a computer or device on a TCP/IP network. Networks using the TCP/IP protocol route messages based on the IP address of the destination. The format of an IP address is a 32-bit numeric address written as four numbers separated by periods. Each number may be zero to 255. For example, 2.160.10.240 could be an IP address.
Within an isolated network, IP addresses may be assigned at random as long as each one is unique. However, connecting a private network to the Internet requires using registered IP addresses (called Internet addresses) as specified by networking standards. The four numbers in an IP address are used in different ways to identify a particular network and a host on that network. Four regional Internet registries—ARIN, RIPE NCC, LACNIC and APNIC—assign Internet addresses from the following three classes. Class A—supports 16 million hosts on each of 126 networks; Class B—supports 65,000 hosts on each of 16,000 networks; and Class C—supports 254 hosts on each of 2 million networks.
In a 32-bit IP address, the number of bits used to identify the network and the host vary according to the network class of the address. In a Class C network, the first 3 bits, or the high-order bits, are always “110.” The next 21 bits are used to define the Class C network, and the final eight bits are used to identify the host. The IP address is represented in dotted decimal notation of four 8-bit fields, or octets, that have been converted from binary to decimal numbers.
The number of valid networks and hosts available is always 2N (where N equals the number of bits used) minus 2 (one for the all zeros address and one for the all ones address). Thus, for a class C address wherein 8 bits are available for hosts, the number of hosts is 28-2, or 256-2, which is 254. Future version of this software will support Ipv6 which allows for a much greater range of IP addresses.
At step 604 a determination is made as to how wide the system is and to allocate search protocols based on this measure. For instance in a Class C network there are 254 potential hosts. Each device has or should have a unique IP address or sub-mask address. If an IP address or name is provided by the IT administrator, a DNS lookup takes place. The present disclosure confirms the DNS name and IP address associated with it and assures that the IP address defaults to the DNS name and vice-versa. If an IP address or name is not provide the search engine 606 will the set the range based on the how wide the system is and ping each element to see if it responds. If an element does respond then it is probed to see if it is listed on one of the ports or is a unique name or IP address device.
Having “ping”-ed an element and it responds, control then passes to step 608 where the element is probed. Although the following steps are listed in a logical and efficient manner for probing elements on a network, other groupings or searching hierarchies may be employed or plugged in later and not depart from the scope of the present disclosure.
At step 610 the device is probed to see if it responds to WMI. Windows Management Instrumentation (WMI) is a set of extensions to the Windows Management Instrumentation that provides an operating system interface through which instrumented components may provide information and notification. If the device is identified as a WMI device data is collected at step 612 and control passes to step 634 where a determination as to whether the device responds to HTTP is made (i.e., has a web server interface) Hypertext Transfer Protocol (HTTP) is a method used to transfer or convey information on the World Wide Web.
If the device is found to be a WMI at step 610 the remaining steps 610 through 630 are skipped, since by default the device will not respond to any of the other protocols. At step 614 the device is probed to see if it responds to SNMP. The simple network management protocol (SNMP) forms part of the internet protocol suite as defined by the Internet Engineering Task Force (IETF). SNMP is used by network management systems to monitor network-attached devices for conditions that warrant administrative attention. It consists of a set of standards for network management, including an Application Layer protocol, a database schema, and a set of data objects.
If at step 614 the device responds, it is identified as a SNMP device data is collected at step 616 and control passes to step 634 where a determination as whether the device responds to HTTP. The remaining steps 618-630 are skipped. The simple network management protocol (SNMP) forms part of the internet protocol suite as defined by the Internet Engineering Task Force (IETF). SNMP is used by network management systems to monitor network-attached devices for conditions that warrant administrative attention. It consists of a set of standards for network management, including an Application Layer protocol, a database schema, and a set of data objects.
At step 618 if the device responds, it is identified as a SSH device, data is collected at step 620 and control passes to step 634 where a determination as whether the device responds to HTTP is made. Steps 622-630 are skipped. Secure Shell or SSH is a set of standards and an associated network protocol that allows establishing a secure channel between a local and a remote computer. It uses public-key cryptography to authenticate the remote computer and (optionally) to allow the remote computer to authenticate the user. Shell commands are then used to obtain the needed information from the asset.
At step 622 if the device responds, it is identified as a JetDirect device, data is collected at step 624 and control passes to step 634 where a determination as whether the device responds to HTTP is made. Steps 626-630 are skipped. JetDirect is the name of a technology sold by Hewlett-Packard that allows computer printers to be directly attached to a Local Area Network. The most common communication uses TCP/IP port 9100.
At step 626 if the device responds, it is identified as a VoIP SIP, data is collected at step 628 and control passes to step 634 where a determination as to whether the device responds to HTTP is made. Voice over Internet Protocol, also called VoIP, IP Telephony, Internet Telephony, Broadband telephony, Broadband Phone and Voice over Broadband is the routing of voice conversations over the Internet or through any other IP-based network.
At step 630 if the device responds, it is identified as an HTTP and data is collected at step 632. Control then passes to step 638, wherein if no response is received and exception report or alert is generated and forwarded to the IT administrator providing the directions as to how to handle these occurrences.
The reason the device failed to respond or did not respond fully, after being identified as being on the system could be numerous. In this instance the port is identified as being open but is identified as not showing anything on it. This could occur for various reasons, such as the user may not have the security clearance to access the system/device in question or a separate login is required that was not provided. The device may be behind a firewall or other device such a hub that will not respond.
Once the data is collected control then passes to step 636 wherein the data collect is posted with each device found on the network. Process steps 606 may be repeated again at a later time to discovery new network devices, but a report will only be generated for devices previously identified if the device configuration has changed. This information is stored on the system so that a history of the device may be created and used to compare with itself or other devices similarly configured and equipped.
This provides for a very efficient way of trouble shooting devices by being able to access a snap shot of a device that was previous working. It also provides the IT administrator the functionality and ability to ensure that each user on the system is appropriately configured with the software, hardware, peripheral access and etc. that their security level or access level requires or allows. Therefore, it a system bios or other parameters are changed and a problem occurs, the IT administrator may utilize this tool to identify the change in the systems configuration at take appropriate measures to resolve it.
At step 902 the monitoring or watcher flow engine is initiated with the parameters set by the IT administrator. Control then passes to step 904 where each known device is processed. Control then passes to step 906 for each monitor where a check status request is initiated at step 908. If the result of the check status is a positive, i.e., the status has changed, the status change is posted to set 912. If the check status request is a negative, i.e., a no result, the process terminates.
Once the change is posted at step 912, control then passes to step 914, where a determination is made, in compliance with the IT administrator set up instructions, to send an email or some other type alert, such as creating an exception report, or log. If the determination at step 914 is a no, then the process terminates, although the data is still stored with the device showing the time of the last scan and its results. This data may remain indefinitely on the system or be periodically culled using a FIFO method over a set time period. If the instructions are affirmative at step 914 to send an email, control passes to step 916 where an email or some other type alert is direct to the party or parties designated by the IT administrator.
The watcher flow or monitoring engine continually performs the various described functions at the period intervals set up for the monitoring process until the process is terminated or altered by the IT administrator.
While the present disclosure has been described with respect to a limited number of embodiments, those skilled in the art, having benefit of this disclosure, will appreciate that other embodiments may be devised which do not depart from the scope of the present disclosure as described herein. Accordingly, the scope of the present disclosure should be limited only by the attached claims.
Claims
1. A method, performed by a host computer, comprising:
- obtaining a local network monitoring software program;
- installing the local network monitoring software program on the host computer;
- determining inventory of software programs that are installed on the information technology devices, including probing at least one of the information technology devices with a plurality of different protocols to determine a matching protocol based on which of the different protocols is responded to, and using the matching protocol to determine the inventory of software programs that are installed on the at least one of the information technology devices; and
- displaying the inventory of software programs that are installed on the information technology devices.
2. The method of claim 1, wherein determining the inventory of the software programs that are installed on the plurality of information technology devices includes pinging the at least one of the information technology devices when an IP address or name of the at least one of the information technology devices is not known, and probing the at least one of the information technology devices when the at least one of the information technology devices responds to the pinging.
3. The method of claim 1, wherein probing the at least one of the information technology devices with a plurality of different protocols includes probing each of the information technology devices with a first protocol and, for each of the information technology devices that does not respond, then probing the information technology devices that does not respond with a second protocol.
4. The method of claim 1, wherein an inventory of all computer systems that are on the local network are determined.
5. The method of claim 1, wherein an inventory of all peripheral printing devices that are on the local network are determined.
6. The method of claim 1, wherein an inventory of all server devices that are on the local network are determined.
7. The method of claim 1, further comprising determining and displaying a status of the information technology devices, wherein the status includes at least one of: whether an information technology device is offline or online, free disk space, last login info, ink or toner levels, amount of memory, IP address, and amount of memory.
8. The method of claim 1, wherein determining the inventory of the software programs installed on the plurality of the information technology devices includes determining the presence of at least one of: antivirus software, software version numbers, when software is installed, and unwanted software.
9. A host computer, configured to:
- obtain a local network monitoring software program;
- install the local network monitoring software program on the host computer;
- determine inventory of software programs that are installed on the information technology devices, including probing at least one of the information technology devices with a plurality of different protocols to determine a matching protocol based on which of the different protocols is responded to, and using the matching protocol to determine the inventory of software programs that are installed on the at least one of the information technology devices; and
- display the inventory of software programs that are installed on the information technology devices.
10. The host computer of claim 9, wherein determining the inventory of the software programs that are installed on the plurality of information technology devices includes pinging the at least one of the information technology devices when an IP address or name of the at least one of the information technology devices is not known, and probing the at least one of the information technology devices when the at least one of the information technology devices responds to the pinging.
11. The host computer of claim 9, wherein probing the at least one of the information technology devices with a plurality of different protocols includes probing each of the information technology devices with a first protocol and, for each of the information technology devices that does not respond, then probing the information technology devices that does not respond with a second protocol.
12. The host computer of claim 9, wherein an inventory of all computer systems that are on the local network are determined.
13. The host computer of claim 9, wherein an inventory of all peripheral printing devices that are on the local network are determined.
14. The host computer of claim 9, wherein an inventory of all server devices that are on the local network are determined.
15. The host computer of claim 9, that is further configured to determine and display a status of the information technology devices, wherein the status includes at least one of: whether an information technology device is offline or online, free disk space, last login info, ink or toner levels, amount of memory, IP address, and amount of memory.
16. The host computer of claim 9, wherein determining the inventory of the software programs installed on the plurality of the information technology devices includes determining the presence of at least one of: antivirus software, software version numbers, when software is installed, and unwanted software.
17. A local network, comprising:
- a plurality of communication paths between a plurality of information technology devices including a host computer, wherein the host computer is configured to:
- obtain a local network monitoring software program;
- install the local network monitoring software program on the host computer;
- determine inventory of software programs that are installed on the information technology devices, including probing at least one of the information technology devices with a plurality of different protocols to determine a matching protocol based on which of the different protocols is responded to, and using the matching protocol to determine the inventory of software programs that are installed on the at least one of the information technology devices; and
- display the inventory of software programs that are installed on the information technology devices.
18. The local network of claim 17, wherein determining the inventory of the software programs that are installed on the plurality of information technology devices includes pinging the at least one of the information technology devices when an IP address or name of the at least one of the information technology devices is not known, and probing the at least one of the information technology devices when the at least one of the information technology devices responds to the pinging.
19. The local network of claim 17, wherein probing the at least one of the information technology devices with a plurality of different protocols includes probing each of the information technology devices with a first protocol and, for each of the information technology devices that does not respond, then probing the information technology devices that does not respond with a second protocol.
20. The local network of claim 17, wherein an inventory of all computer systems that are on the local network are determined.
Type: Application
Filed: Jul 7, 2021
Publication Date: Oct 28, 2021
Inventor: Francis Sullivan (Austin, TX)
Application Number: 17/369,628