This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2016-030054, filed on Feb. 19, 2016, the entire contents of which are incorporated herein by reference.
The embodiments discussed herein are related to a switching apparatus and a packet processing system.
Recently, there is a packet processing system in which a virtual machine (VM) operates on a computer apparatus such as a server and the virtual machine executes a communication process such as routing for determining a transmission route of a packet.
Where such a packet processing system as described above is used, it is difficult to ensure the throughput performance. Therefore, a switching apparatus is used to distribute packets to a plurality of computer apparatus in each of which a virtual machine operates.
For example, a technology has been proposed which changes the NIC allocated to each virtual machine in response to the load to a computer apparatus using a switching apparatus such as an interconnect switch to reduce the transfer time period of a packet transmitted from the virtual machine (refer to, for example, Japanese Laid-open Patent Publication No. 2014-186411). It is to be noted that NIC is an abbreviation of network interface card.
Also a technology has been proposed which monitors, for each of virtual machines, the resource use rate of a computer apparatus, by which the virtual machines are operated, and adjusts resources to be allocated to the individual virtual machines to optimize the operation state of each of the virtual machines (refer to, for example, Japanese Laid-open Patent Publication No. 2008-293117). It is to be noted that the resources of a computer apparatus include a processing capacity of a processor, a storage capacity of a memory and so forth.
According to an aspect of the embodiment, a control apparatus includes a memory, and a processor coupled to the memory and the processor configured to: retain first packets in the memory, output the retained first packets to a processing apparatus including a packet processor, receive second packets processed by the packet processor from the processing apparatus, and control outputting of the retained first packets based on the outputted first packets and the received second packets.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
For example, if a computer apparatus such as a server that executes a communication process of a packet receives packets that exceed the processing capacity of the computer apparatus from a network through a switching apparatus, the computer apparatus outputs a stopping request to instruct the switching apparatus or the like to stop transmission of packets. On the other hand, if a virtual machine that executes a communication process and so forth of packets does not have a function for outputting a stopping request of packets, the virtual machine may receive packets exceeding the processing capacity of the virtual machine, resulting in overflow of packets and hence in packet loss.
In one aspect, it is an object in a switching apparatus and a packet processing system according to the present disclosure to control, even where a virtual machine does not have a function for requesting stopping of transmission of packets, the transfer amount of packets by a switching apparatus and suppress packet loss.
In the following, embodiments are described with reference to the drawings.
A packet processing system SYS depicted in
The packet processing apparatus 200 is a computer apparatus such as a server including an arithmetic processing apparatus such as a processor and a storage apparatus such as a hard disk apparatus. The packet processing apparatus 200 includes one or more packet processing units 50 that execute, for example, a communication process. Where the packet processing apparatus 200 includes a plurality of packet processing units 50, the plurality of packet processing units 50 may execute communication processes different from each other. The packet processing apparatus 200 causes the packet processing unit 50 to execute a communication process corresponding to an internet protocol (IP) packet received from the network NW through the switching apparatus 100. It is to be noted that a function of the packet processing unit 50 is implemented, for example, by a virtual machine executed by the packet processing apparatus 200.
For example, the communication process executed in the packet processing apparatus 200 includes a process of routing for selecting an optimum route from among a plurality of routes in the network NW for the received IP packet (hereinafter referred to also as packet). Further, the communication process executed in the packet processing apparatus 200 includes a process of security architecture for IP (IPsec) for encrypting data included in a packet. Further, the communication process executed in the packet processing apparatus 200 includes a process such as NAPT for converting an IP address and a TCP/UDP port number included in a packet into a different address and a different port number. It is to be noted that TCP is an abbreviation of transmission control protocol. Further, UDP is an abbreviation of user datagram protocol. Further, NAPT is an abbreviation of network address port transmission.
It is to be noted that the communication processes may be executed by one packet processing unit 50.
The packet processing apparatus 200 acquires the substance of a communication process executed for a received packet, for example, based on information of a virtual local area network (VLAN) included in the received packet. The packet processing apparatus 200 causes the packet processing unit 50 to execute a communication process in accordance with the substance of the acquired communication process for the received packet. The packet processing apparatus 200 outputs the packet after processing to the switching apparatus 100.
The switching apparatus 100 includes a switching unit 10, a retention unit 20, a calculation unit 30 and a control unit 40. It is to be noted that, where the switching apparatus 100 is coupled to a plurality of packet processing apparatus 200, the switching apparatus 100 includes a plurality of retention units 20 and a plurality of calculation units 30 individually corresponding to the plurality of packet processing apparatus 200.
The switching unit 10 is a layer 2 switch, a router or the like. The switching unit 10 switches, for example, the output destination of a packet received from the network NW to the packet processing apparatus 200. Then, the switching unit 10 outputs the received packet to the packet processing apparatus 200 of the switched output destination through the retention unit 20. Further, the switching unit 10 receives a packet after processing for which a communication process is executed by the packet processing unit 50 from the packet processing apparatus 200 and transmits the packet after processing to a given transfer destination on the network NW.
The retention unit 20 is a memory having a first-in-first-out function such as a queue. The retention unit 20 retains packets outputted from the switching unit 10 in order therein and outputs the packets in the retention order to the packet processing apparatus 200.
The calculation unit 30 calculates the number of packets whose communication process is being executed by the packet processing apparatus 200 (the number of such packets is hereinafter referred to also as process number) based on the number of packets outputted from the retention unit 20 to the packet processing apparatus 200 and the number of packets after processing received from the packet processing apparatus 200. For example, the calculation unit 30 calculates the difference between the number of packets outputted from the retention unit 20 to the packet processing apparatus 200 and the number of packets after processing received from the packet processing apparatus 200 as the process number of packets being executed by the packet processing apparatus 200. The calculation unit 30 is an example of a first calculation unit.
The control unit 40 is implemented by execution of a program stored in a storage unit such as a memory included in the switching apparatus 100 by a processor or the like included in the switching apparatus 100 and controls operation of the switching apparatus 100. The control unit 40 controls outputting of a packet from the retention unit 20 to the packet processing apparatus 200 based on the process number calculated by the calculation unit 30. For example, the control unit 40 decides whether or not the process number of packets is equal to or greater than a maximum number of packets processable in parallel by the packet processing apparatus 200. In the following description, the maximum number of packets processable by the packet processing apparatus 200 is referred to as credit number. If the process number is lower than the credit number, the control unit 40 issues an instruction to the retention unit 20 to output a packet to the packet processing apparatus 200. On the other hand, if the process number is equal to or greater than the credit number, the control unit 40 issues an instruction to the retention unit 20 to suppress outputting of a packet to the packet processing apparatus 200. In this manner, the control unit 40 controls outputting of a packet from the retention unit 20 to the packet processing apparatus 200 such that the number of packets for which a communication process is being executed by the packet processing apparatus 200 becomes equal to or lower than the credit number.
Therefore, in
Then, in
Then, in
As described above, in the embodiment depicted in
For example, the virtual machine (for example, the packet processing unit 50) and the number of packets are stored in an associated relationship with each other into the switching apparatus 100, and it is assumed that the number associated with the virtual machine indicates the processing capacity of the virtual machine.
A packet processing system SYS1 depicted in
Each of the servers 200a executes, for example, M virtual machines 50a (50a(1) to 50a(M)). The virtual machines 50a individually execute a program to execute programs for communication processes different from each other such as routing and IPsec. The server 200a acquires information indicative of the substance of a communication process to be executed for a received packet based on information of the VLAN or the like included in the received packet. The server 200a transfers the received packet to each of the plurality of virtual machines 50a based on the acquired substance of a communication process and causes the virtual machine 50a to execute the communication process such as routing or IPsec. The server 200a outputs the packet after processing to the switching apparatus 100a. The server 200a is an example of a processing apparatus, and the virtual machine 50a is an example of a packet processing unit.
The switching apparatus 100a includes a switch unit 11, N transfer units 60 (60(1) to 60(N)) and a control unit 40a.
The switch unit 11 is a layer 2 switch, a router or the like, and switches the transmission destination of the packet received from the network NW to one of the N servers 200a. Then, the switch unit 11 outputs the received packet to the server 200a of the switched transmission destination. Further, the switch unit 11 receives a packet after processing for which a communication process is executed from each server 200a through each transfer unit 60, and transmits the received packet to a given transfer destination on the network NW. The switch unit 11 is an example of a switching unit.
The transfer unit 60(1) includes a retention unit 20 and a counter unit 31. It is to be noted that each of the transfer units 60(2) to 60(N) includes the same or similar elements to those of the transfer unit 60(1) depicted in
The counter unit 31 is an up-down counter or the like, and increases the number of counts (hereinafter referred to as count number) by one every time a packet is outputted from the retention unit 20 to the server 200a(1). Further, the counter unit 31 decreases the count number by one every time a packet after processing for which a communication process is executed is received from the server 200a(1). For example, the count number indicated by the counter unit 31 indicates the number of packets for which a communication process is being executed in the server 200a(1). The counter unit 31 is an example of a calculation unit, and the count number is an example of a process number.
The control unit 40a is implemented, for example, by execution of a program stored in a storage unit such as a memory included in the switching apparatus 100a by a processor or the like included in the switching apparatus 100a, and controls operation of the switching apparatus 100a. Similarly to the control unit 40 depicted in
For example, where the count number in the counter unit 31 of the transfer unit 60(1) is smaller than the credit number, the control unit 40a issues an instruction to the retention unit 20 of the transfer unit 60(1) to output a packet to the server 200a(1). On the other hand, where the count number in the counter unit 31 of the transfer unit 60(1) is equal to or greater than the credit number, the control unit 40a issues an instruction to the retention unit 20 of the transfer unit 60(1) to suppress outputting of a packet to the server 200a(1). It is to be noted that, also for the transfer units 60(2) to 60(N), the control unit 40a executes control same as or similar to that for the transfer unit 60(1).
It is to be noted that the packet processing system SYS1 is not limited to the example depicted in
It is to be noted that the process illustrated in
At step S10, the control unit 40a decides whether or not the transfer unit 60(1) receives a packet from the switch unit 11. If a packet is received, the processing of the switching apparatus 100a advances to step S11. On the other hand, if a packet is not received, the processing of the switching apparatus 100a advances to step S12.
At step S11, the retention unit 20 successively retains the packets received at step S10. After the process at step S11 is executed, the processing of the switching apparatus 100a advances to step S12.
At step S12, the control unit 40a decides whether or not a packet is retained in the retention unit 20 of the transfer unit 60(1). If a packet is retained in the retention unit 20 of the transfer unit 60(1), the processing of the switching apparatus 100a advances to step S13. On the other hand, if a packet is not retained in the retention unit 20 of the transfer unit 60(1), the processing of the switching apparatus 100a advances to step S16.
At step S13, the control unit 40a decides whether or not the count number of the counter unit 31 of the transfer unit 60(1) is equal to or greater than the credit number. If the count number is smaller than the credit number, the processing of the switching apparatus 100a advances to step S14. On the other hand, if the count number is equal to or greater than the credit number, the processing of the switching apparatus 100a advances to step S16.
At step S14, the control unit 40a outputs an instruction to the retention unit 20 of the transfer unit 60(1) to output a packet retained at the top of the retention unit 20 to the server 200a(1). Then, the processing of the switching apparatus 100a advances to step S15. Here, the packet retained at the top of the retention unit 20 is a packet received oldest from among packets retained in the retention unit 20.
At step S15, the counter unit 31 of the transfer unit 60(1) increases the count number by one based on outputting of a packet from the retention unit 20 to the server 200a(1). After the process at step S15 is executed, the processing of the switching apparatus 100a advances to step S16.
At step S16, the counter unit 31 of the transfer unit 60(1) decides whether or not a packet after processing is received from the server 200a(1). If a packet after processing is received, the processing of the switching apparatus 100a advances to step S17. On the other hand, if a packet after processing is not received, the processing of the switching apparatus 100a returns to step S10.
At step S17, the counter unit 31 of the transfer unit 60(1) decreases the count number by one. After the process at step S17 is executed, the switching apparatus 100a ends the processing.
Then, the switching apparatus 100a repetitively executes the processes from step S10 to step S17. It is to be noted that the processes from step S10 to step S15 and the processes at steps S16 and S17 may be executed in parallel to each other.
As described above, in the embodiment depicted in
A packet processing system SYS2 depicted in
The switching apparatus 100b includes a switch unit 11, N transfer units 60a (60a(1) to 60a(N)), a control unit 40b and a storage unit 70.
The transfer unit 60a(1) includes an identification unit 15, a demultiplexer (DEMUX) 21, K retention units 20a (20a(1) to 20a(K)) and a multiplexer (MUX) 22. Further, the transfer unit 60a(1) includes a DEMUX 35 and K counter units 31a (31a(1) to 31a(K)). It is to be noted that each of the transfer units 60a(2) to 60a(N) includes elements same as or similar to those of the transfer unit 60a(1) depicted in
The identification unit 15 acquires, for example, information of a VLAN identifier (VID) included in the VLAN tag header added to a packet based on a communication standard such as IEEE802.1p. It is to be noted that IEEE is an abbreviation of The Institute of Electrical and Electronics Engineers, Inc. The identification unit 15 identifies the substance of a communication process executed in the server 200a(1) based on the acquired information of a VID or the like and a process table PT stored in the storage unit 70. Further, the identification unit 15 adds identification information indicative of the identified substance of the communication process to a packet and outputs the packet to which the identification information is added to the DEMUX 21. The substance of operation of the identification unit 15, the process table PT and the communication process is described with reference to
The DEMUX 21 outputs a received packet to one of the retention units 20a based on the identification information added to the packet. For example, the DEMUX 21 outputs the packet to the retention unit 20a for each kind of identification information. For example, the DEMUX 21 outputs a packet for which a same or similar communication process is executed in the server 200a(1) to the same retention unit 20a. For example, the retention unit 20a is provided for each kind of communication process executed in the server 200a(1).
Each of the retention units 20a is a memory having a first-in-first-out function such as a queue. Each retention unit 20a successively retains packets received from the DEMUX 21. Each retention unit 20a outputs the packets in the retention order to the server 200a(1).
The MUX 22 outputs packets outputted from each retention unit 20a to the server 200a(1).
The DEMUX 35 receives a packet after processing from the server 200a(1). The DEMUX 35 outputs information indicative of reception of a packet to one of the counter units 31a based on identification information included in the received packet. It is to be noted that the identification information is added to a packet by the identification unit 15.
The counter unit 31a is provided corresponding to each of the retention units 20a. Each of the counter units 31a is an up-down counter or the like similarly to the counter unit 31 depicted in
The control unit 40b is implemented, for example, by execution of a program stored in the storage unit 70 by a processor or the like included in the switching apparatus 100b, and controls operation of the switching apparatus 100b. The control unit 40b controls outputting of a packet from each retention unit 20a to the server 200a based on the count number counted by the corresponding counter unit 31a in each transfer unit 60a. For example, if the count number in the counter unit 31a(1) of the transfer unit 60a(1) is smaller than the credit number, the control unit 40b issues an instruction to the retention unit 20a(1) of the transfer unit 60a(1) to output a packet to the server 200a(1). On the other hand, if the count number in the counter unit 31a(1) of the transfer unit 60a(1) is equal to or greater than the credit number, the control unit 40b issues an instruction to the retention unit 20a(1) of the transfer unit 60a(1) to suppress outputting of a packet to the server 200a(1). For example, outputting control on each retention unit 20a by the control unit 40b is similar to that in the example of operation by the control unit 40 depicted in
It is to be noted that, also for the retention units 20a(2) to 20a(K) of the transfer unit 60a(1), the control unit 40b executes control same as or similar to that for the retention unit 20a(1) based on comparison between the count number of each of the counter unit 31a(2) to 31a(K) and the credit number. Further, also for the transfer units 60a(2) to 60a(N), the control unit 40b executes control same as or similar to that for the transfer unit 60a(1).
The storage unit 70 is a memory such as a random access memory (RAM) and includes a storage area in which a program executed by the control unit 40b, a process table PT and so forth are stored. An example of the process table PT is depicted in
It is to be noted that the packet processing system SYS2 is not limited to the example depicted in
In the chain area CA, information indicative of the substance of a communication process executed for each packet having a VID (identification number) stored in the identification area IA (such information is hereafter referred to also as chain) is stored. For example, where a chain executed for a packet whose identification number is “1” indicates a communication process of routing, information indicating routing is stored in the chain area CA corresponding to the identification number (VID) of “1.” Where a chain executed for a packet whose identification number is “2” indicates a communication process of IPsec, information indicating IPsec is stored in the chain area CA of the identification number (VID) of “2.” Further, where a chain executed for a packet whose identification number is “3” indicates communication processes of routing and IPsec, information indicating routing and IPsec is stored in the chain area CA corresponding to the identification number (VID) of “3.”
In the group area GA, information indicative of a group in which chains are grouped based on a common communication process from among the communication processes indicated by the chains stored in the chain area CA is stored. For example, in the process table PT depicted in
It is to be noted that, in the process table PT depicted in
It is to be noted that, before the switching apparatus 100b executes transmission and reception operation of a packet, the process table PT is stored in advance in the storage unit 70 by the packet processing system SYS2 or a monitoring apparatus such as a computer apparatus coupled to the network NW.
The identification unit 15 depicted in
The DEMUX 21 depicted in
On the other hand, the DEMUX 35 outputs, every time a packet after processing is received from the server 200a(1), information indicative of reception of a packet to one of the counter units 31a based on the identification information included in the packet. For example, if the identification information included in the received packet after processing indicates the chain group “1,” the DEMUX 35 outputs information indicative of reception of a packet to the counter unit 31a(1). Further, if the identification information included in the received packet after processing indicates the chain group “2,” the DEMUX 35 outputs information indicative of reception of a packet to the counter unit 31a(2). Each of the counter units 31a decreases the count number by one every time the information indicative of reception of a packet is received from the DEMUX 35. For example, each of the counter units 31a counts the number of packets for which a communication process is executed in the server 200a(1) for each of chain groups. It is to be noted that the processing load where the server 200a(1) executes a communication process of a packet differs in accordance with the chain group (the substance of the communication process). Therefore, each counter unit 31a counts the process number for each chain group, and the control unit 40b controls outputting of a packet to the server 200a(1) for each retention unit 20a based on the process number of each counter unit 31a and the credit number of each chain group. For example, as the control unit 40b controls outputting of a packet to the server 200a(1) for each chain group, the packet processing system SYS2 may effectively process packets in comparison with a case in which one counter unit 31 depicted in
It is to be noted that the process illustrated in
If it is decided at step S10 that a packet is received, the switching apparatus 100b advances the processing to step S100, and if it is decided that a packet is not received, the processing advances to step S120.
At step S100, the identification unit 15 identifies the chain group of the packet received at step S10 based on the VID of the VLAN tag header added to the packet and the process table PT depicted in
At step S110, each of the retention units 20a receives packets sorted by the DEMUX 21 depending on the chain group identified at step S100 and retains the received packets in order. After the process at step S110 is executed, the processing of the switching apparatus 100b advances to step S120.
At step S120, the control unit 40b decides whether or not a packet is retained in each of the retention units 20a (for example, for each chain group). Then, the processing of the switching apparatus 100b for the retention unit 20a that retains a packet advances to step S130. On the other hand, the processing of the switching apparatus 100b for the retention unit 20a that does not retain a packet advances to step S16.
At step S130, the control unit 40b decides whether or not the count number of the counter unit 31a of the chain group corresponding to the retention unit 20a with regard to which it is decided at step S120 that a packet is retained is equal to or greater than the credit number. If the count number is smaller than the credit number, the processing of the switching apparatus 100b advances to step S140. On the other hand, if the count number is equal to or greater than the credit number, the processing of the switching apparatus 100b advances to step S16.
At step S140, the control unit 40b issues an instruction to the retention unit 20a of a chain group, with regard to which it is decided at step S130 that the count number of the counter unit 31a is smaller than the credit number, to output a packet to the server 200a(1). After the process at step S140 is executed, the processing of the switching apparatus 100b advances to step S150.
At step S150, the counter unit 31a corresponding to the chain group of the packet outputted at step S140 increases the count number by one. After the process at step S150 is executed, the switching apparatus 100b executes processes at steps S16 and S160. It is to be noted that, if the counter unit 31a receives a packet after processing from the server 200a(1) at step S16 depicted in
At step S160, the counter unit 31a corresponding to the chain group added to the packet after processing received at step S16 decreases the count number by one. After the process at step S160 is executed, the switching apparatus 100b ends the packet process.
Then, the switching apparatus 100b repetitively executes the processes at steps S10, S100 to S150, S16 and S160. It is to be noted that the processes at steps S10 and S100 to S150 and the processes at steps S16 and S160 may be executed in parallel.
As described above, in the embodiment depicted in
Further, the process load to the server 200a differs among different chain groups. Therefore, the control unit 40b controls outputting of a packet to the server 200a from each retention unit 20a based on the process number of each counter unit 31a and the credit number for each chain group. Consequently, the switching apparatus 100b may transfer packets more efficiently than where the single counter unit 31 depicted in
A packet processing system SYS3 depicted in
The switching apparatus 100c includes a switch unit 11, N transfer units 60b (60b(1) to 60b(N)), a control unit 40c and a storage unit 70.
The transfer unit 60b(1) includes an identification unit 15a, a retention unit 20, an interface (IF) unit 25, a counter unit 31, a first measurement unit C1, a second measurement unit C2 and a threshold value calculation unit C3. It is to be noted that each of the transfer units 60b(2) to 60b(N) includes the same or similar elements to those of the transfer unit 60b(1) depicted in
The identification unit 15a acquires a VID (identification number) added to a received packet similarly to the identification unit 15 depicted in
Further, the identification unit 15a adds information such as a serial number for identifying each packet to the packet. Then, the identification unit 15a outputs the packet to which the chain ID and the serial number are added to the retention unit 20.
The IF unit 25 is an input/output (I/O) interface or the like, and outputs a packet received from the retention unit 20 to the server 200a(1) and outputs a packet after processing received from the server 200a(1) to the switch unit 11. Further, for example, when a packet received from the retention unit 20 is outputted to the server 200a(1), the IF unit 25 outputs the chain ID and the serial number added to the packet to the first measurement unit C1 and the second measurement unit C2. Further, the IF unit 25 refers to information indicative of time outputted from a clock circuit included in the switching apparatus 100c or the like and acquires time information such as a timestamp indicative of transmission time at which the packet received from the retention unit 20 is outputted to the server 200a(1). The IF unit 25 outputs the acquired time information to the first measurement unit C1 and the second measurement unit C2.
Further, the IF unit 25 refers, for example, to the information indicative of the time outputted from the clock circuit of the switching apparatus 100c or the like and acquires time information such as a timestamp indicative of reception time when the IF unit 25 receives a packet after processing from the server 200a(1). The IF unit 25 outputs the time information at which the packet after processing is received and the chain ID and the serial number added to the packet after processing to the first measurement unit C1.
The first measurement unit C1 measures, for each chain ID (for example, for the substance of each communication process), a process time period spent on a communication process of a packet in the server 200a(1). For example, the first measurement unit C1 measures the process time period from the difference between the timestamp of the reception time and the timestamp of the transmission time of packets to which the same serial number is added. The first measurement unit C1 outputs the measured process time period in an associated relationship with the chain ID of the packet to the threshold value calculation unit C3.
The second measurement unit C2 measures, when the count number of the counter unit 31 is equal to the credit number, the period of time elapsed after the time at which the retention unit 20 outputted a packet last. For example, the second measurement unit C2 acquires from the IF unit 25 the chain ID, the serial number and the timestamp of the transmission time of the packet outputted last from the retention unit 20. Then, the second measurement unit C2 measures, based on the information indicative of the time outputted from the clock circuit of the switching apparatus 100c and the timestamp of the transmission time acquired from the IF unit 25, the elapsed time period from the time at which the retention unit 20 outputted a packet last. The second measurement unit C2 outputs the measured elapsed time period in an associated relationship with the chain ID of the packet to the threshold value calculation unit C3.
The threshold value calculation unit C3 calculates, using the process time period for each chain ID (substance of the communication process) measured by the first measurement unit C1, a threshold value for a period of time in which it is estimated from the elapsed time period measured by the second measurement unit C2 that, between each adjacent chain IDs, processing of one of the chain IDs ends in the server 200a. Operation of the threshold value calculation unit C3 is described with reference to
The control unit 40c is implemented, for example, by a processor or the like included in the switching apparatus 100c executing a control program stored in the storage unit 70 and controls operation of the switching apparatus 100c. Then, similarly to the control unit 40a depicted in
However, even if the count number of the counter unit 31 is equal to or greater than the credit number, if a given condition (hereinafter referred to also as credit excess condition) is satisfied, the control unit 40c causes the retention unit 20 of the transfer unit 60b(1) to output a packet to the server 200a(1). The credit excess condition and operation of the control unit 40c are described with reference to
It is to be noted that, also for the transfer units 60b(2) to 60b(N), the control unit 40c executes control same as or similar to that for the transfer unit 60b(1).
It is to be noted that the credit number may have values different from each other among the transfer units 60b.
As illustrated in
Further, since the process time period of the communication process that includes only routing of a packet whose chain ID is “1” is included in the distribution PC1, the communication process including only routing is completed before a point of time t13 spaced to the side at which the process time period is longer from the distribution PC1. Therefore, when a packet whose chain ID is “3” is processed successively for routing and IPsec, it is estimated that the communication process of routing from within the communication process for a packet whose chain ID is “3” ends before the time t13. It is to be noted that the time t13 is, for example, a point of time at an average value or the like of the process time periods t1 and t3.
In
Meanwhile, since the packet Pa1 is a packet outputted last from the retention unit 20, the second measurement unit C2 of the transfer unit 60b(1) starts measurement of the elapsed time period. Further, since the chain ID of the packet Pa1 is “3,” the server 200a(1) transfers the packet Pa1 to the virtual machine 50a(1) that executes a communication process of routing, and the virtual machine 50a(1) starts a communication process of routing for the packet Pa1.
Then, in
However, since the packet Pa1 whose chain ID is “3” is transferred to the virtual machine 50a(2) before the elapsed time period of the second measurement unit C2 becomes equal to a time period at time t13, the virtual machine 50a(1) waits until it receives the packet Pa2. For example, the server 200a may execute at least a communication process of routing or a communication process of a process load equivalent to that of the communication process of routing within the range of the processing capacity of the server 200a.
Therefore, as illustrated in
It is to be noted that the counter unit 31 of the transfer unit 60b(1) increases the process number by one to count “4.”
On the other hand, though not illustrated in
For example, the condition that the elapsed time period of the second measurement unit C2 is equal to or longer than the time period at time t13 and the substance of the communication process indicated by the chain ID of the next packet is lighter in process load than the substance of the communication process of the chain ID of the packet outputted last from the retention unit 20 is an example of the credit excess condition.
The threshold value calculation unit C3 calculates, using the process time period for each of the chain IDs measured by the first measurement unit C1, a period of time (process threshold value such as the time period at time t13) in which it is estimated from the elapsed time period of the second measurement unit C2 that, between each adjacent chain IDs, processing of one of the chain IDs ends in the server 200a.
It is to be noted that it is sometimes difficult for the threshold value calculation unit C3 to calculate a process threshold value between each adjacent chain IDs, for example, using the distributions PC1 and PC3 of the process time periods illustrated in
It is to be noted that the process of the threshold value calculation unit C3 is executed while the switching apparatus 100c operates, and the threshold value calculation unit C3 may update the process threshold value between each adjacent chain IDs. Further, when a new virtual machine 50a (for example, a new communication process different from a communication process being executed) is executed in the server 200a(1), the threshold value calculation unit C3 may calculate a process threshold value with regard to the new chain ID. Alternatively, the threshold value calculation unit C3 may update the process threshold value between each adjacent chain IDs at given intervals of time based on time information outputted from the clock circuit of the switching apparatus 100c.
It is to be noted that the packet processing system SYS3 is not limited to the example depicted in
It is to be noted that the process illustrated in
The switching apparatus 100c executes a process at step S200 after it executes the process at step S10.
At step S200, the identification unit 15a identifies, based on the VID of the VLAN tag header added to the packet received at step S10 and the process table PT illustrated in
At step S210, the control unit 40c decides whether or not the count number of the counter unit 31 of the transfer unit 60b(1) is equal to or greater than the credit number. If the count number is smaller than the credit number, the processing of the switching apparatus 100c advances to step S14. On the other hand, if the count number is equal to or greater than the credit number, the second measurement unit C2 starts measurement of the elapsed time period, and the processing of the switching apparatus 100c advances to step S250.
After the switching apparatus 100c executes the process at step S14, it successively executes processes at steps S15, S16 and S220.
At step S220, the first measurement unit C1 measures, for each chain ID, the process time period spent on a communication process of the packet in the server 200a(1). For example, the first measurement unit C1 acquires, the chain ID, serial number, timestamp of the transmission time, timestamp of the reception time and so forth of the packets from the IF unit 25. Then, the first measurement unit C1 measures the process time period from the difference between the timestamp of the reception time of the packet after processing and the timestamp of the transmission time of the packet outputted to the server 200a(1) to which packet the same serial number as the serial number of the packet after processing mentioned just above is added. The first measurement unit C1 outputs the measured process time period in an associated relationship with the chain ID of the packet to the threshold value calculation unit C3. After the process at step S220 is executed, the processing of the switching apparatus 100c advances to step S230.
At step S230, the threshold value calculation unit C3 calculates, from the process time period for each chain ID measured at step S220, a period of time (process threshold value) in which it is estimated from the elapsed time period of the second measurement unit C2 that, between each adjacent chain IDs, processing of one of the chain IDs ends in the server 200a(1). For example, the threshold value calculation unit C3 calculates an average value of the time periods of peaks in the distributions of the process time period between two chain IDs measured by the first measurement unit C1 as a process threshold value between the two chain IDs. After the process at step S230 is executed, the processing of the switching apparatus 100c advances to step S240.
At step S240, the control unit 40c sets the process threshold value between each adjacent chain IDs calculated at step S230 to the transfer unit 60b(1). For example, the control unit 40c stores the calculated process threshold values between each adjacent chain IDs in an associated relationship with the transfer unit 60(1) into the storage unit 70 or the like. After the process at step S240 is executed, the processing of the switching apparatus 100c advances to step S17.
On the other hand, at step S250, the control unit 40c decides whether or not the process threshold value between the chain ID of the packet outputted last from the retention unit 20 and the chain ID of the packet to be outputted subsequently from the retention unit 20 is set in the transfer unit 60b(1). If the process threshold value is set in the transfer unit 60b(1), the processing of the switching apparatus 100c advances to step S260. On the other hand, if the process threshold value is not set in the transfer unit 60b(1), the processing of the switching apparatus 100c advances to step S16.
At step S260, the control unit 40c decides whether or not the elapsed time period of the packet outputted last from the retention unit 20 is longer than the process threshold value. If the elapsed time period is longer than the process threshold value, the processing of the switching apparatus 100c advances to step S270. On the other hand, if the elapsed time period is equal to or shorter than the process threshold value, the processing of the switching apparatus 100c advances to step S16.
At step S270, the control unit 40c decides, based on the process time periods of the individual chain IDs measured at step S220, whether or not the load of the communication process of the chain ID of the packet to be outputted next from the retention unit 20 is lighter than the load of the communication process of the chain ID of the packet outputted last. For example, the control unit 40c decides whether or not the process time period regarding the chain ID of the packet to be outputted next from the retention unit 20 is shorter than the communication time period regarding the chain ID of the packet outputted last from the retention unit 20. Then, if the load of the communication process of the packet to be outputted next from the retention unit 20 is lighter than the load of the communication process of the packet outputted last, the processing of the switching apparatus 100c advances to step S280. On the other hand, if the load of the communication process of the packet to be outputted next from the retention unit 20 is equal to or heavier than the load of the communication process of the packet outputted last, the processing of the switching apparatus 100c advances to step S16.
At step S280, the control unit 40c causes the retention unit 20 of the transfer unit 60b(1) to output the packet retained at the top in the retention unit 20 to the server 200a(1). After the process at step S280 is executed, the processing of the switching apparatus 100c advances to step S290.
At step S290, the counter unit 31 of the transfer unit 60b(1) increases the count number by one. After the process at step S290 is executed, the processing of the switching apparatus 100c advances to step S16.
Then, the switching apparatus 100c repetitively executes the process illustrated in
As described above, in the embodiment depicted in
Further, when the credit excess condition is satisfied, the control unit 40c causes the retention unit 20 to output a next packet irrespective of the process number. It is to be noted that the credit excess condition is a condition that the communication process for a packet to be outputted next from the retention unit 20 is lighter in load than the communication process for a packet outputted last and besides the elapsed time period is longer than the process threshold value. Consequently, even when the server 200a receives packets the number of which exceeds the credit number, the packet processing efficiency may be improved by distributing the received packets to the virtual machines 50a depending on the chain ID (substance of the communication process).
A packet processing system SYS4 depicted in
The switching apparatus 100d includes a switch unit 11, N transfer units 60c (60c(1) to 60c(N)), a control unit 40d and a storage unit 70.
The transfer unit 60c(1) includes an identification unit 15b, a DEMUX 21, K retention units 20a, a MUX 22, an IF unit 25, a DEMUX 35, K counter units 31a, a first measurement unit C1, a second measurement unit C2 and a threshold value calculation unit C3. It is to be noted that each of the transfer units 60c(2) to 60c(N) includes elements same as or similar to those of the transfer unit 60c(1) depicted in
The identification unit 15b acquires a VID included in the VLAN tag header added to a received packet similarly, for example, to the identification unit 15 depicted in
Further, the identification unit 15b adds a serial number for identifying each packet to the packet similarly to the identification unit 15a depicted in
The control unit 40d is implemented, for example, by execution of a program stored in the storage unit 70 by a processor or the like included in the switching apparatus 100d, and controls operation of the switching apparatus 100d. Further, the control unit 40d controls outputting of a packet from each retention unit 20a in each transfer unit 60c to the server 200a based on the count number counted by each counter unit 31a similarly to the control unit 40b depicted in
Further, the control unit 40d causes the retention unit 20a to output a packet to the server 200a when a credit excess condition is satisfied even if the count number of the counter unit 31a(1) is equal to or greater than the credit number similarly to the control unit 40c depicted in
It is to be noted that, also for the transfer units 60c(2) to 60c(N), the control unit 40d executes control same as or similar to that for the transfer unit 60c(1).
It is to be noted that the packet processing system SYS4 is not limited to the example depicted in
The switching process in the switching apparatus 100d depicted in
Further, at step S210, the control unit 40d decides whether or not the count number of the counter unit 31a of the chain group with regard to which it is decided at step S11 that the retention unit 20a retains a packet is equal to or greater than the credit number. If the count number is smaller than the credit number, the processing of the switching apparatus 100d advances to step S14. On the other hand, if the count number is equal to or greater than the credit number, the processing of the switching apparatus 100d advances to step S250.
At step S260, the control unit 40d decides whether or not the elapsed time period of a packet outputted last from the retention unit 20a of the chain group with regard to which it is decided at step S210 that the count number is equal to or greater than the credit number is longer than the process threshold value. If the elapsed time period is longer than the process threshold value, the processing of the switching apparatus 100d advances to step S270. On the other hand, if the elapsed time period is equal to or shorter than the process threshold value, the processing of the switching apparatus 100d advances to step S16.
Further, at step S270, the control unit 40d decides whether or not the load of the communication process of a packet to be outputted next from the retention unit 20a of the chain group with regard to which it is decided at step S260 that the elapsed time period is longer than the process threshold value is lighter than the load of the communication process of the packet outputted last. If the load of the communication process of the packet to be outputted next is lighter, the processing of the switching apparatus 100d advances to step S280. On the other hand, if the load of the communication process of the packet to be outputted next is equal to or heavier than the load of the communication process of the packet outputted last, the processing of the switching apparatus 100d advances to step S16.
Further, at step S280, the control unit 40d causes the retention unit 20a of the chain group, with regard to which it is decided at step S270 that the load of the communication process of a packet to be outputted next is lighter, to output the packet retained at the top of the retention unit 20a to the server 200a(1). After the process at step S280 is executed, the processing of the switching apparatus 100d advances to step S290.
Then, the switching apparatus 100d repetitively executes the process illustrated in
As described above, in the embodiment depicted in
Further, since the process load in the server 200a differs among different chain groups, the control unit 40d controls outputting of a packet from each retention unit 20a to the server 200a based on the process number of each counter unit 31a and the credit number of each chain group. Consequently, the switching apparatus 100d may transfer a packet more efficiently than where the single counter unit 31 depicted in
Further, where the credit excess condition is satisfied, the control unit 40d causes the retention unit 20a to output a next packet irrespective of the process number. It is to be noted that the credit excess condition is a condition that the communication process for a packet to be outputted next from the retention unit 20 is lighter in load than the communication process for a packet outputted last and besides the elapsed time period is longer than the process threshold value. Consequently, even when the server 200a receives packets the number of which exceeds the credit number, the packet processing efficiency may be improved by distributing the received packets to the virtual machines 50a depending on the chain ID (substance of the communication process).
A packet processing system SYS5 depicted in
The switching apparatus 100e includes a switch unit 11, N transfer units 60d (60d(1) to 60d(N)), a control unit 40e and a storage unit 70.
The transfer unit 60d(1) includes an identification unit 15a, a retention unit 20, an IF unit 25, a packet generation unit 27, a counter unit 31, a first measurement unit C1, a second measurement unit C2 and a threshold value calculation unit C3. For example, the transfer unit 60d is configured by adding the packet generation unit 27 to the transfer unit 60b depicted in
The packet generation unit 27 operates in the transfer unit 60d(1) and generates a pseudo packet for causing the server 200a(1) to artificially execute a process for each chain ID (substance of the communication process). The pseudo packet is a dummy packet used by the first measurement unit C1 to measure the process time period for each chain ID.
The control unit 40e is implemented, for example, by execution of a program stored in the storage unit 70 by a processor or the like included in the switching apparatus 100e and controls operation of the switching apparatus 100e. Then, the control unit 40e controls outputting of a packet to the server 200a from the retention unit 20 in each transfer unit 60d based on the count number counted by the counter unit 31 similarly to the control unit 40c depicted in
Further, even if the count number of the counter unit 31 is equal to or greater than the credit number, if a given condition is satisfied, the control unit 40e causes the retention unit 20 of the transfer unit 60d to output a packet to the server 200a similarly to the control unit 40c depicted in
Furthermore, for example, before the packet processing system SYS5 executes a communication process for a packet to be transferred to or from the network NW, the control unit 40e outputs an instruction to the packet generation unit 27 of each transfer unit 60d to generate a pseudo packet of each chain ID. Then, the control unit 40e outputs an instruction to the packet generation unit 27 to output the generated pseudo packet of each chain ID to the server 200a. The first measurement unit C1 of each transfer unit 60d measures the process time period for each chain ID. The threshold value calculation unit C3 of each transfer unit 60d calculates a process threshold value (for example, the time period at time t13 depicted in
It is to be noted that, even when the packet processing system SYS5 is executing a communication process for a packet to be transmitted to or from the network NW, the control unit 40e may cause the packet generation unit 27 to generate a pseudo packet and the threshold value calculation unit C3 may update the process threshold value between each adjacent chain IDs. For example, in the packet processing system SYS5, when the reception number of packets of a given chain ID from the network NW is smaller than the reception number of packets of the other chain IDs, it is sometimes difficult for the threshold value calculation unit C3 to update the process threshold value for the given chain ID. In this case, the control unit 40e may cause, for example, the packet generation unit 27 to generate a pseudo packet of the given chain ID whose reception number is small, and the threshold value calculation unit C3 may update the process threshold value of the given chain ID using a generated packet signal.
It is to be noted that the process illustrated in
Further, the process illustrated in
At step S400, the packet generation unit 27 generates a pseudo packet for each chain ID under the control of the control unit 40e. After the process at step S400 is executed, the processing of the switching apparatus 100e advances to step S410.
At step S410, the packet generation unit 27 successively outputs pseudo packets of the chain IDs generated at step S400 to the server 200a(1). After the process at step S410 is executed, the processing of the switching apparatus 100e advances to step S420.
At step S420, the first measurement unit C1 measures, for each chain ID, a process time period of a communication process in the server 200a(1) for the pseudo packet outputted at step S410 in a same or similar manner as the process at step S220 illustrated in
At step S430, the control unit 40e decides whether or not the number of times of measurement of the process time period for each chain ID by the first measurement unit C1 at step S420 is equal to or greater than a given number of times. If the number of times of measurement of the process time period for each chain ID is smaller than the given number of times, the processing of the switching apparatus 100e advances to step S400. On the other hand, if the number of times of measurement of the process time period for each chain ID is equal to or greater than the given number of times, the processing of the switching apparatus 100e advances to step S440. The given number of times may be once and is preferably determined in response to the magnitude of fluctuations in the process time period in each virtual machine 50a or the like.
At step S440, the threshold value calculation unit C3 calculates, based on the process time period for each chain ID measured at step S420, the process threshold value for each chain ID between each adjacent chain IDs in a same or similar manner as in the process at step S230 illustrated in
At step S450, the control unit 40e sets the process threshold values calculated at step S440 to the transfer unit 60d(1). Then, the switching apparatus 100e ends the setting process of a process threshold value.
It is to be noted that the switching process in the switching apparatus 100e depicted in
It is to be noted that the packet processing system SYS5 is not limited to the example depicted in
As described above, in the embodiment depicted in
Further, when the credit excess condition is satisfied, the control unit 40e causes the retention unit 20 to output a next packet irrespective of the process number. It is to be noted that the credit excess condition is a condition that the communication process for a packet to be outputted next from the retention unit 20 is lighter in load than the communication process for a packet outputted last and besides the elapsed time period is longer than the process threshold value. Consequently, even when the server 200a receives packets the number of which exceeds the credit number, the server 200a may improve the processing efficiency of packets by distributing the received packets to the virtual machines 50a depending on the chain ID (substance of the communication process).
A packet processing system SYS6 depicted in
The switching apparatus 100f includes a switch unit 11, N transfer units 60e (60e(1) to 60e(N)), a control unit 40f and a storage unit 70.
The transfer unit 60e(1) includes an identification unit 15a, a retention unit 20, an IF unit 25, a calculation unit 30a, a first measurement unit C1, a second measurement unit C2 and a threshold value calculation unit C3. For example, the transfer unit 60e(1) includes the calculation unit 30a in place of the counter unit 31 depicted in
The calculation unit 30a determines, for example, if the retention unit 20 outputs a packet to the server 200a(1), a data amount to be used for a communication process from among packets (the data amount is hereinafter referred to also as output data amount) based on a chain ID or a chain group added to the packet. On the other hand, if the calculation unit 30a receives a packet after processing from the server 200a(1), the calculation unit 30a determines a data amount used in a communication process (the data amount is hereinafter referred to also as reception data amount) based on a chain ID or a chain group added to the received packet after processing. Then, the calculation unit 30a calculates a data amount of packets for which a communication process is being executed in the server 200a(1) (the data amount is hereinafter referred to also as process data amount) based on the calculated output data amount and reception data amount.
For example, if a chain ID or a chain group added to a packet indicates a communication process of routing, an IP address of a transmission source and an IP address of a destination stored in the packet are used for the communication process of routing. In this case, the calculation unit 30a determines the amount of data of the IP addresses of the transmission source and the destination as an output data amount and a reception data amount, respectively. Further, where the chain ID or the chain group added to the packet indicates a communication process of IPsec, data stored in the data field of the packet is used in the communication process of IPsec. In this case, the calculation unit 30a determines the amount of data stored in the data field of the packet as an output data amount or a reception data amount.
The control unit 40f is implemented, for example, by execution of a program stored in the storage unit 70 by a processor or the like included in the switching apparatus 100f and controls operation of the switching apparatus 100f. Then, the control unit 40f controls outputting of a packet from the retention unit 20 to the server 200a(1) based on the process data amount calculated by the calculation unit 30a.
For example, the control unit 40f decides whether or not the sum of the output data amount of a packet to be outputted from the retention unit 20 and the process data amount being processed in the server 200a(1) is equal to or greater than the maximum data amount processable by the server 200a(1). In the following description, the maximum data amount processable by the server 200a(1) is referred to also as credit amount. If the sum of the output data amount of the packet to be outputted next from the retention unit 20 and the process data amount being processed by the server 200a(1) is smaller than the credit amount, the control unit 40f causes the retention unit 20 to output the packet to the server 200a(1). On the other hand, if the sum of the output data amount of the packet to be outputted next from the retention unit 20 and the process data amount is equal to or greater than the credit amount, the control unit 40f outputs an instruction to the retention unit 20 to suppress outputting of the packet to the server 200a(1). In this manner, the control unit 40f controls outputting of a packet from the retention unit 20 to the server 200a(1) such that the sum of the output data amount of a packet to be outputted next from the retention unit 20 and the process data amount becomes equal to or smaller than the credit amount.
It is to be noted that, if the credit excess condition is satisfied, the control unit 40f causes the retention unit 20 to output a packet to the server 200a irrespective of the process data amount to which the output data amount of a packet to be outputted next from the retention unit 20 is added similarly to the control unit 40c depicted in
It is to be noted that the packet processing system SYS6 is not limited to the example depicted in
At step S500, the control unit 40f decides whether or not, in the transfer unit 60e(1), the process data amount to which the output data amount of a packet to be outputted next from the retention unit 20 is added is equal to or greater than the credit amount. If the process data amount to which the output data amount of a next packet is added is equal to or greater than the credit amount, the processing of the switching apparatus 100f advances to step S250. On the other hand, if the process data amount to which the output data amount of the next packet is added is smaller than the credit amount, the processing of the switching apparatus 100f advances to step S14.
At step S510, the calculation unit 30a of the transfer unit 60e(1) adds the output data amount of the packet outputted at step S14 to the process data amount.
At step S520, the calculation unit 30a of the transfer unit 60e(1) subtracts the reception data amount of a packet after processing received at step S16 from the process data amount, and ends the processing.
At step S530, the calculation unit 30a of the transfer unit 60e(1) adds the output data amount of the packet outputted at step S280 to the process data amount. After the process at step S530 is executed, the processing of the switching apparatus 100f advances to step S16.
Then, the switching apparatus 100f repetitively executes the process illustrated in
It is to be noted that the process illustrated in
As described above, in the embodiment depicted in
Further, when the credit excess condition is satisfied, the control unit 40f causes the retention unit 20 to output a packet irrespective of the process data amount. It is to be noted that the credit excess condition is a condition that the communication process for a packet to be outputted next from the retention unit 20 is lighter in load than the communication process for a packet outputted last and besides the elapsed time period is longer than the process threshold value. Consequently, even when the server 200a receives packets the number of which exceeds the credit number, the server 200a may improve the processing efficiency of packets by distributing the received packets to the virtual machines 50a depending on the chain ID (substance of the communication process).
A packet processing system SYS7 depicted in
The switching apparatus 100g includes a switch unit 11, N transfer units 60f (60f(1) to 60f(N)), a control unit 40g and a storage unit 70. The storage unit 70 includes a storage area for storing a process table PT2 in place of the process table PT illustrated in
The transfer unit 60f(1) includes an identification unit 15c, a DEMUX 21, L retention units 20b (20b(1) to 20b(L)), a MUX 22, an IF unit 25a, a packet generation unit 27a, M counter units 31b (31b(1) to 31b(M)), a time measurement unit C4 and an adjustment unit 80. Each of the transfer units 60f(2) to 60f(N) includes elements same as or similar to those of the transfer unit 60f(1) depicted in
The identification unit 15c acquires the VID included in the VLAN tag header added to a received packet, for example, similarly to the identification unit 15 depicted in
Further, the identification unit 15c adds information of a serial number or the like for identifying each packet to the packet. Then, the identification unit 15c outputs the packet to which the chain ID and the serial number are added to the DEMUX 21.
Each retention unit 20b is a memory having a first-in-first-out function such as a queue. Each retention unit 20b retains packets distributed by the DEMUX 21 and having the same chain ID (substance of the communication process) in order. Each retention unit 20b outputs the packets in the retention order to the server 200a(1). It is to be noted that the substance of the communication process includes information of a combination of communication processes and an order in which the communication processes are executed, and L substances are available. Therefore, the L retention units 20b are provided in each transfer unit 60f.
The IF unit 25a outputs a packet received from the retention unit 20b to the server 200a(1) and outputs a packet after processing received from the server 200a(1) to the switch unit 11 similarly to the IF unit 25 depicted in
Further, the IF unit 25a refers, for example, to the information indicative of time outputted from the clock circuit of the switching apparatus 100g or the like and acquires time information such as a timestamp indicative of reception time at which a packet after processing is received from the server 200a(1). The IF unit 25a outputs time information at which the packet after processing is received and the chain ID and the serial number added to the packet after processing to the time measurement unit C4.
The packet generation unit 27a generates a pseudo packet for causing each of the virtual machines 50a of the server 200a(1) to execute a process artificially. The pseudo packet is a dummy packet used by the time measurement unit C4 to measure the process time period of each virtual machine 50a.
The counter units 31b(1) to 31b(M) are similar to the counter units 31a depicted in
The time measurement unit C4 measures an elapsed time period after each of packets is outputted from the retention unit 20b to the server 200a(1). For example, the time measurement unit C4 measures the elapsed time period from the time at which the retention unit 20b outputs the packet using information indicative of the time outputted from the clock circuit of the switching apparatus 100g or the like and a timestamp of transmission time of the packet acquired from the IF unit 25a. The time measurement unit C4 outputs the measured elapsed time period in an associated relationship with the chain ID and the serial number of the packet to the adjustment unit 80.
Further, the time measurement unit C4 measures a process time period spent on a communication process of a packet in each of the virtual machines 50a of the server 200a(1) using a pseudo packet generated by the packet generation unit 27a. For example, the packet generation unit 27a generates a pseudo packet to which a chain ID and a serial number for allowing processing by a single virtual machine 50a are added and outputs the generated pseudo packet to the server 200a(1). The time measurement unit C4 acquires the chain ID, serial number and timestamp of the transmission time of the outputted pseudo packet from the IF unit 25a. Further, the time measurement unit C4 acquires the chain ID, serial number and timestamp of the reception time of the pseudo packet after processing received from the server 200a(1) from the IF unit 25a. Then, the time measurement unit C4 calculates the difference between the timestamp of the reception time and the timestamp of the transmission time of pseudo packets to which the same serial number is added and measures the process time period of each virtual machine 50a. The time measurement unit C4 outputs the measured process time period of each virtual machine 50a to the adjustment unit 80.
It is to be noted that the time measurement unit C4 may measure the process time period of each virtual machine 50a using a packet received from the network NW.
The adjustment unit 80 specifies in which virtual machine 50a a packet outputted from each retention unit 20b is being processed using the elapsed time period, measured by the time measurement unit C4, of a packet outputted from each retention unit 20b, the chain ID of the packet and the process table PT2. The adjustment unit 80 adjusts, based on the result of the specification, the process number of each virtual machine 50a counted by the counter unit 31b. Operation of the adjustment unit 80 is described with reference to
The control unit 40g is implemented, for example, by execution of a control program stored in the storage unit 70 by a processor or the like included in the switching apparatus 100g, and controls operation of the switching apparatus 100g. Then, the control unit 40g controls outputting of a packet from each retention unit 20b of the transfer unit 60f(1) to the server 200a based on the process number of each virtual machine 50a counted by each counter unit 31b. Operation of the control unit 40g is described with reference to
It is to be noted that, also for the transfer units 60f(2) to 60f(N), the control unit 40g performs control same as or similar to that for the transfer unit 60f(1).
It is to be noted that the packet processing system SYS7 is not limited to the example depicted in
In the identification area IA, a value of the VID for specifying a VLAN to which a packet belongs is stored as an identification number in a same or similar manner as in the process table PT illustrated in
Each of the process areas from the first process area A1 to the zth process area Az retains information indicative of a virtual machine by which a communication process is executed and information indicative of a process time period of the communication process. The information retained in each of the process areas from the first process area A1 to the zth process area Az is retained in an order in accordance with the substance of the communication process executed for each packet having a VID (identification number). For example, where the communication process executed for a packet whose identification number is “1” is routing and the virtual machine 50a(1) is executing a routing process, information indicative of the virtual machine 50a(1) is stored in the first process area A1. Further, in the first process area A1, a process time period (for example, one second) of the virtual machine 50a(1) spent on a process of routing of a pseudo packet and measured by the time measurement unit C4 using a pseudo packet generated by the packet generation unit 27a is stored. It is to be noted that, in the process table PT2 illustrated in
Further, where the substance of the communication process executed for a packet whose identification number is “2” is two processes of routing and IPsec and besides the process of routing is executed first, information indicative of the virtual machine 50a(1) that executes a routing process is stored in the first process area A1. Meanwhile, in the second process area A2, for example, information indicative of the virtual machine 50a(2) that executes an IPsec process is stored. Further, in the first process area A1 in which the identification number is “2,” a process time period of routing by the virtual machine 50a(1) is stored. Further, in the second process area A2 in which the identification number is “2,” a process time period of IPsec by the virtual machine 50a(2) is stored. The process time period of routing and the process time period of IPsec are measured using a pseudo packet by the time measurement unit C4.
It is to be noted that, in the process table PT2 illustrated in
Further, in the process table PT2 illustrated in
Further, the time measurement unit C4 of the transfer unit 60f(1) starts measurement of the elapsed time period with regard to the packet Pb1 in response to outputting of the packet Pb1 from the retention unit 20b(2). Since the chain ID of the received packet Pb1 is “2,” the server 200a(1) transfers the packet Pb1 to the virtual machine 50a(1) that executes a communication process of routing. Then, the virtual machine 50a(1) starts a communication process of routing for the packet Pb1.
Then, if the elapsed time period of the time measurement unit C4 becomes equal to or longer than the process time period (one second) of the virtual machine 50a(1) in the process table PT2 in
Then, if the elapsed time period of the time measurement unit C4 becomes equal to or longer than the sum total (three seconds) of the process time periods of the virtual machines 50a(1) and 50a(2) in the process table PT2 in
It is to be noted that the process illustrated in
Further, the process illustrated in
Alternatively, the process of
While, in the process illustrated in
At step S405, the packet generation unit 27a generates a pseudo packet for being processed by each virtual machine 50a under the control of the adjustment unit 80. After the process at step S405 is executed, the processing of the switching apparatus 100g advances to step S410. Then, after the switching apparatus 100g executes the process at step S410, it executes the process at step S425.
At step S425, the time measurement unit C4 measures the process time period of a communication process by each virtual machine 50a of the server 200a(1) for the pseudo packet outputted at step S410. After the process at step S425 is executed, the processing of the switching apparatus 100g advances to step S430. Then, if the number of times of measurement of the process time period for each virtual machine 50a is equal to or greater than a given number of times in the process at step S430, the switching apparatus 100g executes a process at step S445. On the other hand, when the number of times of measurement of the process time period for each virtual machine 50a is lower than the given number of times in the process at step S430, the processing of the switching apparatus 100g advances to step S405. It is to be noted that the given number of times may be once.
At step S445, the adjustment unit 80 calculates an average value of the process time period of each virtual machine 50a using the process time periods of the virtual machines 50a measured at step S425 by the number of times equal to or greater than the given number of times. After the process at step S445 is executed, the processing of the switching apparatus 100g advances to step S455.
At step S455, the control unit 40g sets the average value of the process time period of each virtual machine 50a calculated at step S445 to the process table PT2. Then, the switching apparatus 100g ends the setting process of a process time period.
It is to be noted that, when the difference of the average value of the process time period calculated at step S445 for each virtual machine 50a from the process time period before the setting is greater than a given threshold value, the control unit 40g may perform such adjustment as to decrease the credit number set for the virtual machine 50a by one. Then, when the difference of the average value of the process time period calculated in the next measurement process of the process time period from the process time period before the setting is equal to or smaller than the given threshold value, the control unit 40g may perform such a process as to return the credit number set for the virtual machine 50a to its original value. For example, where the fluctuation of the process time period of each virtual machine 50a of the server 200a(1) is great, the packet processing system SYS7 adjusts the credit number of each virtual machine 50a. Consequently, the packet processing system SYS7 may avoid a situation that a packet is discarded in the server 200a(1) due to a failure or the like occurring with the switching apparatus 100g or the server 200a(1), and may suppress packet loss.
It is to be noted that the process illustrated in
At step S600, the control unit 40g decides whether or not the transfer unit 60f(1) receives a packet from the switch unit 11. If a packet is received, the processing of the switching apparatus 100g advances to step S610. On the other hand, if a packet is not received, the processing of the switching apparatus 100g advances to step S630.
At step S610, the identification unit 15c identifies the chain of the received packet based on the VID of the VLAN tag header added to the packet received at step S600 and the process table PT2 illustrated in
At step S620, the DEMUX 21 distributes the packet outputted at step S610 to the retention unit 20b corresponding to the chain ID added to the packet, and each of the retention units 20b retains packets to which the same chain ID is added. Then, the processing of the switching apparatus 100g advances to step S630.
At step S630, the control unit 40g decides whether or not each retention unit 20b (for example, the chain ID) retains a packet. Then, if the retention unit 20b retains a packet, the processing of the switching apparatus 100g advances to step S640. On the other hand, if the retention unit 20b does not retain a packet, the processing of the switching apparatus 100g advances to step S600.
At step S640, the control unit 40g refers to the process table PT2 and decides whether or not the process number of any of the virtual machines 50a (counter units 31b) of the server 200a(1) which execute the substance of the communication process indicated by the chain ID is equal to or greater than the credit number. If the process number of any virtual machine 50a that executes the substance of the communication process indicated by the chain ID is equal to or greater than the credit number, the control unit 40g outputs an instruction to the retention unit 20b that is decided as retaining a packet of the chain ID to suppress outputting of a packet. In this case, the processing of the switching apparatus 100g returns to step S600. On the other hand, if the process number of all of the virtual machines 50a that execute the substance of the communication process indicated by the chain ID is smaller than the credit number, the processing of the switching apparatus 100g advances to step S650.
At step S650, the retention unit 20b that retains a packet of the chain ID decided at step S640 outputs the packet to the server 200a(1). In this case, the time measurement unit C4 starts measurement of the elapsed time period of the outputted packet. Then, the processing of the switching apparatus 100g advances to step S660.
At step S660, the adjustment unit 80 specifies the virtual machine 50a that is processing a packet based on the chain ID of the packet outputted at step S650, the elapsed time period measured by the time measurement unit C4 and the process table PT2. To this end, the adjustment unit 80 initializes a variable S to “1” and successively refers to the process table PT2 beginning with the information stored in the first process area A1. Then, the processing of the switching apparatus 100g advances to step S670.
At step S670, the adjustment unit 80 causes the counter unit 31b of the virtual machine 50a stored in the Sth process area to increase the process number by one. Then, the processing of the switching apparatus 100g advances to step S680.
At step S680, the adjustment unit 80 decides whether or not the elapsed time period measured by the time measurement unit C4 is equal to or longer than a period of time of the sum of the process time periods stored in the process areas from the first process area A1 to the Sth process area. If the elapsed time period measured by the time measurement unit C4 is equal to or longer than the period of time of the sum of the process time periods from the first process area A1 to the Sth process area, the processing of the switching apparatus 100g advances to step S690. On the other hand, if the elapsed time period is shorter than the period of time of the sum of the process time periods from the first process area A1 to the Sth process area, the switching apparatus 100g repeats the process at step S680 until after the elapsed time period becomes equal to or longer than the period of time of the sum of the process time periods.
At step S690, the adjustment unit 80 causes the counter unit 31b of the virtual machine 50a stored in the Sth process area to decrease the process number by one. Then, the processing of the switching apparatus 100g advances to step S700.
At step S700, the adjustment unit 80 decides based on the chain ID of the packet outputted at step S650 and the process table PT2 whether or not information indicative of a virtual machine 50a and a process time period is stored in the (S+1)th process area. If such information is stored in the (S+1)th process area, the adjustment unit 80 increases the value of the variable S by one. Then, the processing of the switching apparatus 100g advances to step S670. On the other hand, if such information is not stored in the (S+1)th process area, the packet processing system SYS7 ends the packet process.
Then, the switching apparatus 100g repetitively executes the process illustrated in
As described above, in the embodiment depicted in
Further, since each counter unit 31b counts the process number in each virtual machine 50a, even when the substance of the communication process indicated by the chain ID is changed, the packet processing system SYS7 may cope with the change flexibly in comparison with the prior art.
A packet processing system SYS8 depicted in
The switching apparatus 100h includes a switch unit 11, N transfer units 60g (60g(1) to 60g(N)), a control unit 40h and a storage unit 70.
The transfer unit 60h(1) includes an identification unit 15c, a DEMUX 21, L retention units 20b, a MUX 22, an IF unit 25a, a packet generation unit 27a, M counter units 31b, J confluence monitoring units 33 (33(1) to 33(J)), a time measurement unit C4 and an adjustment unit 80a. It is to be noted that also each of the transfer units 60g(2) to 60g(N) includes elements same as or similar to those of the transfer unit 60g(1) depicted in
The adjustment unit 80a specifies, using an elapsed time period of each packet measured by the time measurement unit C4, a chain ID of each packet and the process table PT2, by which one of the virtual machines 50a each packet is being processed similarly to the adjustment unit 80 depicted in
Each confluence monitoring unit 33 is an up/down counter or the like. For example, the confluence monitoring unit 33(1) monitors a packet transferred from the virtual machine 50a(2) to the virtual machine 50a(1) based on the result of the specification by the adjustment unit 80a. For example, the confluence monitoring unit 33(1) counts the process number of packets whose process is started by the virtual machine 50a(2) within a period from a point of time prior by the process time period (for example, one second) of the virtual machine 50a(1) to the present point of time to another point of time prior by the process time period (for example, two seconds) of the virtual machine 50a(2). Further, each of the confluence monitoring units 33(2) to 33(J) monitors a packet transferred from the virtual machine 50a of the transfer source to the virtual machine 50a of the transfer destination, whose process time period is shorter than that of the virtual machine 50a of the transfer source, similarly to the confluence monitoring unit 33(1) based on the process table PT2. For example, each of the confluence monitoring units 33(2) to 33(J) counts the process number of packets whose process is started by the virtual machine 50a of the transfer source within a range from a point of time prior by the process time period of the virtual machine 50a of the transfer destination to the present point of time to another point of time prior by the process time period of the virtual machine 50a of the transfer source. Operation of the confluence monitoring unit 33 is described with reference to
The control unit 40h is implemented by a processor included in the switching apparatus 100h or the like and controls operation of the switching apparatus 100h by executing a control program stored in the storage unit 70. Then, based on the monitoring of the confluence monitoring unit 33, the control unit 40h controls each retention unit 20b such that, in the virtual machine 50a(1) and so forth, collision between a packet outputted from the retention unit 20b(1) or the like and another packet from the virtual machine 50a(2) or the like may be avoided. Operation of the control unit 40h is described with reference to
It is to be noted that the control unit 40h executes control same as or similar to that for the transfer unit 60g(1) also for the transfer units 60g(2) to 60g(N).
It is to be noted that the packet processing system SYS8 is not limited to the example depicted in
Incidentally, the control unit 40g of the packet processing system SYS7 depicted in
However, in the process table PT2 illustrated in
However, for example, if the retention unit 20b(4) outputs three packets to the virtual machine 50a(2) in the situation illustrated in
It is to be noted that, immediately before the situation illustrated in
Referring to
Then,
On the other hand, the control unit 40h decides based on the process number of the counter unit 31b(1) and the process number indicated by the confluence monitoring unit 33(1) whether or not the packet Pc2 is to be outputted to the retention unit 20b(1). In the example illustrated in
It is to be noted that, if a packet is transferred, for example, to the virtual machine 50a(2) from a different virtual machine 50a whose process time period is longer than that of the virtual machine 50a(2), in
Then,
In this case, the sum total of the process number of the counter unit 31b(1) and the process number indicated by the confluence monitoring unit 33(1) is smaller than the credit number of the virtual machine 50a(1). For example, even when the packet Pc2 is outputted to the retention unit 20b(1), the control unit 40h decides that one packet transferred from the virtual machine 50a(2) before one second elapses subsequently and the packet Pc2 do not collide with each other in the virtual machine 50a(1).
Referring to
It is to be noted that the process illustrated in
The switching apparatus 100h executes processes at steps S600 to S640. It is to be noted that, if the process number of any of the virtual machines 50a that execute the substance of the communication process indicated by the chain ID is equal to or greater than the credit number at step S640, the processing of the switching apparatus 100h advances to step S800. On the other hand, if the process number of all of the virtual machines 50a that execute the substance of the communication process indicated by the chain ID is smaller than the credit number, the processing of the switching apparatus 100h advances to step S650.
At step S800, the control unit 40h refers to the process table PT2 and decides whether or not, at the virtual machine 50a stored in the first process area A1 of the chain ID (identification number) identified at step S610, a packet from a different virtual machine 50a joins together. The virtual machine 50a in the first process area A1 is hereinafter referred to also as first virtual machine 50a. If a packet from a different virtual machine 50a joins together at the first virtual machine 50a, the processing of the switching apparatus 100h advances to step S820. The case in which a packet from the different virtual machine 50a joins together at the first virtual machine 50a is a case in which information indicative of the first virtual machine 50a is stored in an area such as the second process area A2 of the process table PT2.
On the other hand, if a packet from a different virtual machine 50a does not join together at the first virtual machine 50a, the processing of the switching apparatus 100h advances to step S810.
At step S810, the control unit 40h decides whether or not the process number of the first virtual machine 50a is equal to or greater than the credit number. If the process number of the first virtual machine 50a is equal to or greater than the credit number, the control unit 40h outputs an instruction to the retention unit 20b, which retains the packet of the chain ID identified at step S610, to suppress outputting of a packet to the server 200a(1). In this case, the processing of the switching apparatus 100h advances to step S600. On the other hand, if the process number of the first virtual machine 50a is smaller than the credit number, the processing of the switching apparatus 100h advances to step S650.
At step S820, the control unit 40h decides whether or not the process number of the first virtual machine 50a at which a packet from a different virtual machine 50a joins together is equal to or greater than the credit number. If the process number of the first virtual machine 50a is equal to or greater than the credit number, the control unit 40h outputs an instruction to the retention unit 20b, which retains a packet of the chain ID identified at step S610, to suppress outputting of a packet to the server 200a(1). In this case, the processing of the switching apparatus 100h advances to step S600. On the other hand, if the process number of the first virtual machine 50a is smaller than the credit number, the processing of the switching apparatus 100h advances to step S830.
At step S830, the control unit 40h totals all of the process numbers of the confluence monitoring units 33 of the virtual machines 50a that have a process time period longer than that of the first virtual machine 50a and transfer a packet to the first virtual machine 50a and the process number of the first virtual machine 50a. Then, the control unit 40h decides whether or not the total value is equal to or greater than the credit number of the first virtual machine 50a. If the total value is equal to or greater than the credit number of the first virtual machine 50a, the control unit 40h outputs an instruction to the retention unit 20b, which retains a packet of the chain ID identified at step S610, to suppress outputting of a packet to the server 200a(1). In this case, the processing of the switching apparatus 100h advances to step S600. On the other hand, if the total value is smaller than the credit number of the first virtual machine 50a, the processing of the switching apparatus 100h advances to step S650.
The switching apparatus 100h executes processes at step S650 and at steps S660 to S700 and step S840 illustrated in
At step S840, each confluence monitoring unit 33 updates the process number of packets whose process is started by the virtual machine 50a of the transfer source within a period from a point of time prior by the process time period of the virtual machine 50a of the transfer destination to the present point of time to another point of time prior by the process time period of the virtual machine 50a of the transfer source in response to the elapsed time period measured by the time measurement unit C4.
Then, the switching apparatus 100h repetitively executes the process illustrated in
It is to be noted that, although the process at step S840 is executed in parallel to the processes at steps S670 to S690, the process at step S840 may be executed in parallel to the processes at steps S600 to S700.
As described above, in the embodiment depicted in
Further, the confluence monitoring unit 33 monitors a packet transferred from a virtual machine 50a of the transfer source to another virtual machine 50a of the transfer destination, which has a shorter packet process time period than the virtual machine 50a of the transfer source, based on the result of the specification of the adjustment unit 80a. Then, the confluence monitoring unit 33 counts the process number of packets whose process is started by the virtual machine 50a of the transfer source within a range from a point of time prior by the process time period of the virtual machine 50a of the transfer destination to the present point of time to another point of time prior by the process time period of the virtual machine 50a of the transfer source. The control unit 40h decides, based on the process number of each virtual machine 50a, the process table PT2 and the process number of the confluence monitoring unit 33, whether or not a collision between packets occurs in the packet process. Then, if the control unit 40h decides that a collision of packets does not occur, it outputs an instruction to the retention unit 20b to output a packet to the server 200a. Consequently, the packet processing system SYS8 may effectively utilize each virtual machine 50a of the server 200a(1) and may achieve improvement in efficiency in packet process in comparison with the packet processing system SYS7 depicted in
Further, since each counter unit 31b counts the process number in a corresponding one of the virtual machines 50a, even if the substance of the communication process indicated by a chain ID is changed, the packet processing system SYS8 may cope with the change flexibly in comparison with the prior art.
A packet processing system SYS9 depicted in
The switching apparatus 100i includes a switch unit 11, N transfer units 60h (60h(1) to 60h(N)), a control unit 40i and a storage unit 70. The storage unit 70 includes a storage area for storing a process table PT3 in place of the process table PT2 illustrated in
The transfer unit 60h(1) includes an identification unit 15c, a DEMUX 21, L retention units 20b (20b(1) to 20b(L)), a MUX 22, a band controlling unit 28, an IF unit 25a, a packet generation unit 27a, M counter units 31c (31c(1) to 31c(M)) and a rate measurement unit C5. It is to be noted that also each of the transfer units 60h(2) to 60h(N) includes elements same as or similar to those of the transfer unit 60h(1) depicted in
The band controlling unit 28 controls the band of a packet outputted from the retention unit 20b based on a process such as shaping for allocating a band in response to a priority degree such as quality of service (QoS). For example, the band controlling unit 28 controls the band based on a process rate of each virtual machine 50a stored in the process table PT3 and the substance of a communication process indicated by the chain ID of the packet outputted from the retention unit 20b. It is to be noted that operation of the band controlling unit 28 is described with reference to
The counter units 31c(1) to 31c(M) are up/down counters or the like and count the number of packets (process number) processed in the virtual machines 50a(1) to 50a(M), respectively. For example, every time each retention unit 20b outputs a packet to the server 200a(1), each counter unit 31c increases, based on information indicative of a virtual machine 50a included in the substance of a communication process indicated by the chain ID of the outputted packet, the process number of each virtual machine 50a by one. Further, every time a packet after processing is received from the server 200a(1), each counter unit 31c decreases, based on information that indicates a virtual machine 50a included in the substance of a communication process indicated by the chain ID of the packet after processing, the process number of each virtual machine 50a by one.
The rate measurement unit C5 measures an output rate and a process rate of packets for each virtual machine 50a. The rate measurement unit C5 measures, as the output rate, the number of packets per unit time period (for example, one second) outputted from the retention unit 20b to the server 200a(1) using information indicative of time from a clock circuit included in the switching apparatus 100i or the like. Further, the rate measurement unit C5 calculates, as the process rate, the number of packets per unit time period processed by each virtual machine 50a based on the substance of a communication process indicated by the chain ID of a packet after processing received from the server 200a(1). Then, the rate measurement unit C5 stores the calculated process rate for each virtual machine 50a into the process table PT3. Operation of the rate measurement unit C5 is described with reference to
It is to be noted that the packet outputted to the server 200a(1) may be a packet received from the network NW or may be a pseudo packet generated by the packet generation unit 27a. Further, where a pseudo packet is used, the rate measurement unit C5 may cause, within each unit time period, the packet generation unit 27a to generate a pseudo packet to be processed by any virtual machine 50a of the virtual machines 50a and may measure the process rate of each virtual machine 50a.
The control unit 40i is implemented, for example, by execution of a control program stored in the storage unit 70 by a processor or the like included in the switching apparatus 100i and controls operation of the switching apparatus 100i. Then, the control unit 40i controls outputting of a packet to the server 200a(1) from each retention unit 20b based on the process number of each virtual machine 50a counted by each counter unit 31c and the output rate and the process rate of each virtual machine 50a measured by the rate measurement unit C5.
It is to be noted that, also for the transfer units 60h(2) to 60h(N), the control unit 40i executes control same as or similar to that for the transfer unit 60h(1).
It is to be noted that the packet processing system SYS9 is not limited to the example depicted in
In the area for an identification number (identification area IA), a value of a VID for identifying a VLAN to which a packet belongs is stored as an identification number similarly as in the process table PT2 illustrated in
Each of the first process area A1 to the zth process area Az retains information indicative of a virtual machine 50a that executes a communication process and information indicative of a process rate. The information retained in each of the first process area A1 to the zth process area Az is retained in an order in accordance with the substance of a communication process executed for each packet having a VID (identification number). For example, where the communication process executed for a packet whose identification number is “1” is a process of routing by the virtual machine 50a(1), information indicative of the virtual machine 50a(1) is stored in the first process area A1 similarly as in the process table PT2 illustrated in
It is to be noted that the process illustrated in
Further, the process illustrated in
At step S407, the packet generation unit 27a generates a pseudo packet to be processed by one virtual machine 50a of the virtual machines 50a under the control of the control unit 40i. After the process at step S407 is executed, the processing of the switching apparatus 100i advances to step S410. Then, after the switching apparatus 100i executes a process at step S410, it executes a process at step S435.
At step S435, the rate measurement unit C5 decides, using information indicative of time outputted from the clock circuit of the switching apparatus 100i or the like, whether or not a unit time period such as one second has elapsed after a first pseudo packet is outputted at step S410. If the unit time period has elapsed, the processing of the switching apparatus 100i advances to step S447. On the other hand, if the unit time period has not elapsed, the processing of the switching apparatus 100i advances to step S407.
At step S447, the rate measurement unit C5 calculates a process rate of the virtual machine 50a based on the number of pseudo packets after processing received from the server 200a(1) before the unit time period elapses at step S435. Then, the processing of the switching apparatus 100i advances to step S457.
At step S457, the control unit 40i sets the process rate of the virtual machine 50a calculated at step S447 to the process table PT3. Then, the processing of the switching apparatus 100i advances to step S460.
At step S460, the rate measurement unit C5 decides whether or not the process rate of a next virtual machine 50a is to be measured. If the process rate of a next virtual machine 50a is to be measured, the processing of the switching apparatus 100i advances to step S407. On the other hand, if the process rate of all of the virtual machines 50a has been measured, the switching apparatus 100i ends the setting process.
It is to be noted that, in each of the virtual machines 50a, when the difference of the process rate calculated at step S447 from the process rate before setting is greater than a given threshold value, the control unit 40i may perform such adjustment as to decrease the credit number set for the virtual machine 50a by one. Then, when the difference of the process rate calculated in the next measurement process of the process time period from the process rate before setting is equal to or smaller than a given threshold value, the control unit 40i may perform such a process as to return the credit number set for the virtual machine 50a to its original value. For example, when the fluctuation of the process rate of each virtual machine 50a of the server 200a(1) is great, the packet processing system SYS9 adjusts the credit number of each virtual machine 50a. Consequently, the packet processing system SYS9 may avoid a situation that a packet is discarded in the server 200a(1) because of a failure or the like that occurs in the switching apparatus 100i or the server 200a(1), and may suppress packet loss.
It is to be noted that the process illustrated in
In
At step S655, the counter unit 31c increases the process number of the virtual machine 50a, which processes the packet outputted at step S650, by one based on the chain ID of the outputted packet and the process table PT3. Then, the processing of the switching apparatus 100i advances to step S660, at which the variable S is initialized to “1,” whereafter the processing of the switching apparatus 100i advances to step S685.
At step S685, the control unit 40i decides whether or not the output rate measured by the rate measurement unit C5 is lower than the process rate of the virtual machine 50a stored in the Sth process area. If the output rate of the rate measurement unit C5 is lower than the process rate of the virtual machine 50a of the Sth process area, the control unit 40i decides that the number of packets outputted to the server 200a(1) is within the range of the processing capacity the virtual machine 50a of the Sth process area has. Then, the processing of the switching apparatus 100i advances to step S705. On the other hand, if the output rate of the rate measurement unit C5 is equal to or higher than the process rate of the virtual machine 50a of the Sth process area, the control unit 40i decides that the number of packets outputted to the server 200a(1) exceeds the range of the processing capacity the virtual machine 50a of the Sth process area has. In this case, the control unit 40i suppresses, for example, outputting of a packet from the retention unit 20b. Then, the switching apparatus 100i repeats the process at step S685 until after the output rate becomes lower than the process rate of the virtual machine 50a of the Sth process area. Then, the processing of the switching apparatus 100i advances to step S705.
At step S705, the control unit 40i decides based on the chain ID of the packet outputted at step S650 and the process table PT3 whether or not information indicative of a virtual machine 50a and a process rate is stored in the (S+1)th process area. If information is stored in the (S+1)th process area, the control unit 40i increases the value of the variable S by one. Then, the processing of the switching apparatus 100i advances to step S685. On the other hand, if information is not stored in the (S+1)th process area, the processing of the switching apparatus 100i advances to step S710.
At step S710, if a packet after processing is received from the server 200a(1), the counter unit 31c decreases the process number of the virtual machine 50a, by which the packet after processing has been processed, by one based on the chain ID of the packet after processing and the process table PT3.
Then, the switching apparatus 100i repetitively executes the process illustrated in
As described above, in the embodiment depicted in
Further, the rate measurement unit C5 measures the output rate of packets transferred from the transfer unit 60h to the server 200a and the process rate in each virtual machine 50a. Then, the control unit 40i compares the output rate and the process rate of each virtual machine 50a to monitor the load of the process to each virtual machine 50a and controls outputting of a packet from the retention unit 20b to the server 200a.
Consequently, the switching apparatus 100i controls outputting of a packet to the server 200a without receiving information indicating that the server 200a has no room in the processing capacity of packets from the server 200a. Then, also where the plurality of virtual machines 50a being executed in each server 200a do not have a function for requesting the switching apparatus 100i to stop transmission of a packet, the packet processing system SYS9 may control the transfer amount of packets by the switching apparatus 100i. As a result, the packet processing system SYS9 may suppress packet loss.
From the foregoing detailed description, characteristics and advantages of the embodiments will become clear. It is intended by this that the claims embrace such characteristics and advantages of the embodiments as described above without departing from the spirit and scope of the claims. Further, those having an ordinary skill in the technical field could readily conceive any improvement and alteration. Accordingly, it is not intended to limit the scope of embodiments having inventiveness to those described above, and also it is possible for the claims to rely upon suitable improvements and equivalents included in the range disclosed in the embodiments.
Number | Date | Country | Kind |
---|---|---|---|
2016-030054 | Feb 2016 | JP | national |