1. Field of the Invention
The present invention relates to a packet communications system and a transfer device for use therein.
2. Description of the Related Art
Referring to
The conventional router device 50 is a transfer device for routing and forwarding packets such as IP packets in the Internet. As shown in
The conventional router device 50 is equipped with a routing processor (routing engine) 51j and a forwarding unit (forwarding engine) 51k, which transact with hardware, in each circuit interface 511 to 51n, so that high-speed packet transfer without decrease in throughput transferring IP packets is achieved as Internet traffic increases.
Recently, various kinds of traffic including real-time traffic such as voice, non-real-time traffic such as e-mail, and signaling traffic such as call-controlling signals and location-registering signals are transferred over IP packets. Each traffic has a different requirement for communication quality.
Therefore the router device 50 is equipped with new functions such as a marking function (packet processor 51i), queueing function, and scheduling function (scheduler 51h), The marking function is configured to add a priority flag to an IP packet for priority processing on a packet basis. The queueing function is configured to queue IP packets based on a priority class. The scheduling function is configured to read IP packets based on a priority class.
In recent years, it is assumed that the router device 50 is required for sophisticated processing of IP packets, so as to achieve various kinds of packet communications services such as a first filtering function, a second filtering function, an address-converting function, a first buffering function, a second buffering function, a counting function, capsuling function, a copy function, and a multiplexing function.
The first filtering function is configured to discard selected IP packets according to a destination IP address, a source IP address, or a type/content of the higher level application, as a security service in an IP packet communications network.
The second filtering function is configured to perform congestion control by discarding selected IP packets according to traffic in an IP packet communications network.
The address-converting function is configured to change a destination IP address so as to change the routing destination as the destination terminal moves.
The first buffer function is configured to buffer IP packets temporarily as the destination terminal moves, so as to reduce the IP packet loss of the hand-over phase.
The second buffer function is configured to buffer IP packets temporarily as the destination terminal moves, so as to perform a shaping processing to a burst of traffic.
The counting function is configured to count the amount of information in one packet so as to measure traffic.
The capsuling function is configured to transfer an inputted packet over a different packet, that is, perform a tunneling processing, which is used in MPLS (Multi-protocol Label Switching) or Mobile IP, etc.
The copy function is used in the multicast communication. The multiplexing function is configured to multiplex and select a plurality of IP packets.
However, as described above, the conventional router device 50 is equipped with the required functions (including functions which may be required in the future) in the circuit interfaces 511 to 51n, and executes the functions at a speed which is similar to the input interface speed, so as to achieve high throughput.
The conventional router device 50 has a problem in that the implementation and the internal processing in the router device 50 have become sophisticated and the cost of manufacturing of the router device 50 rises, as the kinds of functions implemented in the circuit interfaces 511 to 51n increase.
The conventional router device 50 has a problem in that it is difficult to add new functions and to make connections among the functions, when each function is implemented into circuit interfaces 511 to 51n as hardware.
The conventional packet communications network has a problem in that the required dedicated signaling protocol has to be implemented in the router device 50 when a new function is added or a new network control is performed, because an independent protocol such as signaling protocol is implemented to each function so as to execute a plurality of functions as described above. The conventional packet communications network has a problem in that a lot of processors for processing the signaling protocol have to be implemented in the router device 50, so that the cost of performing the signaling processing rises.
For example, in the “Mobile IP”, the router device 50 has to be equipped with a dedicated protocol stack as an agent representing a home agent, to perform the signaling processing in the Mobile IP.
Further, the conventional router device 50 has a problem in that a network control function has to be restructured in the entire packet communications network, when each router device 50 comprises various network control functions depending on the packet communications network and the technique used in the packet communications (transports) changes.
In viewing of the foregoing, it is an object of the present invention to provide a packet communications system and a transfer device, which comprise an intelligent control mechanism as a packet communications network, allow packet communications (transports) performed by router devices (transfer devices) to perform various packet processing simply and quickly, and allow a network control function to be changed at low cost flexibly.
A first aspect of the present invention is summarized as a packet communications system comprising a network manager and a plurality of transfer devices. The network manager comprises an instructor configured to transmit instruction information to the plurality of transfer devices. The instruction information indicates a packet ID identifying a packet, and a control function executed on the packet. The transfer device comprises an executer configured to execute a predetermined control function on the packet, a first memory configured to store the packet ID associated with the executer of the control function executed on the packet, a manager configured to update the first memory in accordance with the instruction information received from the network manager, and an internal transfer configured to transfer the received packet to the executer associated with the packet in the first memory.
In the first aspect of the present invention, preferably, the first memory stores the packet ID associated with the executer and a parameter required to execute the control function, the executer comprises a second memory configured to store the packet ID associated with the parameter, the executer executes the control function on the received packet using the parameter associated with the packet in the second memory, and the manager transmits information for updating the second memory in accordance with the instruction information received from the network manager.
In the first aspect of the present invention, preferably, the transfer device comprises an interface configured to transmit and receive the packet via a packet communications network, the interface comprises a third memory configured to store the packet ID identifying the packet received at the interface associated with the executer of the control function executed on the packet, the manager transmits information for updating the third memory in accordance with the instruction information received from the network manager, and the internal transfer transfers the received packet to the executer associated with the packet in the third memory.
In the first aspect of the present invention, preferably, the third memory stores the packet ID associated with the executer and a routing ID, the interface comprises a routing ID adder configured to add the routing ID associated with the packet in the third memory to the received packet, and the internal transfer transfers the packet to the executer in accordance with the routing ID.
In the first aspect of the present invention, preferably, the executer comprises a router configured to route the packet to a predetermined interface after executing the control function on the packet.
In the first aspect of the present invention, preferably, the packet ID is address information included in the packet.
A second aspect of the present invention is summarized as a transfer device used in a packet communications system.
The transfer device comprises an instruction information receiver configured to receive, from a network manager, instruction information indicating a packet ID identifying a packet and a control function executed on the packet, an executer configured to execute a predetermined control function on the packet, a first memory configured to store the packet ID associated with the executer of the control function executed on the packet, a manager configured to update the first memory in accordance with the instruction information received from the network manager, and an internal transfer configured to transfer the received packet to the executer associated with the packet in the first memory.
In the second aspect of the present invention, preferably, the first memory stores the packet ID associated with the executer and a parameter required to execute the control function, the executer comprises a second memory configured to store the packet ID associated with the parameter, the executer executes the control function on the received packet using the parameter associated with the packet in the second memory, and the manager transmits information for updating the second memory in accordance with the instruction information received from the network manager.
In the second aspect of the present invention, preferably, the transfer device comprises an interface configured to transmit and receive the packet via a packet communications network, the interface comprises a third memory configured to store the packet ID identifying the packet received at the interface associated with the executer of the control function executed on the packet, the manager transmits information for updating the third memory in accordance with the instruction information received from the network manager, and the internal transfer transfers the received packet to the executer associated with the packet in the third memory.
In the second aspect of the present invention, preferably, the third memory stores the packet ID associated with the executer and a routing ID, the interface comprises a routing ID adder configured to add the routing ID associated with the packet in the third memory to the received packet, and the internal transfer transfers the packet to the executer in accordance with the routing ID.
In the second aspect of the present invention, preferably, the executer comprises a router configured to route the packet to a predetermined interface after executing the control function on the packet.
In the second aspect of the present invention, preferably, the packet ID is address information included in the packet.
(Configuration of a Packet Communications System According to an Embodiment of the Present Invention)
Referring to FIGS. 2 to 6, a configuration of a packet communications system according to an embodiment of the present invention will be described in detail below.
As shown in
The terminals 10A and 10B, each of which is connected to the router devices 501 to 507, have packet communications functions. The terminals 10A and 10B may connect to the router devices 501 to 507 via wiring circuits or wireless circuits.
The network manager 30 performs network control functions in the packet communications networks 1a and 1b such as a QoS (Quality of Service) control function, a security control function, a mobility control function which manages location information and routing information as a terminal moves, a filtering function, an account function, or a monitoring function.
As shown in
The function-selecting unit 31 selects which packet should be controlled with each control function or which control function should be executed on each packet in accordance with network control in the network manager 30.
The instructing unit 32 is an instructor configured to transmit instruction information to the plurality of router devices 501 to 507 (transfer devices). The instruction information indicates a packet ID identifying a packet and a control function executed on the packet via a common interface 2 with an interaction protocol.
The instructing unit 32 may transmit the instruction information to the plurality of router devices 501 to 507 via a dedicated interface (control signal network 2) set between the instructing unit 32 and the router devices 501 to 507. The instructing unit 32 may transmit the instruction information in the form of a packet to the plurality of router devices 501 to 507 via the packet communications network 1a and 1b.
As shown in
The circuit interface 51 is connected to the packet communications network 1, the function-mapping control unit 52, the routing protocol processor 55, and the packet switch 56. The circuit interface 51 is an interface configured to transmit and receive packets via the packet communications network 1.
As shown in
The packet receiver 51a, which is connected to the interaction protocol transfer unit 51b and the function-routing flag-adding unit 51c, receives packets via the packet communications network 1.
The packet receiver 51a judges whether or not the received packet is the instruction information instructing it to update the function-mapping table 53. If yes, the packet receiver 51a transfers the packet to the interaction protocol transfer unit 51b. The packet receiver 51a transfers the packet to the function-routing flag-adding unit 51c otherwise.
The interaction protocol transfer unit 51b, which is connected to the packet receiver 51a and the function-mapping control unit 52, transfers the packet (instruction information) from the packet receiver 51a to the function-mapping control unit 52.
The function-routing flag-adding unit 51c is connected to the packet receiver 51a, the function-mapping cache table 51e, and the packet switch interface 51f. The function-routing flag-adding unit 51c is a routing ID adder configured to add a routing ID (function-routing flag) associated with the packet in a third memory (the function-mapping cache table 51e) to the received packet. The function-routing flag-adding unit 51c transmits the packets including the routing ID to the packet switch interface 51f.
The function-routing flag-adding unit 51c adds to the received packet all the routing IDs in accordance with the order in which the control functions are executed, when the packet is associated with a plurality of routing IDs.
The cache information receiver 51d, which is connected to the function-mapping cache table 51e, receives information for updating the function-mapping cache table 51e from the function-mapping control unit 52, and transfers the information to the function-mapping cache table 51e.
The function-mapping cache table 51e, which is connected to the function-routing flag-adding unit 51c and the cache information receiver 51d, is a third memory configured to store a packet ID (terminal ID) identifying the packet received at the circuit interface 51 associated with a function unit 57 (function ID) of the control function executed on the packet, a routing ID, and a parameter required to execute the control function (various information element).
The terminal ID is address information indicating a source address or a destination address included in the packet. The terminal ID may be information other than the address information such as information identifying a packet flow and information indicating an application included in the packet (TCP/UDP port number, etc.).
The function ID indicates a control function included in the instruction information from the network manager 30. The routing ID identifies a function unit 571 to 57z which executes the control function. The function ID and the routing ID may be the same or different.
The various information element indicates a parameter required to execute the control function in the function unit 571 to 57z.
The function-mapping cache table 51e shown in
The function-mapping cache table 51e shown in
The function-mapping cache table 51e shown in
The function-mapping cache table 51e can store only records regarding the packets received at the circuit interface 51, or store the records regarding all packets. The function-mapping cache table 51e is the same as the function-mapping table 53 when storing the records regarding all packets.
The packet switch interface 51f, which is connected to the function-routing flag-adding unit 51c and the packet transmitter 51g, transmits the packets from the function-routing flag-adding unit 51c to the packet switch 56, and transmits the packets from the packet switch 56 to the packet transmitter 51g.
The packet transmitter 51g, which is connected to the packet switch interface 51f and the scheduler 51h, transmits the packets from the packet switch interface 51f to the packet communications network 1 in accordance with the instruction from the scheduler 51h.
The scheduler 51h, which is connected to the packet transmitter 51g, instructs the packet transmitter 51g to read the packets in accordance with the priority class.
The function-mapping control unit 52 is connected to the plurality of circuit interfaces 511 to 51n, the function-mapping table 53, and the plurality of function units 571 to 57z. The function-mapping control unit 52 is a manager configured to update the function-mapping table 53 (first memory) in accordance with the instruction information received from the network manager 30.
The function-mapping control unit 52 transmits information for updating the function-mapping cache table 51e to the circuit interfaces 511 to 51n, transmits information for updating the function-mapping cache table 57d to the function units 571 to 57z, when receiving the instruction information from the network manager 30.
The function-mapping control unit 52 can transmit the information regarding all records in the function-mapping cache table 51e or 57d, or transmit the information regarding the records added/changed in the function-mapping cache table 51e or 57d.
The function-mapping control unit 52 can transmit the information to the circuit interfaces 511 to 51n and the function units 571 to 57z directly or via the packet switch 56.
The function-mapping control unit 52 can transmit the information to the concerned circuit interfaces 511 to 51n and the concerned function units 571 to 57z, transmit the information to all the circuit interfaces 511 to 51n and all the function units 571 to 57z.
The function-mapping control unit 52 transmits an acknowledgement (ACK) for reporting the completion of the processing to the network manager 30 via the packet communications network 1 or the control signal network 2.
The function-mapping table 53, which is connected to the function-mapping control unit 52 and the packet switch 56, is a first memory configured to store a packet ID (terminal ID) associated with a function unit 571 to 57z of the control function executed on the packet (function ID) and a parameter required to execute the control function (various information element). As shown in
The routing processor 54, which is connected to the routing protocol processor 55 and the packet switch 56, is a router configured to route the packet to a predetermined circuit interface 51 via the packet switch 56 together with the routing protocol processor 55, after the function units 571 to 57z execute the control function on the packet.
The routing protocol processor 55 is connected to the circuit interfaces 511 to 51n, the routing processor 54, and the function units 571 to 57z. The routing protocol processor 55 manage a routing table in conformance with the routing protocol such as OSPF (Open Shortest Path First) and RIP (Routing Information Protocol).
The packet switch 56 is connected to the circuit interfaces 511 to 51n, the function-mapping control unit 52, the function-mapping table 53, the routing processor 54, and the function units 571 to 57z. The packet switch 56 is an internal transfer configured to transfer the received packet to the function unit (executer) 571 to 57z associated with the packet in the function-mapping table (first memory) 53.
The packet switch 56 can transfer the received packet to the function unit 571 to 57z associated with the packet, by referring to the function-mapping cache table 51e in the circuit interfaces 511 to 51n.
The packet switch 56 can transfer the packet to the function unit 571 to 57z in accordance with routing ID added to the packet.
The packet switch 56 transfers the packets routed by routing processor 54 or 57e to the predetermined circuit interface 511 to 51n.
Further, the packet switch 56 transfers, to the circuit interface 511 to 51n or the function unit 571 to 57z, information for updating the function-mapping cache table 51e or 57d transmitted from the function-mapping control unit 52.
The packet switch 56 is connected to the function units 571 to 57z via a common interface.
The function unit 571 to 57z is connected to the function-mapping control unit 52, the routing protocol processor 55, and the packet switch 56. The function unit 571 to 57z is an executer configured to execute the predetermined control function on the packet.
The function units 571 to 57z are general hardware devices, for example ASIC, which can execute the predetermined control function and are easy to replace. Each of the function unit 571 to 57z may execute a different control function, or some of the function units 571 to 57z may execute the same control function. The function units 571 to 57z may be configured to execute control functions which will be developed in the future, in addition to a QoS control function, a security control function, and mobility control function, etc.
The packet receiver 57a, which is connected to the packet processor 57b, receives the packet transmitted from the packet switch 56, and transmits the received packet to the packet processor 57b.
The packet processor 57b is connected to the packet receiver 57a, the function-routing flag-checking unit 57c, and the function-mapping cache table 57d. The packet processor 57b executes the predetermined control function by referring to the function-mapping cache table 57d. The packet processor 57b transmits, to the function-routing flag-checking unit 57c, the packet on which the predetermined control function is executed.
The function-routing flag-checking unit 57c is connected to the packet processor 57b, the routing processor 57e, the packet transmitter 57f. The function-routing flag-checking unit 57c deletes the routing ID included in the packet transmitted from the packet processor 57b. The function-routing flag-checking unit 57c judges whether or not the packet includes other routing ID. If yes, the function-routing flag-checking unit 57c transmits the packet to the packet transmitter 57f. The function-routing flag-checking unit 57c transmits the packet to the routing processor 57e otherwise.
The function-mapping cache table 57d, which is connected to the packet processor 57b, is a second memory configured to store the packet ID (terminal ID) associated with the parameter (various information element).
The routing processor 57e, which is connected to the function-routing flag-checking unit 57c and the packet transmitter 57f, is a router configured to route the packet transmitted from the function-routing flag-checking unit 57c, to the predetermined circuit interface 51 via the packet switch 56, together with the routing protocol processor 55.
The packet transmitter 57f, the function-routing flag-checking unit 57c and the routing processor 57e, transmits the packet transmitted from the function-routing flag-checking unit 57c or the routing processor 57e to the packet switch 56.
The network manager 30 and the router device 50 can be installed in a device together. In the embodiment, the router device 50 is used as a transfer device. However, the present invention is not limited to the above. Any devices which can transfer packets may be used as a transfer device.
(Operation of the Packet Communications System According to the Embodiment)
Next the operations of the packet communications system according to the embodiment will be described with reference to FIGS. 7 to 9.
As shown in
In step 602, the packet receiver 51a judges whether or not the packet conforms to the interaction protocol, that is, the packet is instruction information. If yes, the operation proceeds to step 603. The operation proceeds to step 604 otherwise.
In step 603, the interaction protocol transfer unit 51b the instruction information to the function-mapping control unit 52, so as to update the function-mapping table 53. Then, the operation finishes.
In step 604, the function-routing flag-adding unit 51c refers to the function-mapping cache table 51e. In step 605, the function-routing flag-adding unit 51c judges whether or not the function-mapping cache table 51e includes a record (entry) related to the received packet. If yes, the operation proceeds to step 606. The operation proceeds to step 607 otherwise.
In step 606, the function-routing flag-adding unit 51c adds to the received packet the routing ID associated with the packet. In step 607, the packet switch interface 51f transfers the packet transmitted from the function-routing flag-adding unit 51c to the packet switch 56.
As shown in
In step 703, the packet switch 56 transfers the received packet to the concerned function unit 571 to 57z using the routing ID.
In step 704, the packet switch 56 transfers the packet to the output circuit interface 51 in accordance with the result of the routing processing performed by the routing processor 54.
The packet switch 56 can transfer the packet to the function unit 571 to 57z using the routing ID associated with the packet by referring to the function-mapping table 53, when the routing ID is not added to the packet received from the circuit interface 51 in step 702.
As shown in
In step 803, the function-routing flag-checking unit 57c deletes the routing ID (function-routing flag) in the packet received from the packet processor 57b.
In step 804, the function-routing flag-checking unit 57c checks whether or not the other routing ID is added to the packet.
If yes, the function-routing flag-checking unit 57c transmits the packet to the packet transmitter 57f, and the packet transmitter 57f transmits the received packet to the packet switch 56.
Otherwise, the function-routing flag-checking unit 57c transmits the packet to the routing processor 57e, and the packet transmitter 57f transmits the packet routed by the routing processor 57e.
As shown in
In step 903, the function-mapping control unit 52 in the router device 50 updates the function-mapping table 53 in accordance with the instruction information which is received via the control signal network 2, or via the packet communications network 1 and the circuit interface 51.
In step 904, the function-mapping unit 52 transmits information for updating the function-mapping cache table 51e (cache information) to the circuit interfaces 511 to 51n, and transmits information for updating the function-mapping cache table 57d (cache information) to the function units 571 to 57z.
In step 905, the function-mapping cache tables 51e in the circuit interfaces 51 are updated in accordance with the information, and the function-mapping cache tables 57d in the function units 57 are also updated in accordance with the information.
In step 906, the acknowledgement (ACK) is transmitted from the function-mapping control unit 52 to the network manager 30 via the packet communications network 1 or the control signal network 2.
(The Functions and Effects of the Packet Communications System According to the Embodiment)
According to the packet communications system of this embodiment, the packet switch 56 (internal transfer) in the router device 50 (transfer device) can transfer the received packet to the function unit 57 (executer) associated with the packet in the function-mapping table 53 (first memory), and the function unit 57 (executer) can execute the predetermined control function on the packet, thus enabling various packet processing for various kinds of network control with combinations of the control functions executed by the plurality of function units 57.
According to the packet communications system of this embodiment, the function units 57 which are hardware devices executing general functions allow the internal configuration in the router devices 50 (transfer device) to be general, allow higher flexibility for adding/changing/deleting the network control functions, and allow high-speed IP packet processing and IP packet transfer at a low cost.
Then, the hardware devices executing the general functions required in the router devices 50 (transfer device) can be installed as plug-and-play devices into the router devices 50 (transfer device) via the common interface in the router devices 50 (transfer device), thus making it possible for the network operator such as the telecommunication company and the ISP (Internet Service Provider) to select only the required network control functions easily.
According to the packet communications system of this embodiment, the function-mapping control unit 52 (manager) can update the function-mapping table 53 (first memory) in accordance with the instruction information received from the network manager 30, and the packet switch 56 (internal transfer) can transfer the received packet to the function unit 57 (executer) associated with the packet in the function-mapping table 53 (first memory), thus enabling the construction of the packet communications network 1 independently of the various network controls. More specifically, various kinds of network control can be achieved in the network, other than an IP network such as the Internet at present without a change of the network manager.
According to the packet communications system of this embodiment, the function-mapping cache table 57d (second memory) can store the terminal ID (packet ID) associated with the various information element (parameter), and the function unit 57 (executer) can execute the control function using the various information element (parameter), thus making it possible for the function unit 57 (executer) to execute the control function which requires the parameter.
According to the packet communications system of this embodiment, the circuit interface 51 (interface) can comprise the function-mapping cache table 51e (third memory), and the packet switch 56 (internal transfer) can transfer the received packet to the function unit 57 (executer) associated with the packet in the function-mapping cache table 51e (third memory), thus enabling high-speed processing in the router device 50 (transfer device).
As described above, according to the present invention, the packet communications system and router device which are configured with an intelligent control mechanism as a packet communications network, allow packet communications (transports) performed by router devices (transfer devices) to perform various packet processing simply and quickly, and allow a network control function to be changed at low cost flexibly.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the invention in its broader aspects is not limited to the specific details and the representative embodiment shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
2002-055001 | Feb 2002 | JP | national |
This application is a divisional of U.S. Serial application Ser. No. 10/373,846 filed on Feb. 27, 2003, all of which claim priority to Japanese Patent Application No. 2002-055001 filed on Feb. 28, 2002. The contents of each of these documents are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 10373846 | Feb 2003 | US |
Child | 11842697 | Aug 2007 | US |