This application claims the benefit of priority based on Taiwan Patent Application No. 104139393 filed on Nov. 26, 2015, which is hereby incorporated by reference in its entirety.
The present invention relates to a network packet management server, a network packet management method and a non-transitory tangible computer readable medium thereof. More particularly, the network packet management server of the present invention can generate a packet processing prediction message according to packet edition information and internet of things (IoT) device information, and further generate at least one control message according to the packet processing prediction message, thereby editing and managing the packet.
With the development of the network communication technology in recent years, more and more devices with the network communication function have been widely used in people's daily life. For example, nowadays, various hand-held devices can access data stored in cloud servers via networks, and many kinds of sensing devices (e.g., sensing devices for temperature monitoring) can continuously upload sensing data to the cloud servers via the networks. An internet of things (IoT) can be formed by networking various devices to make the devices capable of data transmission.
Currently, application of the IoT can help network administrators to monitor and manage a device more conveniently. However, the transmission environment of the IoT is highly heterogeneous because there are numerous IoT transmission standards and the transmission protocols defined or used by the IoT transmission standards are also different from each other. Moreover, hardware specifications of the IoT devices are also different from each other, so the IoT protocol and the transmission performance thereof supported by one IoT device are also different from those supported by another IoT device. Thus, as compared to general network environments, network protocols corresponding to different demands and qualities need to be made for various scenarios in the IoT environment, and change and expansion of application layer network protocols need to be supported flexibly to a greater extent. In this case, if the network administrators want to change and expand the protocols in the IoT environment, then they shall evaluate whether the changed and expanded protocols are suitable for the current IoT environment by performing complicated setting and testing operations, and the evaluation result usually can only be decided based on the experience of the network administrators. In other words, currently there lacks a convenient mechanism that assists the network administrators in changing and expanding the protocols of the IoT environment and performing evaluation in advance.
Accordingly, an urgent need exists in the art to provide a packet management mechanism that assists the network administrators in changing and expanding the protocols of the IoT environment and performing evaluation in advance so as to meet the service quality requirements of the IoT network.
The disclosure includes a packet management mechanism, which can assist the network administrator in evaluating in advance whether a packet management demand thereof is suitable for the current IoT environment according to the packet management demand of the network administrator and further based on the capacity of an IoT device, and automatically generate a control message in response to the acknowledgement of the network administrator so as to control a gateway or other network controlling devices connected to the IoT device.
The disclosure includes a network packet management server. The network packet management server comprises a network interface, a storage medium and a processor. The network interface is connected to a network and configured to receive internet of things (IoT) device information via the network and is connected to a network control device and a gateway via the network. The storage medium is configured to store the IoT device information and a packet management program. The packet management program includes a graphics user interface (GUI). The processor is electrically connected to the network interface and the storage medium and is configured to run the packet management program so as to generate header field analysis information in response to an operation on the GUI, generate a packet processing prediction message according to the header field analysis information and the IoT device information, generate at least one control message according to the packet processing prediction message, and transmit the at least one control message to at least one of the network control device and the gateway via the network interface.
The Disclosure also includes a network packet management method for use in a network packet management server. The network packet management server comprises a network interface, a storage medium and a processor. The network interface connects to a network and connects to a network control device and a gateway via the network. The storage medium stores a packet management program. The packet management program includes a GUI. The processor is electrically connected to the network interface and the storage medium. The network packet management method is executed by the processor through running the packet management program and comprises the following steps of: receiving IoT device information through the network interface and via the network, and storing the IoT device information into the storage medium; generating header field analysis information in response to an operation on the GUI; generating a packet processing prediction message according to the header field analysis information and the IoT device information; generating at least one control message according to the packet processing prediction message; and transmitting the at least one control message to at least one of the network control device and the gateway via the network interface.
The disclosure further includes a non-transitory tangible computer readable medium with a packet management program stored therein, and the packet management program includes a GUI and a plurality of codes. When the packet management program is loaded and installed into a network packet management server, the codes are executed by the network packet management server to execute a network packet management method. The network packet management server connects to a network. The network packet management method comprises the following steps of: receiving IoT device information via the network, and storing the IoT device information; generating header field analysis information in response to an operation on the GUI; generating a packet processing prediction message according to the header field analysis information and the IoT device information; generating at least one control message according to the packet processing prediction message; and transmitting the at least one control message to at least one of the network control device and the gateway.
The detailed technology and preferred embodiments implemented for the subject invention are described in the following paragraphs accompanying the appended drawings for people skilled in this field to well appreciate the features of the claimed invention.
In the following description, the present invention will be explained with reference to certain example embodiments thereof. The examples include a network packet management server, a network packet management method and a non-transitory tangible computer readable medium thereof. It shall be appreciated that, these example embodiments are not intended to limit the present invention to any particular example, embodiment, environment, applications or implementations described in these example embodiments. Therefore, description of these example embodiments is only for purpose of illustration rather than to limit the present invention, and the scope claimed in this application shall be governed by the claims.
In the following embodiments and the attached drawings, elements unrelated to the present invention are omitted from depiction; and dimensional relationships among individual elements in the attached drawings are illustrated only for ease of understanding, but not to limit the actual scale.
Please refer to
The network interface 11 of the network packet management server 1 connects to a network (not shown), and can receive internet of things (IoT) device information 102 via the network and it also connects to a network control device and a gateway via the network. In the present invention, the network control device may be a software defined network (SDN) controller or a switch. It shall be noted that, the aforesaid network may be a local area network, the Internet, a telecommunication network or any combination thereof, but it is not limited thereto.
The IoT device may be a device capable of network connected (wireless/wired) transmission. For example, the IoT device may be an intelligent home appliance, an environment sensing device (a temperature/humidity sensor, an optical sensor and a CO or CO2 sensor) or a power sensing device (an intelligent socket, a power meter) or the like, but it is not limited thereto.
For example, under the network architectures 2_1 and 2_2 of
The network interface 11 receives the IoT device information 102 from the cloud server 21, or receives the IoT device information 102 from the gateway 23. The IoT device information 102 may comprise capacity information of various devices (e.g., specification information of the device, which includes the clock pulse of a processor, the capacity of a memory, the available electricity quantity, and the load capacity of the network, but is not limited thereto). The storage medium 13 is configured to store the IoT device information 102 and a packet management program (PMP).
In detail, the packet management program PMP is loaded and installed into the network packet management server 1 so that the network packet management server 1 executes the packet management mechanism of the present invention. The packet management program PMP has a graphical user interface (GUI), via which a user (e.g., the network administrator) can input packet edition information. Schematic description of the GUI will be detailed later.
It shall be appreciated that, once any of the IoT devices under the network architecture has been changed, the network packet management server 1 receives the IoT device information 102 via the network, so the network packet management server 1 will continuously receive the IoT device information 102, and the packet management program PMP may record the IoT device information 102 in the form of a device evaluation database so that the IoT device information 102 is stored into the storage medium 13. In other words, in addition to at least the IoT device information of the currently connected IoT devices (e.g., the hand-held device IoT_d1, the camera IoT_d2 and the refrigerator IoT_d3), the device evaluation database (i.e., the IoT device information 102 stored in the storage medium 13) may further include the IoT device information of the once connected IoT devices.
The processor 15 is electrically connected to the network interface 11 and the storage medium 13 and is configured to run the packet management program PMP. When the user inputs the packet edition information via the GUI, the processor 15 generates header field analysis information in response to the operation of the user on the GUI (i.e., in response to the input of the packet edition information). Specifically, the packet edition information may be packet format information, comparison condition information and translation condition information or the like, but it is not limited thereto. The header field analysis information is generated by the packet management program PMP through further analyzing the packet edition information, and it may include but is not limited to: protocol layering information, protocol number information, header length information, field type information, field number information, and nested depth information or the like. On the other hand, the packet management program PMP may also record the header field analysis information in the form of a packet format database so that the header field analysis information is stored into the storage medium 13.
Next, the packet management program PMP may read the IoT device information 102 from the device evaluation database stored in the storage medium 13, and read the header field analysis information from the packet format database stored in the storage medium 13. Then, the packet management program PMP generates a packet processing prediction message according to the header field analysis information and the IoT device information 102. Specifically, the packet processing prediction message is generated by the network packet management server 1 according to the packet edition information inputted by the user and further based on the capacity of the IoT devices (e.g., the clock pulse of the processor, the capacity of the memory or the like as described above). Finally, the packet management program PMP may further generate at least one control message 104 (e.g., a control message 104_1 and a control message 104_2) according to the packet processing prediction message so as to transmit the at least one control message 104 to at least one of the network control device and the gateway 23 via the network interface 11.
As shown in
Further speaking, in the present invention, the control message 104_2 is generated based on the control protocol provided by the gateway 23, e.g., the HyperText Transfer Protocol (HTTP); the control message 104_1 is generated based on the software-defined network (SDN) technology used by the SDN controller 25, e.g., the protocol oblivious forwarding (POF) or the Programming Protocol-Independent Packet Processors (called P4 for short) in the new generation of OpenFlow 2.0. How the control messages 104_1 and 104_2 are generated shall be readily appreciated by those of ordinary skill in the art based on the aforesaid description, and thus will not be further described herein. Additionally, after receiving the control message 104_1 based on the OpenFlow 2.0, the SDN controller 25 also generates another control message 106 to the switch 27 based on the OpenFlow 2.0.
In the network architecture 2_3 of another implementation, as shown in
Moreover, in the network architecture 2_4 as shown in
The second embodiment of the present invention is as shown in
As described above, the network administrator may access the GUI directly on the network packet management server 1. In this scenario, the network packet management server 1 further comprises an input interface (not shown) and a display module (not shown). The input interface and the display module are electrically connected to the processor 15. The display module may be configured to display the GUI. When the network administrator inputs the packet edition information on the GUI using an input interface (e.g., a physical mouse, a physical keyboard, a touch virtual keyboard or the like), the input interface can generate an input signal in response to the operation of the network administrator on the GUI, and the packet management program PMP further enables the GUI to present packet edition information according to the input signal. Accordingly, the packet management program PMP further generates the header field analysis information according to the packet edition information.
As described above, the packet edition information presented by the GUI may comprise packet format information, comparison condition information and translation condition information or the like, which may be as shown in
After selecting the layer, the network administrator may further select a known protocol through a pull-down menu. For example, if the network administrator wants to edit or manage the packet of the layer 3 and wants to select a known protocol IPv6, then he/she may first click on and select the “Layer 3” on the graphical user interface GUI_1 and then select the “IPv6” through the pull-down menu corresponding to the “Layer 3”. Furthermore, if the network administrator wants to add an additional protocol on his/her own, then he/she may further click on and select the “+” button next to the pull-down menu to add an additional protocol.
After the network administrator has selected the packet of the layer 3 and the corresponding IPv6 protocol thereof, a “Packet Format” belonging to the “IPv6 Protocol” may be presented on the graphical user interface GUI_1 (i.e., information of the “IPv6 Packet Format” is presented on the graphical user interface GUI_1). The “Packet Format” may include many fields, e.g., fields (columns) such as “Type”, “Start”, “Bits”, “Name” or the like. The column “Type” indicates whether the packet field is of a digital format or a text format, the column “Start” indicates the start bit of the field, the column “Bits” indicates the length of the field, and the column “Name” indicates the name of the field.
It shall be appreciated that, if the existing fields presented in the “Packet Format” are insufficient, then the network administrator may click on the key “Add New Field” and thereby add new fields into the selected protocol. On the other hand, a network administrator who wants to edit the packets of several protocols at the same time may click on the key “Add Protocol” to enable the GUI to present another picture “Packet Edition Information” so that the network administrator can edit other relevant protocols. It shall be appreciated that, as mentioned above, the GUI presented in this embodiment is only used to make it convenient to describe how the network administrator performs the operation on the GUI of the present invention, and is not intended to limit the present invention.
Once the network administrator has selected a certain protocol (e.g., the protocol IPv6), the network administrator may click on the key “Add Comparison Condition”, and then a picture presenting a graphical user interface GUI_2 shown in
On the other hand, as shown in
For example, if the network administrator wants to perform translation between the field “Version” of the protocol IPv6 and the field “Version” of the protocol IPv4, and perform translation between the field “Length” of the protocol IPv6 and the field “Length” of the protocol IPv4, then it is necessary to determine whether the fields “Version” of the two protocols are aligned and whether the fields “Length” of the two protocols are aligned. If the aforesaid fields have not yet been aligned, then the order of the fields may be changed through the pull-down menu. Next, a rule for the translation is set. For example, when the values of the fields of the two protocols can be directly copied from each other, then the operator “=” may be selected in a field “Rule”. If the fields require string processing, then the regular expression (not shown) may be selected for the string processing.
After the network administrator has inputted the “Packet Edition Information” as described above, the packet management program PMP can be executed to generate the header field analysis information as described in the first embodiment, and further generate the packet processing prediction message according to the header field analysis information and the IoT device information 102. Next, the packet management program PMP may further present a packet processing acknowledgement (ACK) information on the GUI according to the packet processing prediction message. For example, as shown in
On the other hand, if the network administrator is not satisfied with the packet processing prediction performance, then he/she may further click on the key “Reset”, and thus the packet management program PMP will not generate the at least one control message 104 but return to the graphical user interface GUI_1 for resetting by the network administrator. In other words, the network packet management server 1 of the present invention can predict the packet processing performance for the network administrator in advance, and when the predicted packet processing performance meets the expectation, subsequent packet transmission and management can be performed according to the packet edition information inputted by the network administrator at that time. Otherwise, the network administrator may re-adjust the packet edition information until the analyzed packet processing prediction performance is relatively good, and then the control message 104 is generated accordingly to control at least one of a network control device (e.g., the SDN controller 25 or the switch 27) and the gateway 23.
Furthermore, there may also be a key “Detail” on the graphical user interface GUI_4 so that the network administrator can know the detailed packet processing prediction result. However, as described earlier, the graphical user interfaces GUI_1 to GUI_4 depicted in
It shall be appreciated that, as described above, the network administrator may also access the network packet management server 1 via other UEs (e.g., via a personal computer PC31, as shown in
Similarly, after the network packet management server 1 has obtained the packet processing prediction message by analyzing relevant data, the packet management program PMP may further generate packet processing ACK information 304 according to the packet processing prediction message and transmit the packet processing ACK information 304 to the personal computer PC31 through the network interface 11. In this way, the packet processing ACK information 304 may be displayed on the GUI of the personal computer PC31 operated by the network administrator. If the network administrator is satisfied with the packet processing prediction result, then a packet processing ACK message 306 may be transmitted through the personal computer PC31. Thus, the network interface 11 further receives the packet processing ACK message 306 from the personal computer PC31 via the network so that the packet management program PMP generates at least one control message 104 according to the packet processing ACK message 306.
The third embodiment of the present invention is an extension of the first embodiment, and please further refer to
Additionally, in this embodiment, in addition to the IoT device information 102 received from the cloud server 21 or from the gateway 23 as described above, the IoT device information 102 stored in the storage medium 13 may further include the specification information of IoT devices currently available on the market. By obtaining the IoT device information 102, the network packet management server 1 may first decide the packet efficiency information PEI. In other words, the packet efficiency information PEI indicates the result of considering the capacity of various kinds of IoT devices.
Next, the packet management program PMP further retrieves connected IoT device information from the IoT device information 102. Specifically, the network packet management server 1 may update IoT devices that are to perform data transmission at the present time or the connected IoT devices in real time. Accordingly, based on the connected IoT device information and the packet efficiency information PEI that is estimated earlier, the network packet management server 1 uses a classification algorithm to classify the packet efficiency information PEI and generate classified packet efficiency information CPEI, and generates the packet processing prediction message based on the distribution of the connected IoT device in the classified packet efficiency information CPEI. For example, the packet management program PMP may use the classification algorithm in the data mining, e.g., the K Nearest Neighbors (KNN) algorithm, the support vector machine (SVM) algorithm or the like (but not limited thereto).
Moreover, as described earlier, the header field analysis information includes a plurality of pieces of packet information of multiple dimensions, e.g., the protocol layering information, the protocol number information, the header length information, the field type information, the field number information, and the nested depth information or the like. In an implementation of the present invention, the packet management program PMP may further first change the packet information of multiple dimensions into information of fewer dimensions (e.g., two dimensions). For example, the packet management program PMP may use a field rule algorithm to calculate a calculation complexity and a calculation storage amount based on the plurality of pieces of packet information included in the header field analysis information. In other words, after the plurality of pieces of packet information of multiple dimensions are converted into information of two dimensions by the packet management program PMP, the information of two dimensions of packet information would be obtained/output (i.e., the “Calculation Complexity” and the “Calculation Storage Amount”). Thereby, the packet management program PMP uses the clustering algorithm to generate the packet efficiency information PEI based on the calculation complexity, the calculation storage amount and the IoT device information 102.
For example, as shown in
Through a field rule generation procedure 401, the packet management program PMP can utilize the field rule algorithm to convert the plurality of pieces of information of multiple dimensions into information of two dimensions, i.e., the calculation complexity 41 and the calculation storage amount 43. The “Calculation Complexity 41” may be used to evaluate the speed of the calculation, and the “Calculation Storage Amount 43” may indicate the data amount that needs to be stored in the storage buffer. Next, as shown in
In detail, the packet management program PMP uses the clustering algorithm of the machine learning to quantify the IoT device information so as to generate the packet efficiency information PEI based on the calculation complexity 41 and the calculation storage amount 43. As shown in the packet efficiency information PEI of
For example, when the packet efficiency information PEI is represented with two dimensions, the horizontal axis (X axis) thereof may represent the “memory capacity load status”, and the vertical axis (Y axis) may represent the “power consumption status”, but it is not limited thereto. How to utilize the clustering algorithm to obtain the packet efficiency information PEI based on the calculation complexity 41, the calculation storage amount 43 and the IoT device information 102 shall be appreciated by those of ordinary skill in the art depending on the aforesaid description, and thus will not be further described herein.
As described above, in addition to the IoT device information received from the cloud server 21 or from the gateway 23, the IoT device information 102 stored in the storage medium 13 may also include built-in specification information of IoT devices that are currently available on the market. Then, the packet management program PMP utilizes a packet processing prediction procedure 503 and further utilizes the classification algorithm to generate classified packet efficiency information CPEI, and further generates the packet processing prediction message according to the classified packet efficiency information CPEI.
Further speaking, the classified packet efficiency information CPEI of
The fourth embodiment of the present invention is a network packet management method, and a flowchart diagram of the method is as shown in
First, in step S601, IoT device information is received from the network through the network interface. Next, in step S603, the IoT device information is stored into the storage medium. Thereafter, in step S605, header field analysis information is generated in response to an operation on the GUI. Then, in step S607, a packet processing prediction message is generated according to the header field analysis information and the IoT device information.
In step S609, at least one control message is generated according to the packet processing prediction message. Finally, in step S611, the at least one control message is transmitted to at least one of the network control device and the gateway via the network interface. It shall be noted that, the order in which the steps S601 and S603 and the step S605 are executed is not limited in the present invention. In other words, the steps S601 and S603 and the step S605 may be executed simultaneously, or the steps S601 and S603 may be executed after the step S605. On the other hand, in the network packet management method of this embodiment, the network control device is one of a SDN controller and a switch.
In other embodiments, the step S607 may further comprise steps S701, S703 and S705 as shown in
Additionally, in other embodiments, the step S701 may further comprise steps S801 and S803 as shown in
In another embodiment, the network packet management server further comprises an input interface electrically connected to the processor. The input interface is configured to generate an input signal in response to the operation of a user on the GUI. The network packet management method further comprises the following steps of: enabling the GUI to present packet edition information according to the input signal; and generating the header field analysis information according to the packet edition information. Furthermore, in other embodiments, the network packet management method further comprises the following steps of: enabling the GUI to present packet processing ACK information according to the packet processing prediction message so that the input interface further generates another input signal in response to another operation of the user on the GUI; and generating a packet processing ACK message according to the another input signal so as to generate the at least one control message in response to the packet processing ACK message.
In other embodiments, the user may access the network packet management server via other UEs (e.g., a personal computer) to perform an input operation on the GUI via the other UEs, thereby executing the network packet management method via the other UEs and the network packet management server. In this case, the network packet management method further comprises the following steps of: receiving packet edition information from the network through the network interface in response to the operation of a user on the GUI; and generating the header field analysis information according to the packet edition information.
In another embodiment, the network packet management method further comprises the following steps of: generating packet processing ACK information according to the packet processing prediction message; transmitting the packet processing ACK information to a UE via the network interface; receiving a packet processing ACK message from the UE via the network interface; and generating the at least one control message according to the packet processing ACK message. Additionally, in other embodiments, in the case that the network interface further connects to a cloud server via the network, the network packet management method may further comprise the following steps of: receiving the IoT device information from one of the cloud server and the gateway through the network interface and via the network.
On the other hand, in the network packet management method of the present invention, the header field analysis information may be generated according to packet edition information presented by the GUI, and the packet edition information further comprises at least one of packet format information, comparison condition information and translation condition information. Moreover, in other embodiments, the IoT device information stored in the storage medium comprises a plurality of pieces of individual IoT device information, and each of the plurality of pieces of individual IoT device information further comprises instruction period information, memory capacity information, power consumption information and network load information. In addition to the aforesaid steps, the network packet management method of the present invention can also execute all the operations set forth in the aforesaid embodiments and have all the corresponding functions. How this embodiment executes these operations and have these functions will be readily appreciated by those of ordinary skill in the art based on the explanation of the aforesaid embodiments, and thus will not be further described herein.
As can be known from the above descriptions, the network packet management method of the present invention may be executed by a packet management program having a plurality of codes. The packet management program may be stored into a non-transitory tangible computer readable medium. When packet management program are loaded and installed into an electronic device (e.g., the network packet management server), the packet management program executes the network packet management method of the present invention. The non-transitory computer readable medium may be an electronic product, e.g., a read only memory (ROM), a flash memory, a floppy disk, a hard disk, a compact disk (CD), a mobile disk, a magnetic tape, a database accessible to networks, or any other storage media with the same function and well known to those skilled in the art.
According to the above descriptions, the packet management mechanism of the present invention provides the network administrator with a packet management tool, through which the processing performance when the IoT device processes the packet can be predicted (i.e., a packet processing prediction message can be generated) according to the packet edition information inputted by the network administrator and the capacity of the IoT device (i.e., the IoT device information). If the network administrator is satisfied with the packet processing prediction result (or when the packet processing prediction result is determined to be acceptable), then a control message may accordingly be generated, thereby achieving the objectives of monitoring, managing and editing the packet transmission and so on. Accordingly, the packet management mechanism of the present invention can effectively assist the network administrator in evaluating in advance whether a packet management demand thereof is suitable for the current IoT environment, and automatically generate a control message in response to the acknowledgement of the network administrator so as to control a gateway or other network controlling devices connected to the IoT device.
The above disclosure is related to the detailed technical contents and inventive features thereof. People skilled in this field may proceed with a variety of modifications and replacements based on the disclosures and suggestions of the invention as described without departing from the characteristics thereof. Nevertheless, although such modifications and replacements are not fully disclosed in the above descriptions, they have substantially been covered in the following claims as appended.
Number | Date | Country | Kind |
---|---|---|---|
104139393 | Nov 2015 | TW | national |