The present disclosure relates generally to systems and methods for sending and receiving data among a set of devices on a network. Selected embodiments relate generally to sending and receiving data among configurable devices and maintenance systems for a Voice-over-IP (VoIP) network.
Conventionally, systems for transmitting voice signals over the Internet commonly include a configurable device for converting analog voice signals into digital signals and transmitting the digital signals. Generally, these devices are connected to a conventional telephone or integrated with the phone to provide a customer with traditional and familiar telephone functionality.
As digital voice networks such as VoIP became more complex, the deployed devices were complemented with management systems to maintain and control aspects of device functions. These management systems sometimes configure the devices to control their operation and allow the customer access to certain configuration parameters related to services. To ensure proper operation of the device, the device preferably operates using the most current configuration. These configurations are often profile-based, where these profiles include parameters controlling various aspects of the device's features, performance, and overall behavior.
Occasionally, the configurable device 101 transfers files 153 to the management system 105 using an HTTP POST or PUT operation 119. The files in the HTTP POST or PUT operation 119 include a variety of file types generated by the device such as device log information. Upon receipt of the files 153, the management system 105 sends an acknowledgement message 121 to the configurable device 101 confirming that the files were received, thereby concluding the HTTP POST/PUT operation.
The conventional systems and methods of data transfer among devices 101 and the management system 105 have the disadvantage of requiring many separate communications sessions to be established among the communicating entities. These numerous sessions consume bandwidth and hardware resources. To effectively scale their VoIP and data networks, network operators and service providers are faced with the challenge of maintaining the performance and function of the various remotely deployed devices with a manageable and minimal investment in shared infrastructure.
Accordingly, there is a need in industry for technological solutions providing a more efficient system and method for transferring data between a configurable device and a management system.
Various disclosed embodiments are generally directed to a system and method for managing data transfer between a configurable device and a management system including generating device data, detecting a polling request, transmitting, in a first common communications session and in response to the polling request, at least a portion of the device data and a configuration request, and receiving a configuration file corresponding to the configuration request.
Various aspects of the present disclosure will be or become apparent to one with skill in the art by reference to the following detailed description when considered in connection with the accompanying exemplary non-limiting embodiments, wherein:
One aspect of the present disclosure includes grouping data transmissions within common communications sessions. Another aspect includes prioritizing data collected at a remote configurable device for grouped or individual transmission. Yet another aspect includes selecting a configuration file to update a remote configurable device based on the device condition reflected by collected device data.
Various disclosed embodiments advantageously provide more efficient systems and methods for transferring data between a configurable device and a management system. In particular, selected embodiments reduce the required number of communications sessions required among networked entities.
Device data includes, but is not limited to, a device status entry, a device error entry, a communications error entry, a device performance entry, and a communications performance entry. For example, a device status entry indicates an operating condition of the device such as “operational,” “malfunctioning,” or “busy,” and optionally indicates a configuration profile version currently being used by the device. In another example, a device error entry indicates a type of error related to the device itself such as a malfunctioning component or software module. In yet another example, a communications error entry indicates problems with the device's network connection such as low bandwidth or disconnections. In an additional example, a device performance entry indicates measurements of the device's functions such as operation times or durations, digital-to-analog or analog-to-digital conversion metrics, sampling rates, and dropped frames or packets. In a further example, a communications performance entry indicates measurements of the device's communications functions such as data transfer rates, latency, or signal noise.
Device data is preferably prioritized to identify at least low priority items. Low priority items include, but are not limited to, data entries which do not reflect immediate or impending malfunction or serious problems with either the device or network performance. Low priority items are preferably stored and transmitted with the configuration request after a polling request is detected. In alternative embodiments, all device data, including high priority or critical device data, is stored and transmitted with the configuration request upon detection of a polling request.
A polling request includes, but is not limited to, a SIP NOTIFY message from a SIP proxy server. Alternatively, the polling request is received from the management system. In another alternative, the polling request is generated locally. For instance, the device optionally counts external polling requests and commences transmission after a predetermined number of polling requests. Alternatively, the device transmits intermittently or periodically based on an internal timer. Optionally, the independent local timer operates in conjunction with externally received requests. Accordingly, the device updates according to a regular schedule and in accordance with external polling requests generated, for instance, when a service provider seeks to implement a network-wide change in response to network performance or network security conditions.
A configuration request includes, but is not limited to, a request for the most recent configuration file. Alternatively, for instance when the remote configurable device is attempting to recover after a critical failure, the request may be for an original configuration file or a patch corresponding to a detected critical failure.
A configuration file includes, but is not limited to, a firmware update, a software patch, or updated feature parameter values altering the behavior or capabilities of the configurable device.
The configuration file request and the device data, either alone or in combination, are used by the management system to select a configuration file for transmission to the configurable device. Further, the management system optionally also analyzes data previously transmitted by the device (for instance, high priority or critical device data items transmitted upon generation) in view of the device data received with the configuration request. Analyzing these data types from the device enables the management system to ascertain whether the configurable device requires a major or minor update to its configuration. For example, the configurable device, if corrupted, may request the wrong version of the configuration file and exhibit low or unsatisfactory performance. If major errors or issues are determined from critical data previously transmitted, then the management system optionally selects and transmits a configuration file different from that requested in view of its analysis of the device data. Further, additional files such as a complete firmware upgrade or user guidance document are optionally transmitted based on detected issues with the configurable device.
The configurable device 301 generates device data including, but not limited to, one of a device status entry, device error entry, communications error entry, device performance entry, and communications performance entry as disclosed elsewhere. Optionally, the device data is stored and prioritized to identify low priority items 381 and higher priority or critical items 383.
The polling request is received at the configurable device 301. Preferably, a SIP Proxy server 303 sends a polling request as a SIP NOTIFY message 311 over a network to the configurable device 301. The polling request is optionally a timer event 313 from a source local to the configurable device 301. Alternatively, the polling request 321 is optionally received from the management system 305. In certain architectures (for instance, if the configurable device 301 is located behind a Network Address Translation (NAT) router or firewall) the management system 305 and the SIP proxy 303 communicate 323 to enable the management system 305 to ascertain the network identity or location of the configurable device 301.
Upon detecting the polling request 311/313, the device 301 responds by transmitting device data and a configuration request. In a first common communications session, the device 301 preferably responds by sending an HTTP POST or PUT message 315 including files 351 to the management system 305 along with a request 317 for the most current configuration file. The files 351 sent with the HTTP POST or PUT message 315 include, but are not limited to, device data as disclosed elsewhere. These files or analysis thereof update the management system 305 as to the status of the device 301. Further, the files optionally assist in identifying problems (present or potential) with the device 301 or communications to and from the device 301. Supplemental files 355 are also optionally transmitted to the management system 305 during this communications session. In one embodiment, the data transmitted during this operation includes diagnostic and debugging data, such as debugging messages that would otherwise be stored in a log file, or transmitted a line at a time using a network protocol such as “syslog”. Additionally, the data can include performance related data related to the application or function that the device performs. For example, for a VoIP device, it might include voice quality information that was passively measured over some recent calls that were placed. The data can additionally include other “active” measurements performed alongside the primary function, such as measuring network connectivity, probing the path that traffic takes over the network as part of the application and communicating that back to the management system. In alternative embodiments, alternative protocols are employed to transfer data including, but not limited to, File Transfer Protocol (FTP), SSH FTP (SFTP), FTP over SSL (FTPS), or Trivial FTP (TFTP).
After the files 351 are sent to the management system 305, the management system sends a new configuration file 353, if necessary, back to the device. The new configuration file 353 is selected by the management system 305 in accordance with an analyzed device condition. Various approaches to ascertaining or estimating device condition are described elsewhere.
The management system 305 optionally maintains records in a database 391 corresponding to the status of the device 301 to assist in the selection of the appropriate configuration file 353. These records optionally correspond to the historical or present status or condition of the device 301 as reflected in the device data transmitted by the device 301. Further, the database 391 also optionally contains a plurality of configuration files corresponding to various types of devices 301 and device conditions/statuses. The database 391 is implemented in any number of separate or integrated storage entities as is known in the art.
The transfer of the configuration file 353 in this communications session advantageously obviates the need for a separate and distinct TCP connection or other transaction between configurable device 301 and management system 305. This coupled transfer also avoids the associated overhead and delay of establishing an additional communications session. Conveyance of the configuration file 353 also serves as a positive acknowledgement 319 that files 351 (for example, device data) were received.
In another embodiment, in response to the receipt of the files 351 conveyed preferably with an HTTP POST or PUT operation, the management system 305 sends another type of file 357 along with the configuration file 353 back to the device 301 in a second common communications session. This complementary file 357 includes, but is not limited to, a firmware patch, an updated troubleshooting guide or software, or an advertisement. Accordingly, by grouping occasionally generated data with configuration requests and data that are routinely transferred, a more efficient management of the transfer of data between a configurable device and a management system is achieved.
The memory 403 is coupled to the CPU 407. The memory 403, or computer-readable medium, may be one or more of readily available memory such as random access memory (RAM), read only memory (ROM), floppy disk, hard disk, flash memory or any other form of digital storage, local or remote. The support circuits 409 are coupled to the CPU 407 for supporting the processor in a conventional manner. These circuits include cache, power supplies, clock circuits, input/output circuitry and subsystems, and the like. A software routine 405, when executed by the CPU 407, causes the device 401 to perform processes of the present invention and is generally stored in the memory 403. The software routine 405 may also be stored and/or executed by a second CPU (not shown) that is remotely located from the hardware being controlled by the CPU 407.
The software routine 405 is executed when a preferred method of managing data transfer between the configurable device 401 and a management system 305 is desired. The software routine 405, when executed by the CPU 407, transforms the general purpose computer into a specific purpose computer (device) 401 that controls the web-based application, suite of diagnostic tools or other similar actions. Although the process of the present invention is discussed as being implemented as a software routine, some of the method steps that are disclosed therein may be performed in hardware as well as by the software device. As such, the invention may be implemented in software as executed upon a computer system, in hardware as an application specific integrated circuit or other type of hardware implementation, or a combination of software and hardware. The software routine 405 of the present invention is capable of being executed on computer operating systems including but not limited to Microsoft Windows 98, Microsoft Windows 2000/XP/Vista, FreeBSD, NetBSD, Apple OS X and Linux. Similarly, the software routine 405 of the present invention is capable of being performed using CPU architectures including but not limited to IBM Power PC, Intel x86, Sun SPARC, AMD, Transmeta, MIPS, and ARM.
It may be emphasized that the above-described embodiments, particularly any “preferred” embodiments, are merely possible examples of implementations, merely set forth for a clear understanding of the principles of the disclosure. Many variations and modifications may be made to the above-described embodiments of the disclosure without departing substantially from the spirit and principles of the disclosure. All such modifications and variations are intended to be included herein within the scope of this disclosure and the present disclosure and protected by the following claims.
The embodiments disclosed herein for managing data transfer can be implemented using computer usable medium having a computer readable code executed by special purpose or general purpose computers.
The disclosure claims the filing-date benefit of Provisional Application No. 60/776,796, filed Feb. 27, 2006, the specification of which is incorporated herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4100377 | Flanagan | Jul 1978 | A |
4748620 | Adelmann et al. | May 1988 | A |
4777354 | Thomas | Oct 1988 | A |
4782485 | Gollub | Nov 1988 | A |
5018136 | Gollub | May 1991 | A |
5425085 | Weinberger et al. | Jun 1995 | A |
5444707 | Cerna et al. | Aug 1995 | A |
5452289 | Sharma et al. | Sep 1995 | A |
5519769 | Weinberger et al. | May 1996 | A |
5526353 | Henley et al. | Jun 1996 | A |
5572576 | Klausner et al. | Nov 1996 | A |
5623490 | Richter et al. | Apr 1997 | A |
5638433 | Bubien, Jr. et al. | Jun 1997 | A |
5751967 | Raab et al. | May 1998 | A |
5796951 | Hamner et al. | Aug 1998 | A |
5835126 | Lewis | Nov 1998 | A |
5966427 | Shaffer et al. | Oct 1999 | A |
5995491 | Richter et al. | Nov 1999 | A |
6014437 | Acker et al. | Jan 2000 | A |
6029196 | Lenz | Feb 2000 | A |
6067516 | Levay et al. | May 2000 | A |
6084956 | Turner et al. | Jul 2000 | A |
6097804 | Gilbert et al. | Aug 2000 | A |
6104706 | Richter et al. | Aug 2000 | A |
6104711 | Voit | Aug 2000 | A |
6115460 | Crowe et al. | Sep 2000 | A |
6115468 | De Nicolo | Sep 2000 | A |
6118860 | Hillson et al. | Sep 2000 | A |
6122364 | Petrunka et al. | Sep 2000 | A |
6128304 | Gardell et al. | Oct 2000 | A |
6128379 | Smyk | Oct 2000 | A |
6137869 | Voit et al. | Oct 2000 | A |
6138072 | Nagai | Oct 2000 | A |
6167042 | Garland et al. | Dec 2000 | A |
6169741 | LeMaire et al. | Jan 2001 | B1 |
6175565 | McKinnon et al. | Jan 2001 | B1 |
6178239 | Kishinsky et al. | Jan 2001 | B1 |
6185285 | Relyea et al. | Feb 2001 | B1 |
6188762 | Shooster | Feb 2001 | B1 |
6195425 | Farris | Feb 2001 | B1 |
6195697 | Bowman-Amuah | Feb 2001 | B1 |
6226286 | Danne et al. | May 2001 | B1 |
6226361 | Koyama | May 2001 | B1 |
6243443 | Low et al. | Jun 2001 | B1 |
6249576 | Sassin et al. | Jun 2001 | B1 |
6266405 | Madour et al. | Jul 2001 | B1 |
6269398 | Leong et al. | Jul 2001 | B1 |
6272126 | Strauss et al. | Aug 2001 | B1 |
6282281 | Low | Aug 2001 | B1 |
6282284 | Dzonno et al. | Aug 2001 | B1 |
6282574 | Voit | Aug 2001 | B1 |
6292553 | Fellingham et al. | Sep 2001 | B1 |
6298062 | Gardell et al. | Oct 2001 | B1 |
6298064 | Christie | Oct 2001 | B1 |
6304572 | Christie | Oct 2001 | B1 |
6304637 | Mirashrafi et al. | Oct 2001 | B1 |
6304653 | O'Neal et al. | Oct 2001 | B1 |
6310941 | Crutcher et al. | Oct 2001 | B1 |
6311182 | Colbath et al. | Oct 2001 | B1 |
6320951 | Shtivelman et al. | Nov 2001 | B1 |
6327572 | Motron et al. | Dec 2001 | B1 |
6330317 | Garfinkel | Dec 2001 | B1 |
6337899 | Alcendor et al. | Jan 2002 | B1 |
6343115 | Foladare et al. | Jan 2002 | B1 |
6349132 | Wesemann et al. | Feb 2002 | B1 |
6351464 | Galvin et al. | Feb 2002 | B1 |
6351526 | Shaffer et al. | Feb 2002 | B1 |
6359880 | Curry et al. | Mar 2002 | B1 |
6363421 | Barker et al. | Mar 2002 | B2 |
6366577 | Donovan | Apr 2002 | B1 |
6366661 | Devillier et al. | Apr 2002 | B1 |
6373836 | Deryugin et al. | Apr 2002 | B1 |
6373936 | Raniere et al. | Apr 2002 | B1 |
6373938 | Palacious et al. | Apr 2002 | B1 |
6385209 | Skirmont et al. | May 2002 | B1 |
6389119 | McBride | May 2002 | B1 |
6393115 | Krauss et al. | May 2002 | B1 |
6393476 | Barnhouse et al. | May 2002 | B1 |
6400820 | Edwards et al. | Jun 2002 | B1 |
6404746 | Cave et al. | Jun 2002 | B1 |
6404882 | Fellner et al. | Jun 2002 | B2 |
6404884 | Marwell et al. | Jun 2002 | B1 |
6408062 | Cave | Jun 2002 | B1 |
6408065 | O'Neal et al. | Jun 2002 | B1 |
6411697 | Creamer et al. | Jun 2002 | B1 |
6411704 | Pelletier et al. | Jun 2002 | B1 |
6415269 | Dinwoodie | Jul 2002 | B1 |
6421437 | Slutsman | Jul 2002 | B1 |
6424707 | Chatterjee | Jul 2002 | B1 |
6430175 | Echols et al. | Aug 2002 | B1 |
6430176 | Christie, IV | Aug 2002 | B1 |
6430275 | Voit et al. | Aug 2002 | B1 |
6430289 | Liffick | Aug 2002 | B1 |
6434143 | Donovan | Aug 2002 | B1 |
6442242 | McAllister et al. | Aug 2002 | B1 |
6446127 | Schuster et al. | Sep 2002 | B1 |
6452932 | Christie | Sep 2002 | B1 |
6456618 | Kozdon et al. | Sep 2002 | B2 |
6463052 | Christie | Oct 2002 | B1 |
6466570 | Low et al. | Oct 2002 | B1 |
6470010 | Szviatovszki et al. | Oct 2002 | B1 |
6473429 | Christie | Oct 2002 | B1 |
6480484 | Morton | Nov 2002 | B2 |
6480581 | Wu et al. | Nov 2002 | B1 |
6487200 | Fraser | Nov 2002 | B1 |
6493337 | Stevenson, III | Dec 2002 | B1 |
6493437 | Olshansky | Dec 2002 | B1 |
6496477 | Perkins et al. | Dec 2002 | B1 |
6504921 | Kotik et al. | Jan 2003 | B2 |
6510219 | Wellard et al. | Jan 2003 | B1 |
6519232 | Becher | Feb 2003 | B1 |
6519333 | Malik | Feb 2003 | B1 |
6539077 | Ranalli et al. | Mar 2003 | B1 |
6542589 | Baskin | Apr 2003 | B1 |
6553023 | Yamamiya et al. | Apr 2003 | B1 |
6564261 | Gudjonsson et al. | May 2003 | B1 |
6567398 | Aravamudan et al. | May 2003 | B1 |
6567419 | Yarlagadda | May 2003 | B1 |
6571212 | Dent | May 2003 | B1 |
6577712 | Larsson et al. | Jun 2003 | B2 |
6584094 | Maroulis et al. | Jun 2003 | B2 |
6584098 | Dutnall | Jun 2003 | B1 |
6584186 | Aravamudan et al. | Jun 2003 | B1 |
6584510 | Anttila | Jun 2003 | B2 |
6587836 | Ahlberg et al. | Jul 2003 | B1 |
6597685 | Miloslavsky et al. | Jul 2003 | B2 |
6614786 | Byers | Sep 2003 | B1 |
6614899 | Sollee et al. | Sep 2003 | B1 |
6621899 | Dezonno et al. | Sep 2003 | B2 |
6628760 | Mirashrafi et al. | Sep 2003 | B2 |
6633561 | Christie | Oct 2003 | B2 |
6650890 | Irlam et al. | Nov 2003 | B1 |
6664978 | Kekic et al. | Dec 2003 | B1 |
6665294 | Christie | Dec 2003 | B2 |
6665389 | Haste, III | Dec 2003 | B1 |
6665392 | Wellner et al. | Dec 2003 | B1 |
6668055 | Marwell et al. | Dec 2003 | B2 |
6681252 | Schuster et al. | Jan 2004 | B1 |
6690780 | Kotik et al. | Feb 2004 | B2 |
6694007 | Lang et al. | Feb 2004 | B2 |
6697475 | MeLampy et al. | Feb 2004 | B1 |
6707811 | Greenberg et al. | Mar 2004 | B2 |
6707906 | Ben-Chanoch | Mar 2004 | B1 |
6711160 | Chan et al. | Mar 2004 | B2 |
6714988 | Takemoto et al. | Mar 2004 | B2 |
6718031 | Fellner et al. | Apr 2004 | B2 |
6724755 | Kim | Apr 2004 | B1 |
6731630 | Schuster et al. | May 2004 | B1 |
6731642 | Borella et al. | May 2004 | B1 |
6731741 | Fourcand et al. | May 2004 | B1 |
6741586 | Schuster et al. | May 2004 | B1 |
6748057 | Ranalli et al. | Jun 2004 | B2 |
6760429 | Hung et al. | Jul 2004 | B1 |
6763226 | McZeal, Jr. | Jul 2004 | B1 |
6765931 | Rabenko et al. | Jul 2004 | B1 |
6769020 | Miyazaki et al. | Jul 2004 | B2 |
6771637 | Suzuki et al. | Aug 2004 | B1 |
6775368 | Lee et al. | Aug 2004 | B1 |
6778661 | Yumoto et al. | Aug 2004 | B1 |
6798873 | Vardi et al. | Sep 2004 | B2 |
6819752 | Raniere et al. | Nov 2004 | B2 |
6822945 | Petrovykh | Nov 2004 | B2 |
6839359 | Skirmont et al. | Jan 2005 | B2 |
6839421 | Esparza et al. | Jan 2005 | B2 |
6922722 | Mann et al. | Jul 2005 | B1 |
7024476 | Page et al. | Apr 2006 | B1 |
7181519 | Pillai et al. | Feb 2007 | B2 |
7246159 | Aggarwal et al. | Jul 2007 | B2 |
7308487 | Dansie et al. | Dec 2007 | B1 |
7334001 | Eichstaedt et al. | Feb 2008 | B2 |
7421495 | Yang et al. | Sep 2008 | B2 |
7480705 | DeLima et al. | Jan 2009 | B2 |
20010005412 | Light et al. | Jun 2001 | A1 |
20010005415 | Grunsted et al. | Jun 2001 | A1 |
20010014919 | Tzirin | Aug 2001 | A1 |
20020007391 | Suzuki | Jan 2002 | A1 |
20020049815 | Dattatri | Apr 2002 | A1 |
20020049860 | Koitinen | Apr 2002 | A1 |
20020055879 | Wengrovitz et al. | May 2002 | A1 |
20020095516 | Nada | Jul 2002 | A1 |
20020112073 | McLampy et al. | Aug 2002 | A1 |
20020114430 | Murata | Aug 2002 | A1 |
20020126818 | Cai et al. | Sep 2002 | A1 |
20020129131 | Yamashita | Sep 2002 | A1 |
20020150083 | Fangman et al. | Oct 2002 | A1 |
20020156900 | Marquette et al. | Oct 2002 | A1 |
20020191635 | Chow et al. | Dec 2002 | A1 |
20030005280 | Bobde et al. | Jan 2003 | A1 |
20030041132 | Lim et al. | Feb 2003 | A1 |
20030043787 | Emerson, III | Mar 2003 | A1 |
20030053446 | Kwon | Mar 2003 | A1 |
20030095541 | Chang et al. | May 2003 | A1 |
20030095542 | Chang et al. | May 2003 | A1 |
20030108064 | Bilke et al. | Jun 2003 | A1 |
20030163526 | Clarisse et al. | Aug 2003 | A1 |
20030174695 | Lautenschlager et al. | Sep 2003 | A1 |
20030202504 | Dhara et al. | Oct 2003 | A1 |
20040028025 | Chang | Feb 2004 | A1 |
20040028207 | Kato | Feb 2004 | A1 |
20040039938 | Katz et al. | Feb 2004 | A1 |
20040057415 | Colson et al. | Mar 2004 | A1 |
20040114575 | Morita et al. | Jun 2004 | A1 |
20040190711 | Miyajima | Sep 2004 | A1 |
20040205209 | Wengrovitz et al. | Oct 2004 | A1 |
20040205777 | Zalenski et al. | Oct 2004 | A1 |
20040215770 | Maher, III et al. | Oct 2004 | A1 |
20040223606 | Enete et al. | Nov 2004 | A1 |
20040258021 | Kashimoto et al. | Dec 2004 | A1 |
20040258238 | Wong | Dec 2004 | A1 |
20040258239 | Gallant et al. | Dec 2004 | A1 |
20050018659 | Gallant et al. | Jan 2005 | A1 |
20060136582 | Mills | Jun 2006 | A1 |
20060253567 | Selin et al. | Nov 2006 | A1 |
20090113037 | Pouchak | Apr 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20070263552 A1 | Nov 2007 | US |
Number | Date | Country | |
---|---|---|---|
60776796 | Feb 2006 | US |