1. Technical Field
The present invention relates generally to an improved data processing system and in particular, a method and apparatus for processing data. Still more particularly, the present invention provides a method, apparatus, and computer instructions for managing a remote host data processing system.
2. Description of Related Art
In network data processing systems, remote wake-up abilities are often provided for clients. This type of feature allows a client that is in a sleep mode to be woken up through the network. With this feature, a system administrator or other user may wake-up a sleeping client by sending a selected type of network packet. This packet is called a “wake-up packet”. For example, with a network adapter, such as an Ethernet controller, the adapter is modified to listen for a special wake-up packet on a local area network (LAN) address even when the computer in which the network adapter is located is asleep in a power conservation mode. Upon receiving this packet, the network adapter checks the packet content to ensure that the packet is destined for this particular client. If the packet is destined for the client, the adapter wakes up the sleeping client. This type of technology also is referred to as “magic packet technology”.
This type of feature may be used on a large network data processing system in which the system administrator's data processing system is located on a different subnet from the clients that are being managed. A subnet is a division of a network into an interconnected, but independent, segment, or domain, in order to improve performance and security. In generating a wake-up packet, the remote data processing system's 48- bit media access control (MAC) address is encoded into the wake-up packet. A MAC address is a unique serial number that is used to identify a network card. Thereafter, the wake-up packet is broadcast to address 255.255.255.255 if the remote data processing system is on the same subset. Otherwise, this packet is sent to a subnet-directed broadcast address if the remote data processing system is located on another subnet.
To wake up a remote data processing system on a subnet, the administrator needs to have the remote data processing system's MAC address and subnet mask in addition to having the name of the remote data processing system or the IP address for the remote data processing system. The technique is used by the IP protocol to filter messages into a particular network segment (subnet). The subnet mask is a binary pattern that is stored in the client data processing system, server or router and is matched up with the incoming Internet Protocol (IP) address to determine whether to accept or reject the packet. It is inconvenient for an administrator to obtain a MAC address and subnet mask for all remote data processing systems managed by an administrator, especially when large numbers of clients are managed.
Therefore, it would be advantageous to have an improved method, apparatus, and computer instructions for identifying host information such as a MAC address and a subnet mask, for a remote data processing system.
The present invention provides a method, apparatus, and computer instructions for providing host information. A request is received for host information for a remote computer from a requester wherein the request includes one of a host name or an Internet Protocol address. The host information is received from a requester. A media access control address and a subnet mask is identified using the request, and a response is returned to the requester, wherein the response includes the media access control address and the subnet mask.
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:
With reference now to the figures,
In the depicted example, server 104 is connected to network 102 along with storage unit 106. In addition, clients 108, 110, and 112 are connected to network 102. These clients 108, 110, and 112 may be, for example, personal computers or network computers. In the depicted example, server 104 provides data, such as boot files, operating system images, and applications to clients 108-112. Clients 108, 110, and 112 are clients to server 104. Network data processing system 100 may include additional servers, clients, and other devices not shown. In the depicted example, network data processing system 100 is the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational and other computer systems that route data and messages. Of course, network data processing system 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).
Referring to
Peripheral component interconnect (PCId) bus bridge 214 connected to I/O bus 212 provides an interface to PCI local bus 216. A number of modems may be connected to PCI local bus 216. Typical PCI bus implementations will support four PCI expansion slots or add-in connectors. Communications links to clients 108-112 in
Additional PCI bus bridges 222 and 224 provide interfaces for additional PCI local buses 226 and 228, from which additional modems or network adapters may be supported. In this manner, data processing system 200 allows connections to multiple network computers. A memory-mapped graphics adapter 230 and hard disk 232 may also be connected to I/O bus 212 as depicted, either directly or indirectly.
Those of ordinary skill in the art will appreciate that the hardware depicted in
The data processing system depicted in
With reference now to
An operating system runs on processor 302 and is used to coordinate and provide control of various components within data processing system 300 in
Those of ordinary skill in the art will appreciate that the hardware in
As another example, data processing system 300 may be a stand-alone system configured to be bootable without relying on some type of network communication interfaces. As a further example, data processing system 300 may be a personal digital assistant (PDA) device, which is configured with ROM and/or flash ROM in order to provide non-volatile memory for storing operating system files and/or user-generated data.
The depicted example in
The present invention provides a method, apparatus, and computer instructions for identifying host information for a remote data processing system. In particular, the mechanism of the present invention identifies a MAC address and subnet mask for a remote data processing system that is to be woken up.
According a preferred embodiment of the present invention, if the remote data processing system, also referred to as a remote host, uses dynamic host configuration protocol (DHCP) to obtain an IP address, the DHCP server obtains the MAC address and subnet mask of the remote host as part of the process of assigning an IP address to this client. The mechanism of the present invention sends this information, along with the IP address, to a domain name system (DNS) server. If the remote host has a static IP address, this information is sent to the DNS server at the time the static address is provisioned for the remote host. As a result, when a remote host is to be woken up, an administrator, at a managing data processing system or host, sends a DNS query to a DNS server to obtain the MAC address and subnet mask. In this manner, an administrator or managing host is not required to know all of the host information for managed remote hosts. Such a feature is especially useful with respect to data processing systems in which IP addresses may change based on using DHCP.
Turning next to
Administration computer 400 also needs a MAC address and a subnet mask for target computer 404. The MAC address and subnet mask are the host information that is needed to generate wake-up packet 402. In these examples, this information may be obtained from DNS sever 408. DNS server 408 contains a mapping of names-to-addresses and a mapping of addresses-to-names in database 410. The mapping information in this database is loaded into DNS server cache 411.
To obtain the host information, administration computer 400 sends “TXT” DNS query 406 to DNS server 408. This query includes the host name for target computer 404. In these examples, this host information is located in the name-to-address mapping file. In response to receiving “TXT” DNS query 406, DNS server 408 queries DNS server cache 411 for host information, such as the MAC address and subnet mask. In this example, “TXT” DNS query 406 is for a text record for target computer 404.
The host name is used to identify this record in DNS server cache 411 to obtain the MAC address and the subnet mask for use in generating a wake-up packet. When the text record is found, this record is returned to administration computer 400 as response 412. With this information, administration computer 400 places the appropriate host information into wake-up packet 402.
The text records containing host information in database 410 may be provisioned on DNS server 408 through different mechanisms. One mechanism involves having DHCP server 414 obtain the host information from target computer 404 when assigning IP addresses. This mechanism is used with dynamic IP addresses. In the case of static IP addresses, the host information may be provisioned directly by a user or administrator.
In this example, with dynamic IP address, target computer 404 uses DHCP to obtain an IP address from DHCP server 414. As part of this process, DHCP server 414 retrieves host information 416 from target computer 404. As illustrated, host information 416 is the MAC address and subnet mask for target computer 404. DHCP server 414 sends host information 416 as an update to DNS server 408. This information is placed into DNS server cache 411. Thus, queries from users, such as one at administration computer 400, may be processed to provide host information needed for management activities, such as waking up a remote host with a wake-up packet.
DNS server cache 411 contains the most up-to-date host information in these examples. Periodically, DNS server 408 updates database 410 with information from DNS server cache 411. In particular, a name-to-address mapping file and an address-to-name mapping file in database 410 is updated from DNS server cache 411.
In the case in which target computer 404 has a static IP address, the MAC address and subnet mask is provided to DNS sever 408 by a user or system administrator. This provisioning of host information is typically performed when the static IP address is provisioned. This information only needs to be provided to DNS server 408 once. As a result, future queries for host information causes DNS server 408 to provide that information to the requesters. In this manner, an administrator does not need to know all of the host information for a remote host. Knowledge of the IP address or name of the remote host is sufficient.
Turning next to
Turning next to
The process begins by receiving a discover message for an IP address from a client with the client's MAC address (step 600). An offer is sent to the client with the IP address and other options (step 602). Other options may include, for example, gateways, DNS servers and subnet masks. A broadcast request is then received from the client indicating that the client accepts the offer (step 604). Thereafter, an acknowledgement is sent to the client in response to the client receiving the broadcast request. Afterward, an update is sent to DNS server (step 608) with the process terminating thereafter. This update includes the MAC address, the IP address, and the subnet mask.
Turning next to
The process begins by sending a discover message for an IP address to a DHCP server (step 700). This discover message includes the MAC address of the host. An offer is received from a DHCP server with the IP address and other options (step 702). In response to receiving this offer, a request is broadcast to the DHCP server accepting the offer (step 704) with the process terminating thereafter.
Turning now to
The process begins by stopping the DNS server (step 800). A MAC address and subnet mask is added as part of the text record of that client in the name-to-address mapping file (step 802). Then, the DNS server is restarted (step 804). The DNS server then loads the address to name mapping file and the name to address mapping file in to the cache (step 806) with the process terminating thereafter.
Turning now to
The process begins by configuring the DNS server to allow dynamic updates from a specific host or from any host to configure the DNS server to write information to a cache in which the information is used to update a name-to-address mapping file after a fixed period of time (step 900).
Next, the DNS server is started (step 902). An “nsupdate” tool is used to dynamically update the MAC address and the subnet address as part of the text record in the DNS server's cache (step 904). The “nsupdate” tool may be obtained from the Internet Software Consortium. This tool is one that may be used by a user to dynamically update DNS mapping information in the DNS server cache. After the fixed period of time passes, the mapping information in the cache is used to update the name-to-address mapping file (step 906) with the process terminating thereafter.
Turning now to
The process begins by sending a type “A” DNS query to a DNS server for host information (step 1000). This query includes the host name, but requires no other host information. This type of query results in an IP address being returned for the host name. After the query has been sent, an IP address is received (step 1002). Next, a type “TXT” DNS query is sent to the DNS server (step 1004). This query also requires only a host name and is used to obtain a text record. Thereafter, a text record is received from the DNS server.
The MAC address and subnet mask is extracted from the text record returned from the DNS server (step 1008). This information is used to calculate a subnet broadcast address (step 1010). The MAC address received in the text record from the DNS server is encoded into a wake-up packet (step 1012). The wake-up packet is then sent to the subnet-directed broadcast address (step 1014) with the process terminating thereafter.
A similar process may be used to send a wake-up packet to a remote host in which only an IP address is used. In this case, the first query sent is a type “PTR” DNS query containing the IP address, which results in a host name being returned for the IP address. Steps similar to steps 1004-1014 are used as described above. In step 1004, the type “TXT” DNS query is sent using the host name. In these examples, the host information is present in the name-to-address mapping file.
Thus, the present invention provides a method, apparatus, and computer instructions for obtaining host information for a remote host or data processing system. The mechanism of the present invention avoids a user or process having to store or identify all of the host information for a remote host. The host information needed may be obtained from a server, such as a DNS server, using a query containing a host name for the remote host. Host information, such as a MAC address and a subnet mask is supplied in response to the query. This information may then be used to direct packets, such as wake-up packets, to a remote host to wake up the remote host. Management of the remote data processing system is made more convenient for a user or administrator when the user or administrator only needs to provide a host name or IP address to generate a wake-up packet.
It is important to note that while the present invention has been described in the context of a fully functioning data processing system, those of ordinary skill in the art will appreciate that the processes of the present invention are capable of being distributed in the form of a computer readable medium of instructions and a variety of forms and that the present invention applies equally regardless of the particular type of signal bearing media actually used to carry out the distribution. Examples of computer readable media include recordable-type media, such as a floppy disk, a hard disk drive, a RAM, CD-ROMs, DVD-ROMs, and transmission-type media, such as digital and analog communications links, wired or wireless communications links using transmission forms, such as, for example, radio frequency and light wave transmissions. The computer readable media may take the form of coded formats that are decoded for actual use in a particular data processing system.
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.