Recording of communications is important to many industries, particularly those in which compliance regulations have been implemented. In this regard, a traditional passive tap Internet Protocol (IP) recording technique includes recorders that are deployed along routes of communications. In this technique, each recorder operates similar to a “sniffer” by analyzing pass-by communication IP packets. Each recorder detects the packets corresponding to certain communication sessions, locally stores the sessions by gathering the corresponding packets, and then directs the recorded sessions to long term storage. Clearly, interfacing such recorders with the communication network in the proper locations is required to ensure that the desired communications are detected and ultimately recorded.
Systems and methods for providing recording as a network service are provided. In this regard, an embodiment of such a system comprises a switching device operative to: communicate Internet Protocol (IP) packets of a network with which the switching device is associated; receive instructions indicating that IP packets associated with a communication that is to be recorded are to be directed to long term storage; determine which of the IP packets communicated by the switching device are associated with a communication that is to be recorded; and direct information corresponding to the IP packets associated with the communication to a long term storage device. The switching device is a network infrastructure component configured for directing IP packets.
An embodiment of such a method comprises: communicating instructions to a network, the instructions indicating that IP packets associated with a communication that is to be recorded are to be directed to long term storage such that the network: receives the instructions; determines whether Internet Protocol (IP) packets, which are being communicated by the network, are associated with a communication that is to be recorded; and directs information corresponding to the IP packets associated with the communication to a long term storage device.
A computer-readable media having computer programs stored thereon also are provided. An embodiment of such a computer-readable medium has computer program comprising computer-executable instructions for performing the computer-implemented steps of: communicating instructions to a network, the instructions indicating that IP packets associated with a communication that is to be recorded are to be directed to long term storage such that the network: receives the instructions; determines whether Internet Protocol (IP) packets, which are being communicated by the network, are associated with the communication; and directs the IP packets associated with the communication to a long term storage device.
Other systems, methods, features and/or advantages of this disclosure will be or may become apparent to one with skill in the art upon examination of the following drawings and detailed description. It is intended that all such additional systems, methods, features and/or advantages be included within this description and be within the scope of the present disclosure.
Many aspects of the disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
As will be described here with reference to several exemplary embodiments, systems and methods for providing recording as a network service are provided. In this regard, some embodiments of such a system involve the use of switching devices, e.g., network switches, network routers and/or other components that form the infrastructure of many communication networks, such as the World Wide Web. Specifically, in these embodiments, the switching devices themselves are capable of performing various functionality that conventionally is provided by recorders, which typically tap into a network, e.g., at a switching device, in order to record communications.
Referring now in detail to the drawings,
Communicating with each of networks 102 and 104 is a network switching device 110 that can be used for directing IP packets, such as directing IP packets between the networks. For instance, the network switching device can be a network switch, which directs IP packets based on the ports of the switch that receive the packets, or a network router, which directs IP packets based on header information contained in the packets.
Long term storage 112 also communicates with the networks 102, 104 and thus with the switching device 110. By way of example, long term storage 112 can be a storage area network (SAN) or network attached storage (NAS). Long term storage 112 receives IP packets, such as IP packets associated with a communication that is to be recorded, and stores information corresponding to the IP packets so that the recorded communications can be replayed. By way of example, in some embodiments in which the communications involve voice communications, received IP packets could be converted to audio files for storage, or the IP packets themselves could be stored. Notably, various other types of communications could be involved, such as email, chat and/or corresponding screens of data that are displayed during such communications. Clearly, the switching device could forward raw IP packets or re-ordered IP packets (i.e., IP packets arranged for conversion to a file type such as an audio file).
In determining whether IP packets are associated with a communication that is to be recorded, various techniques can be used. By way of example, embodiments of such a system can incorporate one or more of receiving, filtering, analyzing and storing of the IP packets. In this regard, it should be noted that an IP packet (which can be of various IP versions, e.g., IPv4, Ipv6) incorporates three basic elements, i.e., a header, a data area, and a trailer. The header designates the beginning of the packet, the data area includes the data payload, and the trailer designates the end of the packet.
In some embodiments, the determining step mentioned above can include analyzing of one or more of the three basic elements of the IP-packets received by the system. By way of example, some embodiments can operate in a promiscuous mode, in which each packet received is read in its entirety. Thus, in some embodiments, the device(s) of the system associated with performing the determining step can capture and save the packets for analysis.
Additionally or alternatively, such a system can operate in monitor mode, in which the device(s) of the system associated with performing the determining step wirelessly receive the packets and then act on the packets in a manner similar to the promiscuous mode.
Additionally or alternatively, such a system can operate in non-promiscuous (or normal) mode, in which the device(s) of the system associated with performing the determining step check the address of the packet and merely forward the packet to a next device if the packet is not of interest. Thus, these embodiments perform a type of filtering.
Referring back to
In block 312, the instructions are received at the switching device. In block 314, a determination is made as to whether Internet Protocol (IP) packets, which are being communicated by the switching device, are associated with a communication that is to be recorded. Notably, the particular communication and/or the criteria for determining whether the communication is to be recorded are contained in the instructions. In block 316, the switching device is used to direct the IP packets associated with the communication to long term storage.
In contrast to conventional methods of recording that use dedicated recorders for tapping communications, using a switching device potentially reduces the latency associated with buffering IP packets in such a recorder prior to the recorder directing the captured data to long term storage. That is, in some embodiments, a switching device may not perform a buffering function at all, instead directing IP packets associated with communications that are to be recorded directly to a network-connected long term storage device without first buffering the packets. In other embodiments, however, some form of buffering could be provided by the switching device depending upon its particular configuration.
Additionally, by streaming information for recording directly to network attached storage, optimal usage of hard disks may be achieved. This is because hard disks used for storage typically are sized for expected load even though such load is difficult to predict. By sharing the hard disks attached to the network, the potential of a single hard disk being over used is diminished.
It should be noted that, in contrast to the embodiment described above with respect to
Communicating with each of networks 402 and 404 is a network switching device 410 that can be used for directing IP packets. Long term storage 412 communicates with the networks 402, 404 and thus with the switching device 410. Long term storage 412 receives IP packets, such as IP packets associated with a communication that is to be recorded, and stores information corresponding to the IP packets so that the recorded communications can be replayed. In some embodiments, such information could include an identification of the source (e.g., source address), an identification of the destination (e.g., destination address), identification of an agent that is a party to the communication, machine name and/or called phone number, for example.
As shown in
Additionally or alternatively, duplicate recording of information can potentially be avoided. In some embodiments, this can be accomplished by permitting the storage devices to communicate with each other regarding recording activity. This could be facilitated via a network protocol. In other embodiments, a recording-controller could be used to track the recording activity of the recording devices and to direct the recording activity. By way of example, the recording controller could inform the network about the recording device(s) that should be used for recording.
The processor 502 may be a hardware device for executing software, particularly software stored in memory 504. In this regard, the processor can be a custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the recorder, a semiconductor based microprocessor (in the form of a microchip or chip set), a macroprocessor, or generally any device for executing software instructions.
The memory 504 can include one or combination of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)) and nonvolatile memory elements (e.g., ROM, hard drive, tape, CDROM, etc.). Moreover, the memory may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory can have a distributed architecture, where various components are situated remote from one another, but can be accessed by the processor. Additionally, the memory can include an operating system 512, as well as instructions associated with a recording controller 520.
The software in memory may include one or more separate programs, each of which includes an ordered listing of executable instructions for implementing logical functions. The operating system can be configured to control the execution of other computer programs and provides scheduling, input-communication control, file and data management, memory management, and communication control and/or related services.
It should be noted that a system component embodied as software may also be construed as a source program, executable program (object code), script, or any other entity comprising a set of instructions to be performed. When constructed as a source program, the program is translated via a compiler, assembler, interpreter, or the like, which may or may not be included within the memory, so as to operate properly in connection with the operating system.
When the computer 500 is in operation, the processor is configured to execute software stored within the memory, to communicate data to and from the memory, and to generally control operations of the recorder pursuant to the software. Software in memory, in whole or in part, is read by the processor, perhaps buffered, and is then executed. In this regard, when executing instructions associated with the recording controller, the exemplary functionality described above with respect to recording controllers may be performed.
Communicating with each of networks 702 and 704 is a network switching device 710 that can be used for directing IP packets. Long term storage 712 communicates with the networks 702, 704 and thus with the switching device 710. Long term storage 712 receives IP packets, such as IP packets associated with a communication that is to be recorded, and stores information corresponding to the IP packets so that the recorded communications can be replayed. Notably, the IP packets received can be copies or some other interpretation of the original IP packets, thereby ensuring that the original packets continue to be routed as desired.
As shown in
In some embodiments, the recorder determines which of the IP packets are to be recorded based on the tapping of the switching device and then directs the switching device to direct those packets for long term storage. In other embodiments, responsive to determining which of the IP packets are to be recorded based on the tapping of the switching device, the recorder transmits those packets back to the switching device so that those packets can be directed by the switching device to long term storage.
In such an embodiment, the recorder is somewhat similar to a conventional recorder in that the recorder taps communications. However, unlike a conventional recorder, the recorder of
It should be noted that any of the executable instructions, such as those depicted functionally in the accompanying flowcharts, can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions. In the context of this document, a “computer-readable medium” can be any means that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer readable medium can be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device. More specific examples (a non-exhaustive list) of the computer-readable medium could include an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical). In addition, the scope of embodiments of this disclosure can include embodying the functionality described in logic embodied in hardware or software-configured media.
It should also be noted that the flowcharts included herein show the architecture, functionality and/or operation of implementations that may be configured using software. In this regard, each block can be interpreted to represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that in some alternative implementations, the functions noted in the blocks may occur out of the order depicted. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.
It should be emphasized that the above-described embodiments are merely possible examples of implementations set forth for a clear understanding of the principles of this disclosure. Many variations and modifications may be made to the above-described embodiments 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.
This application is a utility application that is based on and claims priority to U.S. Provisional Application Ser. No. 60/817,630, filed on Jun. 29, 2006, and which is incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
3594919 | De Bell et al. | Jul 1971 | A |
3705271 | De Bell et al. | Dec 1972 | A |
4510351 | Costello et al. | Apr 1985 | A |
4684349 | Ferguson et al. | Aug 1987 | A |
4694483 | Cheung | Sep 1987 | A |
4763353 | Canale et al. | Aug 1988 | A |
4815120 | Kosich | Mar 1989 | A |
4924488 | Kosich | May 1990 | A |
4953159 | Hayden et al. | Aug 1990 | A |
5016272 | Stubbs et al. | May 1991 | A |
5101402 | Chiu et al. | Mar 1992 | A |
5117225 | Wang | May 1992 | A |
5210789 | Jeffus et al. | May 1993 | A |
5239460 | LaRoche | Aug 1993 | A |
5241625 | Epard et al. | Aug 1993 | A |
5267865 | Lee et al. | Dec 1993 | A |
5299260 | Shaio | Mar 1994 | A |
5311422 | Loftin et al. | May 1994 | A |
5315711 | Barone et al. | May 1994 | A |
5317628 | Misholi et al. | May 1994 | A |
5347306 | Nitta | Sep 1994 | A |
5388252 | Dreste et al. | Feb 1995 | A |
5396371 | Henits et al. | Mar 1995 | A |
5432715 | Shigematsu et al. | Jul 1995 | A |
5465286 | Clare et al. | Nov 1995 | A |
5475625 | Glaschick | Dec 1995 | A |
5485569 | Goldman et al. | Jan 1996 | A |
5491780 | Fyles et al. | Feb 1996 | A |
5499291 | Kepley | Mar 1996 | A |
5535256 | Maloney et al. | Jul 1996 | A |
5572652 | Robusto et al. | Nov 1996 | A |
5577112 | Cambray et al. | Nov 1996 | A |
5590171 | Howe et al. | Dec 1996 | A |
5597312 | Bloom et al. | Jan 1997 | A |
5619183 | Ziegra et al. | Apr 1997 | A |
5696906 | Peters et al. | Dec 1997 | A |
5717879 | Moran et al. | Feb 1998 | A |
5721842 | Beasley et al. | Feb 1998 | A |
5742670 | Bennett | Apr 1998 | A |
5748499 | Trueblood | May 1998 | A |
5778182 | Cathey et al. | Jul 1998 | A |
5784452 | Carney | Jul 1998 | A |
5790798 | Beckett, II et al. | Aug 1998 | A |
5796952 | Davis et al. | Aug 1998 | A |
5809247 | Richardson et al. | Sep 1998 | A |
5809250 | Kisor | Sep 1998 | A |
5825869 | Brooks et al. | Oct 1998 | A |
5835572 | Richardson, Jr. et al. | Nov 1998 | A |
5862330 | Anupam et al. | Jan 1999 | A |
5864772 | Alvarado et al. | Jan 1999 | A |
5884032 | Bateman et al. | Mar 1999 | A |
5907680 | Nielsen | May 1999 | A |
5918214 | Perkowski | Jun 1999 | A |
5923746 | Baker et al. | Jul 1999 | A |
5933811 | Angles et al. | Aug 1999 | A |
5944791 | Scherpbier | Aug 1999 | A |
5948061 | Merriman et al. | Sep 1999 | A |
5958016 | Chang et al. | Sep 1999 | A |
5964836 | Rowe et al. | Oct 1999 | A |
5978648 | George et al. | Nov 1999 | A |
5982857 | Brady | Nov 1999 | A |
5987466 | Greer et al. | Nov 1999 | A |
5990852 | Szamrej | Nov 1999 | A |
5991373 | Pattison et al. | Nov 1999 | A |
5991796 | Anupam et al. | Nov 1999 | A |
6005932 | Bloom | Dec 1999 | A |
6009429 | Greer et al. | Dec 1999 | A |
6014134 | Bell et al. | Jan 2000 | A |
6014647 | Nizzari et al. | Jan 2000 | A |
6018619 | Allard et al. | Jan 2000 | A |
6035332 | Ingrassia et al. | Mar 2000 | A |
6038544 | Machin et al. | Mar 2000 | A |
6039575 | L'Allier et al. | Mar 2000 | A |
6057841 | Thurlow et al. | May 2000 | A |
6058163 | Pattison et al. | May 2000 | A |
6061798 | Coley et al. | May 2000 | A |
6072860 | Kek et al. | Jun 2000 | A |
6076099 | Chen et al. | Jun 2000 | A |
6078894 | Clawson et al. | Jun 2000 | A |
6091712 | Pope et al. | Jul 2000 | A |
6108711 | Beck et al. | Aug 2000 | A |
6122665 | Bar et al. | Sep 2000 | A |
6122668 | Teng et al. | Sep 2000 | A |
6130668 | Stein | Oct 2000 | A |
6138139 | Beck et al. | Oct 2000 | A |
6144991 | England | Nov 2000 | A |
6146148 | Stuppy | Nov 2000 | A |
6151622 | Fraenkel et al. | Nov 2000 | A |
6154771 | Rangan et al. | Nov 2000 | A |
6157808 | Hollingsworth | Dec 2000 | A |
6171109 | Ohsuga | Jan 2001 | B1 |
6182094 | Humpleman et al. | Jan 2001 | B1 |
6195679 | Bauersfeld et al. | Feb 2001 | B1 |
6201948 | Cook et al. | Mar 2001 | B1 |
6211451 | Tohgi et al. | Apr 2001 | B1 |
6225993 | Lindblad et al. | May 2001 | B1 |
6230197 | Beck et al. | May 2001 | B1 |
6236977 | Verba et al. | May 2001 | B1 |
6244758 | Solymar et al. | Jun 2001 | B1 |
6282548 | Burner et al. | Aug 2001 | B1 |
6286030 | Wenig et al. | Sep 2001 | B1 |
6286046 | Bryant | Sep 2001 | B1 |
6288753 | DeNicola et al. | Sep 2001 | B1 |
6289340 | Puram et al. | Sep 2001 | B1 |
6301462 | Freeman et al. | Oct 2001 | B1 |
6301573 | McIlwaine et al. | Oct 2001 | B1 |
6324282 | McIlwaine et al. | Nov 2001 | B1 |
6347374 | Drake et al. | Feb 2002 | B1 |
6351467 | Dillon | Feb 2002 | B1 |
6353851 | Anupam et al. | Mar 2002 | B1 |
6360250 | Anupam et al. | Mar 2002 | B1 |
6370574 | House et al. | Apr 2002 | B1 |
6404857 | Blair et al. | Jun 2002 | B1 |
6411989 | Anupam et al. | Jun 2002 | B1 |
6418471 | Shelton et al. | Jul 2002 | B1 |
6459787 | McIlwaine et al. | Oct 2002 | B2 |
6487195 | Choung et al. | Nov 2002 | B1 |
6493758 | McLain | Dec 2002 | B1 |
6502131 | Vaid et al. | Dec 2002 | B1 |
6510220 | Beckett, II et al. | Jan 2003 | B1 |
6535909 | Rust | Mar 2003 | B1 |
6542602 | Elazer | Apr 2003 | B1 |
6546405 | Gupta et al. | Apr 2003 | B2 |
6560328 | Bondarenko et al. | May 2003 | B1 |
6583806 | Ludwig et al. | Jun 2003 | B2 |
6606657 | Zilberstein et al. | Aug 2003 | B1 |
6665644 | Kanevsky et al. | Dec 2003 | B1 |
6674447 | Chiang et al. | Jan 2004 | B1 |
6683633 | Holtzblatt et al. | Jan 2004 | B2 |
6697858 | Ezerzer et al. | Feb 2004 | B1 |
6724887 | Eilbacher et al. | Apr 2004 | B1 |
6738456 | Wrona et al. | May 2004 | B2 |
6757361 | Blair et al. | Jun 2004 | B2 |
6772396 | Cronin et al. | Aug 2004 | B1 |
6775377 | McIlwaine et al. | Aug 2004 | B2 |
6792575 | Samaniego et al. | Sep 2004 | B1 |
6810414 | Brittain | Oct 2004 | B1 |
6820083 | Nagy et al. | Nov 2004 | B1 |
6823384 | Wilson et al. | Nov 2004 | B1 |
6870916 | Henrikson et al. | Mar 2005 | B2 |
6871229 | Nisani et al. | Mar 2005 | B2 |
6901438 | Davis et al. | May 2005 | B1 |
6959078 | Eilbacher et al. | Oct 2005 | B1 |
6965886 | Govrin et al. | Nov 2005 | B2 |
7194550 | Chamdani et al. | Mar 2007 | B1 |
7296080 | Rowley et al. | Nov 2007 | B2 |
20010000962 | Rajan | May 2001 | A1 |
20010032335 | Jones | Oct 2001 | A1 |
20010043697 | Cox et al. | Nov 2001 | A1 |
20020038363 | MacLean | Mar 2002 | A1 |
20020052948 | Baudu et al. | May 2002 | A1 |
20020065911 | Von Klopp et al. | May 2002 | A1 |
20020065912 | Catchpole et al. | May 2002 | A1 |
20020128925 | Angeles | Sep 2002 | A1 |
20020143925 | Pricer et al. | Oct 2002 | A1 |
20020165954 | Eshghi et al. | Nov 2002 | A1 |
20030055883 | Wiles et al. | Mar 2003 | A1 |
20030079020 | Gourraud et al. | Apr 2003 | A1 |
20030118053 | Edsall et al. | Jun 2003 | A1 |
20030144900 | Whitmer | Jul 2003 | A1 |
20030154240 | Nygren et al. | Aug 2003 | A1 |
20040100507 | Hayner et al. | May 2004 | A1 |
20040111473 | Lysenko et al. | Jun 2004 | A1 |
20040165717 | McIlwaine et al. | Aug 2004 | A1 |
20040250205 | Conning | Dec 2004 | A1 |
20050108518 | Pandya et al. | May 2005 | A1 |
20050135680 | Lee et al. | Jun 2005 | A1 |
20050180341 | Nelson et al. | Aug 2005 | A1 |
20060168234 | Safstrom et al. | Jul 2006 | A1 |
Number | Date | Country |
---|---|---|
0453128 | Oct 1991 | EP |
0773687 | May 1997 | EP |
0989720 | Mar 2000 | EP |
2369263 | May 2002 | GB |
WO 9843380 | Nov 1998 | WO |
WO 0016207 | Mar 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20080005307 A1 | Jan 2008 | US |
Number | Date | Country | |
---|---|---|---|
60817630 | Jun 2006 | US |