The present disclosure relates generally to communication systems, and more specifically to a system and method for managing communications.
As businesses and the population expand, the providing of inter-city/long-haul communication services becomes more desirable. Inter-city/long-haul communication services can be provided by building an overlay inter-LATA network by laying down fiber; by leasing dark fiber from a long distance service provider; by leasing wavelengths from a long distance service provider; and by leasing circuits such as Packet over SONET (POS), Frame Relay, and ATM from a long distance service provider. However, each of these options can be very expensive and can be a time consuming process. The cost and time spent can be exacerbated by the particular location of the overlay network and its extent.
A need therefore arises for a system and method for managing communications.
Embodiments in accordance with the present disclosure provide a system and method for managing communications.
In a first embodiment of the present disclosure, a computer-readable storage medium, in a network proxy of a first communication system, can have computer instructions for establishing internet access through an internet service provider; establishing a Generic Route Encapsulation (GRE) tunnel to a second communication system through the internet service provider; establishing VRF functionality in a border router of the first communication system that uses MPLS protocol; and routing a packet from the first communication system to the second communication system along the GRE tunnel according to a MPLS label of the packet and a VRF routing table.
In a second embodiment of the present disclosure, a method of providing a communication service between first and second service providers, can involve establishing a logical tunnel to the first and second service providers utilizing an internet service provider; and routing a packet along the logical tunnel between the first and second service providers according to a MPLS label of the packet and a VRF routing table.
In a third embodiment of the present disclosure, a communication device can have a controller element to transmit a packet along a logical tunnel established through an internet service provider, wherein the route of the packet is managed according to a MPLS label of the packet and a VRF routing table.
In a fourth embodiment of the present disclosure, a network element of a first communication system can have a controller element to receive a packet from a second communication system along a Generic Route Encapsulation (GRE) tunnel according to a MPLS label of the packet and a VRF routing table, wherein the GRE tunnel is established through an internet service provider.
As a packet-switched network, network 105 can represent an Internet Service Provider (ISP) network. The network 105 can be coupled to a network proxy 122, a cellular network 113 and network elements, including network elements located in one or more of the buildings 112. As a circuit-switched network, network 105, can provide PSTN services to fixed communication devices 116. In a combined embodiment, network 105 can utilize technology for transporting Internet, voice, and video traffic.
In an enterprise setting, the building 112 can include a gateway 114 that provides voice and/or video connectivity services between communication devices 116, such as VoIP terminals or other forms of communication devices of enterprise personnel. In a residential setting, the building 112 can include a gateway 114 represented by, for example, a residential gateway coupled to central office 106 utilizing conventional telephonic switching for processing calls with third parties.
The network proxy 122 can be used to control operations of a media gateway 109, the central office 106 and/or the gateway 114. Communications between the network proxy 122, the communication devices 116 and other network elements of the communication system 100 can conform to any number of signaling protocols such as a session initiation protocol (SIP), or a video communications protocol such as H.323 which combines video and voice over a packet-switched network.
The network proxy 122 can comprise a communications interface 124 that utilizes common technology for communicating over an IP interface with the network 105, the media gateway 109, the cellular network 113, and/or the gateway 114. By way of the communications interface 124, the network proxy 122 can direct by common means any of the foregoing network elements to establish packet switched data, voice, and/or video connections between communication devices 116 distributed throughout the communication system 100. The network proxy 122 can further comprise a memory 126 (such as a high capacity storage medium) embodied in this illustration as a database, and a controller 128 that makes use of computing technology such as a desktop computer, or scalable server for controlling operations of the network proxy 122. The network proxy 122 can operate as an IP Multimedia Subsystem (IMS) conforming in part to protocols defined by standards bodies such as 3GPP (Third Generation Partnership Protocol).
Under the control of the network proxy 122, the media gateway 109 can link packet-switched and circuit-switched technologies such as the cellular network 113 (or central office 106) and the network 105, such as an ISP network. The media gateway 109 can conform to a media gateway control protocol (MGCP) also known as H.248 defined by work groups in the Internet Engineering Task Force (IETF). This protocol can handle signaling and session management needed during a multimedia conference. The protocol defines a means of communication which converts data from the format required for a circuit-switched network to that required for a packet-switched network. MGCP can therefore be used to set up, maintain, and terminate calls between multiple disparate network elements of the communication system 100. The media gateway 109 can therefore support hybrid communication environments for communication devices 116, including VoIP terminals.
The cellular network 113 can support voice and data services over a number of access technologies such as GSM-GPRS, EDGE, CDMA-1X, UMTS, WiMAX, software defined radio (SDR), and other known and future technologies. The cellular network 113 can be coupled to base stations 127 under a frequency-reuse plan for communicating over-the-air with roaming VoIP terminals 116. The communication system 100 can utilize common computing and communications technologies to support circuit-switched and/or packet-switched communications, including MPLS.
The geographic area of the network 105 and LATAs 210 and 220 can vary. In one embodiment, network 105 can be a long-haul Internet service provider capable of operating over large distances, such as inter-city, inter-state, and international communications. In one embodiment, the LATAs 210 and 220 can be located in different cities or other distinct areas.
Each of the network 105 and LATAs 210 and 220 can comprise network elements 250 for communication, including routers for transmitting packets over each of the networks and between the networks. The routers can include provider routers (P), such as provider edge routers (PE) that are customer location equipment (PE-CLE) and point of presence (PE-POP), and autonomous system border routers (ASBR). A logical tunnel 275, such as a Generic Routing Encapsulation tunnel (GRE) can be established between the LATAs 210 and 220 over the network 105. The packets can be transmitted according to various protocols and combinations of protocols, including Border Gateway Protocol (BGP), External Border Gateway Protocol (EBGP), Ethernet over MPLS (EoMPLS), Internal Border Gateway Protocol (IBGP), Internet Protocol (IP), Layer-2 Tunneling Protocol version 3 (L2TPv3), Label Distribution Protocol (LDP), Multi-Protocol Border Gateway Protocol (MP-BGP), Multi-Protocol Label Switching (MPLS), Open Shortest Path First (OSPF), and Virtual Routing and Forwarding (VRF).
Communication system 300 can transmit packet 320 with various tags provided by the various network elements 250, including VLAN, LDP, VC, IP, GRE, and VPN. The packet 320 can be transmitted from Site A to Site B without changing the VC-Label. Packet 320 can also be transmitted over the inter-city/long-haul service provider network 105 without the GRE header, IP header and VPN label being changed. In one embodiment, the services that the local Ethernet service provider is offering by way of LATAs 210 and 220 to Sites A and B can be done so without the inter-city/long-haul service provider being made aware.
Similar to the LATAs 210 and 220, the LATA 430 can comprise network elements 250 for communication, including routers for transmitting packets over each of the networks and between the networks. The routers can include provider routers 4(P), such as provider edge routers (PE) that are customer location equipment (PE-CLE) and point of presence (PE-POP), and autonomous system border routers (ASBR). Logical tunnels 275, such as a Generic Routing Encapsulation tunnel (GRE), can be established between the LATAs 210, 220 and 430 over the network 105. The packets 320 can be transmitted according to various protocols and combinations of protocols, including BGP, EBGP, EoMPLS, IBGP, IP, L2TPv3, LDP, MP-BGP, MPLS, OSPF, and VRF.
Method 500 begins with step 502 in which network elements 250 of LATAs 210 and 220 can advertise their loopback address to one or more available ISP networks 105. For example, ASBR-A can advertise ASBR-A's /32 IPv4 loopback address to ASBR-SP-A. Similarly, ASBR-B can advertise ASBR-B's /32 IPv4 loopback address to ASBR-SP-B. These loopback address can be advertised through suitable protocol, such as EBGP.
In step 504, the LATAs 210 and 220 can determine if an ISP network 105 is available. If an ISP network 105 is available and retrieves the loopback addresses then the network elements 250 of the ISP network can advertise the loopback addresses of the network elements of the LATA's 210 and 220, as in step 506. For example, the ASBR-SP-A can advertise ASBR-A's /32 IPv4 loopback address to ASBR-SP-B. Similarly, ASBR-SP-B can advertise ASBR-B's /32 IPv4 loopback address to ASBR-SP-A. These loopback address can be advertised through suitable protocol, such as IBGP. ASBR-SP-B can then advertise ASBR-A's /32 IPv4 loopback address to ASBR-B with ASBR-SP-B as the next hop. Similarly, ASBR-SP-A can advertise ASBR-B's /32 IPv4 loopback address to ASBR-A with ASBR-SP-A as the next hop. These loopback address can be advertised through suitable protocol, such as EBGP. If on the other hand an ISP network 105 is unavailable, then the LATAs 210 and 220 can notify the users (e.g., an unavailability message in step 508) and/or continue to advertise the loopback addresses.
In step 510, the LATAs 210 and 220 can establish a logical tunnel over the ISP network 105 based upon the receipt of the loopback addresses. In one embodiment, the logical tunnel can be the GRE tunnel 275. For example, the ASBR-A and ASBR-B can utilize the loopback addresses received to establish the GRE tunnel over the ISP network 105 between each other.
In one embodiment, the LATAs 210 and 220 can have the same autonomous system (AS) number. The LATAs 210 and 220 can disable a loop detection function to prevent an erroneous detection of a loop caused by use of the same AS number, as in step 512. In another embodiment, the LATAs 210 and 220 can poison the routes to prevent routing loops, such as through use of distance-vector routing protocols and indicating to one or more routers that a route is no longer reachable, as in step 514.
With a logical tunnel established between network elements 250 of LATAs 210 and 220, such as between ASBR-A and ASBR-B, a VRF functionality can be established in ASBR-A and ASBR-B. In step 516, MPLS switching can be turned on in VRF instances. In step 518, a VRF instance can be included in an OSPF routing protocol instance of the LATAs 210 and 220 (e.g., local Ethernet service provider networks).
With the VRF functionality established between the network elements 250 of LATAs 210 and 220, OSPF adjacency through the GRE tunnel 275 can be established, as in step 520. The OSPF can allow the ASBR-A and ASBR-B to exchange all the routes between each other. In step 522, a targeted LDP session can be established between network elements 250 of the LATAs 210 and 220, such as PE-POP-A and PE-POP-B. In step 524, an Ethernet over MPLS (EOMPLS) virtual circuit (VC) can be established between network elements 250 of the LATAs 210 and 220, such as PE-POP-A and PE-POP-B. For example, the PE-POP-A can advertise the VC label for VLAN-A to PE-POP-B via the targeted LDP session, and the PE-POP-B can advertise the VC label for VLAN-B to PE-POP-A via the targeted LDP session.
With the EoMPLS virtual circuit established between network elements 250 of the LATAs 210 and 220, an inter-city/long-haul Ethernet service between PE-CLE-A and PE-CLE-B can be established, as in step 526. For example, a port between PE-CLE-A and Site-A can be configured as a trunk port, and VLAN-A can be added to that port. Similarly, a port between PE-CLE-B and Site-B can be configured as a trunk port, and VLAN-B can be added to that port. A port between PE-CLE-A and PE-POP-A can be configured as a trunk port, and VLAN-A can be added to that port. Similarly, a port between PE-CLE-B and PE-POP-B can be configured as a trunk port, and VLAN-B can be added to that port. The communication of packets 320 can be managed according to MPLS switching and the VRF functionality.
From the foregoing descriptions, it would be evident to an artisan with ordinary skill in the art that the aforementioned embodiments can be modified, reduced, or enhanced without departing from the scope and spirit of the claims described below. For example, the LATAs 210 and 220 can establish other types of logical tunnels over the ISP network 105, such as a L2TP tunnel. The number and configuration of the LATAs can be such that a local Ethernet service provider can establish its own overlay network, which is a logical overlay network, and can provide other services, such as IP-VPN, so as to become a virtual ISP. These are but a few examples of the modifications that can be applied to the present disclosure without departing from the scope of the claims. Accordingly, the reader is directed to the claims for a fuller understanding of the breadth and scope of the present disclosure.
The machine may comprise a server computer, a client user computer, a personal computer (PC), a tablet PC, a laptop computer, a desktop computer, a control system, a network router, switch or bridge, or any machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. It will be understood that a device of the present disclosure includes broadly any electronic device that provides voice, video or data communication. Further, while a single machine is illustrated, the term “machine” shall also be taken to include any collection of machines that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.
The computer system 600 may include a processor 602 (e.g., a central processing unit (CPU), a graphics processing unit (GPU, or both), a main memory 604 and a static memory 606, which communicate with each other via a bus 608. The computer system 600 may further include a video display unit 610 (e.g., a liquid crystal display (LCD), a flat panel, a solid state display, or a cathode ray tube (CRT)). The computer system 600 may include an input device 612 (e.g., a keyboard), a cursor control device 614 (e.g., a mouse), a mass storage medium 616, a signal generation device 618 (e.g., a speaker or remote control) and a network interface device 620.
The mass storage medium 616 may include a computer-readable storage medium 622 on which is stored one or more sets of instructions (e.g., software 624) embodying any one or more of the methodologies or functions described herein, including those methods illustrated above. The computer-readable storage medium 622 can be an electromechanical medium such as a common disk drive, or a mass storage medium with no moving parts such as Flash or like non-volatile memories. The instructions 624 may also reside, completely or at least partially, within the main memory 604, the static memory 606, and/or within the processor 602 during execution thereof by the computer system 600. The main memory 604 and the processor 602 also may constitute computer-readable storage media.
Dedicated hardware implementations including, but not limited to, application specific integrated circuits, programmable logic arrays and other hardware devices can likewise be constructed to implement the methods described herein. Applications that may include the apparatus and systems of various embodiments broadly include a variety of electronic and computer systems. Some embodiments implement functions in two or more specific interconnected hardware modules or devices with related control and data signals communicated between and through the modules, or as portions of an application-specific integrated circuit. Thus, the example system is applicable to software, firmware, and hardware implementations.
In accordance with various embodiments of the present disclosure, the methods described herein are intended for operation as software programs running on a computer processor. Furthermore, software implementations can include, but not limited to, distributed processing or component/object distributed processing, parallel processing, or virtual machine processing can also be constructed to implement the methods described herein.
The present disclosure contemplates a machine readable medium containing instructions 624, or that which receives and executes instructions 624 from a propagated signal so that a device connected to a network environment 626 can send or receive voice, video or data, and to communicate over the network 626 using the instructions 624. The instructions 624 may further be transmitted or received over a network 626 via the network interface device 620.
While the computer-readable storage medium 622 is shown in an example embodiment to be a single medium, the term “computer-readable storage medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The term “computer-readable storage medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present disclosure.
The term “computer-readable storage medium” shall accordingly be taken to include, but not be limited to: solid-state memories such as a memory card or other package that houses one or more read-only (non-volatile) memories, random access memories, or other re-writable (volatile) memories; magneto-optical or optical medium such as a disk or tape; and carrier wave signals such as a signal embodying computer instructions in a transmission medium; and/or a digital file attachment to e-mail or other self-contained information archive or set of archives is considered a distribution medium equivalent to a tangible storage medium. Accordingly, the disclosure is considered to include any one or more of a computer-readable storage medium or a distribution medium, as listed herein and including art-recognized equivalents and successor media, in which the software implementations herein are stored.
Although the present specification describes components and functions implemented in the embodiments with reference to particular standards and protocols, the disclosure is not limited to such standards and protocols. Each of the standards for Internet and other packet switched network transmission (e.g., TCP/IP, UDP/IP, HTML, HTTP) represent examples of the state of the art. Such standards are periodically superseded by faster or more efficient equivalents having essentially the same functions. Accordingly, replacement standards and protocols having the same functions are considered equivalents.
The illustrations of embodiments described herein are intended to provide a general understanding of the structure of various embodiments, and they are not intended to serve as a complete description of all the elements and features of apparatus and systems that might make use of the structures described herein. Many other embodiments will be apparent to those of skill in the art upon reviewing the above description. Other embodiments may be utilized and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. Figures are also merely representational and may not be drawn to scale. Certain proportions thereof may be exaggerated, while others may be minimized. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.
Such embodiments of the inventive subject matter may be referred to herein, individually and/or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is in fact disclosed. Thus, although specific embodiments have been illustrated and described herein, it should be appreciated that any arrangement calculated to achieve the same purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the above description.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separately claimed subject matter.