The present invention relates to communication systems, in particular, to a distributed TFTP server network for downloading software to a plurality of devices connected to the network.
In medium size and large businesses, communication between devices is typically established over a network, such as a LAN or a WAN, for example. In order to communicate over the network, devices such as IP phones, computers, or other network devices must be assigned an IP address. This is normally accomplished by the device requesting an IP address from a server using Dynamic Host Configuration Protocol (DHCP). In addition, when the device is first connected to the network or when software upgrades are required, devices such as IP phones customarily incorporate a TFTP client in order to download software, including executable binary files, from a central TFTP server, such as a PBX. TFTP (Trivial File Transfer Protocol) is a simple file transfer protocol used for downloading bootcode to diskless devices, such as IP phones. TFTP is set forth in RFC 1350 published by the Network Working Group in July 1992.
However, the PBX is only able to perform a limited number of concurrent TFTP sessions because each TFTP session between a phone client and the PBX burdens the processing capability of the PBX.
The size of the downloaded executable binary files has grown from approximately 256 KB to approximately 4 MB and continues to grow. At the same time, the size of PBXs continues to grow, with increasing numbers of phones. The large size of the executable binary files and the increased number of phones connected to the PBX compromises the performance of the PBX. Bandwidth utilization and upgrade time for all connected phones is also impacted.
Many PBX configurations include remote campuses routed over T1 links and other bandwidth limited media to a central TFTP server. IP fragmentation in routed networks and narrow communication connections results in TFTP download times becoming onerous. In addition, the processing capability of the PBX is impacted by phones performing DHCP, attempting to make TCP connections or attempting SSL or other secure protocols on top of TCP.
It is therefore desirable to improve TFTP download time from a PBX to multiple IP phones, and otherwise reduce the processing burden on the PBX.
In one aspect of the present invention there is provided a method for providing a distributed TFTP server network among a plurality of IP devices, the method including:
providing a plurality of IP devices, each of the IP devices being in communication with a central TFTP server;
each IP device maintaining a list of available servers, the central TFTP server remaining at the bottom of the list of available servers;
at least one IP device selecting a TFTP server from the top of the list of available servers and attempting to connect to the TFTP server;
downloading software from the TFTP server to the at least one IP device;
the at least one IP device sending a server ready signal over the distributed TFTP server network following successful download of the software whereupon the at least one IP device is added to the top of the list of available servers and operates as a further TFTP server for allowing other IP devices in the distributed TFTP server network to attempt to connect to the further TFTP server for downloading the software.
The distributed TFTP method of the present invention reduces the number of TFTP clients that the central TFTP server (i.e. PBX) must service. Further, the distributed TFTP method reduces the number of router hops and possible MTU (Maximum Transmission Unit) fragmentation between the TFTP servers and TFTP clients. Additionally, TFTP traffic over the external communication links of remote campuses will also be reduced.
The invention will be better understood with reference to the following Figures in which like numerals denote like parts and in which:
Referring to
Each phone contains a TFTP client that has the ability to transform itself into a TFTP server. As such, a phone may download software from the central TFTP server or, alternatively, may download software from another phone that has transformed itself into a TFTP server. An example of a distributed TFTP method is shown in
Each phone is provided with two IP addresses. The first IP address is the central TFTP server IP address. The second IP address is used to allow the phones to communicate with one another and may be either a multicast group address or a broadcast address. The TFTP sessions between the phones and the central TFTP server are unicast. Similarly, the TFTP sessions between the phones and a phone that has transformed itself into a TFTP server are also unicast. The phones only use multicasts or broadcasts to communicate server status with one another.
The phones determine that the distributed TFTP method is being used by the network 10 from the DHCP options or from manual entry, i.e. because there are two TFTP IP addresses. The phones know that they are to attempt the distributed TFTP method if one of the TFTP addresses provided to them is a multicast or broadcast IP address. Such addresses can be identified because they fall in the range of 224.0.0.0 to 239.255.255.255. If the phones detect a TFTP IP address in this range, they determine that the distributed TFTP method is being used.
In the distributed TFTP method, each phone institutes a random back off prior to attempting TFTP. All phones must observe and complete a random back off before attempting to initiate a TFTP session.
When a phone completes a TFTP download, it transmits a “TFTP Server Ready” message using the designated communication protocol dictated by DHCP or manual entry. The information that is transmitted with the “TFTP Server Ready” message includes: set type, filename available, file revision number, phone IP address and phone MAC address. Each time a phone in a random back off state reads a “TFTP Server Ready” message with a corresponding set type and filename, it adds the TFTP server to it's TFTP server list. Each new TFTP server is added to the top of the list. The central TFTP server, which the phone discovers via DHCP or manual entry, remains at the bottom of the list.
When searching for a TFTP server, phones start at the top of their TFTP server list and continue down the list until an available TFTP server is found. Phones that are in TFTP server mode service five TFTP sessions, either sequentially or concurrently. Additional TFTP session requests are answered with a TFTP error message. If a phone is rejected, the phone then attempts a TFTP session with the next TFTP server on it's TFTP server list. Phones that are in TFTP server mode resume normal operation if they have completed five TFTP session requests or if they have completed less than 5 TFTP session requests and more than 10 seconds has elapsed since their last TFTP session request. Once a phone has resumed normal operation, further TFTP requests from other phones are denied.
In the scenario depicted in
In another embodiment, the phones 14 are used to download software for other IP phones or to download the software to devices other than IP phones, such as personal digital assistants (PDAs), faxes and printers, for example. In order to download software to devices other than IP phones, the phones are programmed to download binaries meant for other devices. The phones 14 would have to modify the information in their broadcasts accordingly.
A specific embodiment of the present invention has been shown and described herein. However, modifications and variations may occur to those skilled in the art. All such modifications and variations are believed to be within the sphere and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
05257443.1 | Dec 2005 | EP | regional |