CN105337857A - Multi-path transmission method based on software-defined network - Google Patents

Multi-path transmission method based on software-defined network Download PDF

Info

Publication number
CN105337857A
CN105337857A CN201510818810.2A CN201510818810A CN105337857A CN 105337857 A CN105337857 A CN 105337857A CN 201510818810 A CN201510818810 A CN 201510818810A CN 105337857 A CN105337857 A CN 105337857A
Authority
CN
China
Prior art keywords
stream table
host
stream
list item
field
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201510818810.2A
Other languages
Chinese (zh)
Other versions
CN105337857B (en
Inventor
王敬宇
戚琦
包剑楠
陈良章
樊利民
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing University of Posts and Telecommunications
Original Assignee
Beijing University of Posts and Telecommunications
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing University of Posts and Telecommunications filed Critical Beijing University of Posts and Telecommunications
Priority to CN201510818810.2A priority Critical patent/CN105337857B/en
Publication of CN105337857A publication Critical patent/CN105337857A/en
Application granted granted Critical
Publication of CN105337857B publication Critical patent/CN105337857B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/02Topology update or discovery
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/12Shortest path evaluation
    • H04L45/124Shortest path evaluation using a combination of metrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/24Multipath
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/42Centralised routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/54Organization of routing tables
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • H04L45/745Address table lookup; Address filtering

Abstract

The invention relates to a multi-path transmission method based on a software-defined network. The method comprises the following steps: a host A and a host B inform the opposite side and a software-defined network SDN controller of respective additional network card address information in a manner of repeatedly responding to a Dupack message, and the SDN controller calculates independent paths between the host A and the host B and selects a most suitable independent path P from the independent paths; the SDN controller generates a flow table of the independent path P and issues the flow table to a related openflow protocol switch on the independent path P; and the host A and the host B establish a subflow on the independent path P to carry out data transmission, and the host A delivers a data packet to multiple independent paths established with the host B. The method establishes an optimal path for both communication sides, thus realizing multi-path optimal data transmission in SDN.

Description

A kind of multi-path transmission method based on software defined network
Technical field
The present invention relates to a kind of multi-path transmission method based on software defined network, belong to areas of information technology, particularly belong to software defined network technical field.
Background technology
Software defined network (SoftwareDefinedNetworking, SDN) be a centrally controlled network, multiple network node is unified control by SDN controller, network equipment information, net control equipment can be obtained relatively easily, a unified network view is presented to application/client, wherein there is switch, router, virtual machine, storage, virtual subnet and the virtual gateway for communicating between virtual subnet, user can according to the routing rule between the IP address of the network planning configure virtual machine of oneself, configuration subnet and subnet.The open customization of SDN and centralized control characteristic, to some extent solve the problem that internet ossifys, impart the ability of the subscriber customized network system and procotol, user according to the requirement developing of oneself, the application drawn oneself up and hardware platform, independent and flexible can build private network to a certain extent.
MPTCP be the MPTCP working group of IETF to the expansion of conventional TCP, with the addition of MPTCP layer, original TCP layer becomes multiple subflow layer, and the corresponding IP layer of each subflow layer, and namely each subflow can be considered as a TCP and connects.MPTCP makes user can set up corresponding connection on incoherent path, and carries out transfer of data in the mode of independent subflow on these paths.
How the Dominant Facies of software defined network SDN and MPTCP is combined, become for user provides multi-path data to transmit on SDN the technical barrier being badly in need of solving in current software defined network field.
Summary of the invention
In view of this, the object of the invention is to invent a kind of method, realize the multi-path data transmission between subscriber's main station based on software defined network SDN.In order to achieve the above object, the present invention proposes a kind of multi-path transmission method based on software defined network, described method comprises following operative step:
(1) controller of software defined network SDN obtained by regular active probe described in the bandwidth of the topology diagram of software defined network, the time delay of every bar link and every bar link;
(2) host A and host B are by described software defined network under the control of SDN controller, adopt the mode of MPTCP agreement three-way handshake to set up main connection, i.e. First Contact Connections;
(3) host A and host B are by sending the mode of duplicate answer Dupack message, inform the additional NIC address information of the other side and SDN controller oneself, and described duplicate answer Dupack message comprises interpolation address option MP_Addaddress;
(4) the SDN controller described in calculates the independent pathway between host A and host B, N*M*num_flows bar independent pathway can be calculated at most between host A and host B, wherein N is the network interface card number of host A, M is the network interface card number of host B, and num_flows is the sub-connection number that between set often pair of network interface card, most multipotency is set up; The independent pathway of front L bar optimum selected by described SDN controller, and informs host A, and notification comprises the linking number between host A and host B often pair network interface card; L be greater than 1 natural number;
(5) host A contains the SYN message SYN of MP_Join option to host B transmission L bar according to the information be apprised of;
(6) the stream table mismatch of the access side openflow protocol switch A of the SYN message described in and host A, so this openflow protocol switch A is by Packet_in message, sends to the controller of described software defined network SDN by this SYN message;
(7) after the SDN controller described in receives this Packet_in message, parse described SYN message, from described L bar independent pathway, the independent pathway P corresponding with described network interface card information is selected according to the network interface card information in SYN message, generate the stream table of this independent pathway P, and openflow protocol switch relevant on this independent pathway P issues stream table;
(8) host A and host B set up sub-connection and subflow carries out transfer of data on described independent pathway P; Within the time cycle of setting, if openflow protocol switch relevant on this independent pathway P does not have transfer of data on the stream list item corresponding to this independent pathway P, then this stream list item is deleted, and this stream list item deletion event is informed described SDN controller; All openflow protocol switch relevant on described independent pathway P are after the stream list item corresponding to this independent pathway P is all deleted, and described independent pathway P deletes by described SDN controller;
(9) host A is according to the data packet dispatching principle of setting, packet delivery on many independent pathways set up with host B; The data packet dispatching principle of described setting be the data that make to send on the whole fastest to reaching receiving terminal, i.e. host B.
In described step (4), the particular content of the independent pathway that SDN controller calculates between host A and host B is:
After described SDN controller gets the IP address information of all additional network interface card of host A and host B, determine that the access top-cross of described additional network interface card is changed planes according to this address information; Described switch marks out by SDN controller in the topology diagram of the SDN described in obtaining, the source point representing transmitting terminal is added in described topology diagram, add the meeting point representing receiving terminal, then add between the access top-cross of all network interface cards of source point and transmitting terminal is changed planes and connect, adding between the access top-cross of all network interface cards of meeting point and receiving terminal is changed planes equally and connect, so just obtaining the path computing structure chart for calculating the incoherent independent pathway of link;
Transmitting terminal and receiving terminal all have multiple network interface cards, be equivalent to the superposition of multiple 0-1 flow problem, according to foregoing path computing structure chart, if in source point-switch-link by flow be Q, in same meeting point-switch-link by flow be also Q, wherein Q is the integer much larger than 1, if in switch-switch link by flow be 1, so the host A described in calculating and the incoherent path of link between host B have just been simplified to non-directed graph maximum flow problem, solve by Dinic algorithm.
The concrete form of the stream table of the independent pathway P that the SDN controller described in described step (7) generates is as follows:
Stream table is divided into level Four, every one-level stream table is made up of many stream list items, each stream list item is one hexa-atomic group, is namely made up of six fields, respectively: matching domain field, precedence field, counter Counter field, instruction field, timer timeout field and Cookies field;
Wherein, matching domain field is mainly used to coupling bag, formed by the incorporating aspects in ethernet type, IP protocol number, IPv4 source address, IPv4 destination address, tcp source port and TCP destination interface six parameters, be specially: the matching domain field of first order stream table is made up of ethernet type and IPv4 source address, the matching domain field of second level stream table is made up of ethernet type and IPv4 destination address, the matching domain field of third level stream table is made up of IP protocol number and TCP destination interface, and the matching domain field of fourth stage stream table is made up of IP protocol number and tcp source port;
Precedence field defines the priority of every bar stream list item, the stream list item priority match bag that priority is high;
Counter Counter field is mainly used to the number of adding up the packet that this stream list item mated;
Instruction field is divided into goto and output two kinds of instruction types, and goto instruction type is used for the first order, the second level and third level stream table, and be used to refer to next stage stream table, output instruction type is used for fourth stage stream table, is used to specify the switch ports themselves of output;
Timer timeout field is divided into idle_timeout and hard_timeout two kinds of timer types, and how long afterwards the idle_timeout timer type stated free time inefficacy of this stream list item, and hard_timeout timer specifies to flow the total residence time of list item;
Cookie field mainly can allow controller distinguish not homogeneous turbulence list item;
Second level stream table tableA represents, third level stream table tableB represents, fourth stage stream table tableC represents;
First order stream table has and only has one, is responsible for Match IP v4 source address, realizes the differentiation to sending network interface card, and the number of its stream list item equals the network interface card total number of communicating pair use; The value of its instruction goto field is tableA, i.e. second level stream table;
Matching domain IPv4 destination address is responsible for by second level stream table, achieves a butt joint and receives the differentiation of network interface card, and its number flowing list item equals the network interface card total number that communicating pair uses, and the value of its instruction goto field is tableB, i.e. third level stream table;
Coupling TCP destination interface is responsible for by third level stream table, and the value of its instruction goto field is tableC, i.e. fourth stage stream table;
Fourth stage stream table is responsible for mating tcp source port, and the value of its instruction output field is the port numbers in respective switch.
The particular content of described step (7) comprises following operator step:
(71) the SDN controller described in parses SYN message from the Packet_in message received, therefrom extract source IP address and object IP address, the network interface card information be connected with the MPTCP of current maintenance is mated, if the match is successful, then go to step (72), otherwise common path selection is carried out to it, is it and selects a best paths, carry out single path transmission;
(72) the SDN controller described in is according to source IP address and object IP address, judge the path whether can laid in addition in the independent pathway of the L bar optimum calculated at it, then do not stop, have from Packet_in message, then extract stream table number table_id, and judge it is the information which grade stream table is submitted to according to this stream table number table_id, if the information that first order stream table is submitted to then goes to step (73), if the information that second level stream table is submitted to then goes to step (74), if the information that third level stream table is submitted to then goes to step (75), if the information that fourth stage stream table is submitted to then goes to step (76), described stream table number table_id refers to the concrete numbering of second level stream table tableA, third level stream table tableB and fourth stage stream table tableC,
(73) the SDN controller described in produces the stream table number table_id of new second and third, level Four stream table, records; Then issue the stream list item pointing to new second level stream table to the first order stream table of described submission information, and issue stream list item to new second and third, level Four stream table, go to step (77);
(74) the SDN controller described in produces the stream table number table_id of third and fourth grade of new stream table, records; Then the second level stream table to described submission information issues the stream list item pointing to new third level stream table, and issues stream list item to third and fourth grade of new stream table, goes to step (77);
(75) the SDN controller described in produces the stream table number table_id of new fourth stage stream table, records; Then the third level stream table to described submission information issues the stream list item pointing to new fourth stage stream table, and issues stream list item to new fourth stage stream table, goes to step (77);
(76) the SDN controller described in issues stream list item to the fourth stage stream table of described submission information, goes to step (77);
(77) the openflow protocol switch that the SDN described in is relevant on described independent pathway P issues the stream list item carrying out forwarding.
In described step (8), the process of openflow protocol switch deletion stream list item is as follows: when the timer timeout field of described stream list item exceedes certain hour, if do not have packet to flow through this stream list item, then this stream list item can be automatically left out.
Beneficial effect of the present invention is: after getting the network interface card ip information of network edge side main frame, the information such as the full topology information getting whole network and the real-time bandwidth time delay getting each link in whole network, SDN controller more fully can perceive the service condition of whole network, multi-path transmission protocol is applied based on this in SDN environment, for communicating pair sets up optimum path, achieve the transmission of communicating pair multipath optimal data.
Accompanying drawing explanation
Fig. 1 is the flow chart of a kind of multi-path transmission method based on software defined network that the present invention proposes.
Embodiment
For making the object, technical solutions and advantages of the present invention clearly, below in conjunction with accompanying drawing, the present invention is described in further detail.
See Fig. 1, introduce a kind of multi-path transmission method based on software defined network that the present invention proposes, described method comprises following operative step:
(1) controller of software defined network SDN obtained by regular active probe described in the bandwidth of the topology diagram of software defined network, the time delay of every bar link and every bar link;
The concrete detection method of step (1) can see another part Chinese invention patent application of present invention applicant, and denomination of invention is: a kind of method of the detection of the network information for software defined network SDN;
(2) host A and host B are by described software defined network under the control of SDN controller, adopt the mode of MPTCP agreement three-way handshake to set up main connection, i.e. First Contact Connections;
(3) host A and host B are by sending the mode of duplicate answer Dupack message, inform the additional NIC address information of the other side and SDN controller oneself, and described duplicate answer Dupack message comprises interpolation address option MP_Addaddress;
The concrete operation method of step (3) can see another part Chinese invention patent application of present invention applicant, and denomination of invention is: a kind of host network card IP address acquiring method based on software defined network;
(4) the SDN controller described in calculates the independent pathway between host A and host B, N*M*num_flows bar independent pathway can be calculated at most between host A and host B, wherein N is the network interface card number of host A, M is the network interface card number of host B, and num_flows is the sub-connection number that between set often pair of network interface card, most multipotency is set up; The independent pathway of front L bar optimum selected by described SDN controller, and informs host A, and notification comprises the linking number between host A and host B often pair network interface card; L be greater than 1 natural number;
Such as: establish N=2, M=3, num_flows=5, then can calculate at most 2*3*5=30 bar independent pathway between host A and host B, if setting L=10, then front 10 optimum independent pathways selected by described SDN controller, and inform host A.
(5) host A contains the SYN message of MP_Join option to host B transmission L bar according to the information be apprised of;
(6) the stream table mismatch of the access side openflow protocol switch A of the SYN message described in and host A, so this openflow protocol switch A is by Packet_in message, sends to the controller of described software defined network SDN by this SYN message;
(7) after the SDN controller described in receives this Packet_in message, parse described SYN message, from described L bar independent pathway, the independent pathway P corresponding with described network interface card information is selected according to the network interface card information in SYN message, generate the stream table of this independent pathway P, and openflow protocol switch relevant on this independent pathway P issues stream table;
(8) host A and host B set up sub-connection and subflow carries out transfer of data on described independent pathway P; Within the time cycle of setting, if openflow protocol switch relevant on this independent pathway P does not have transfer of data on the stream list item corresponding to this independent pathway P, then this stream list item is deleted, and this stream list item deletion event is informed described SDN controller; All openflow protocol switch relevant on described independent pathway P are after the stream list item corresponding to this independent pathway P is all deleted, and described independent pathway P deletes by described SDN controller;
(9) host A is according to the data packet dispatching principle of setting, packet delivery on many independent pathways set up with host B; The data packet dispatching principle of described setting be the data that make to send on the whole fastest to reaching receiving terminal, i.e. host B.
In described step (4), the particular content of the independent pathway that SDN controller calculates between host A and host B is:
After described SDN controller gets the IP address information of all additional network interface card of host A and host B, determine that the access top-cross of described additional network interface card is changed planes according to this address information; Described switch marks out by SDN controller in the topology diagram of the SDN described in obtaining, the source point representing transmitting terminal is added in described topology diagram, add the meeting point representing receiving terminal, then add between the access top-cross of all network interface cards of source point and transmitting terminal is changed planes and connect, adding between the access top-cross of all network interface cards of meeting point and receiving terminal is changed planes equally and connect, so just obtaining the path computing structure chart for calculating the incoherent independent pathway of link;
Transmitting terminal and receiving terminal all have multiple network interface cards, be equivalent to the superposition (" 0-1 flow problem " refers to https: //en.wikipedia.org/wiki/Knapsack_problem) of multiple 0-1 flow problem, according to foregoing path computing structure chart, if in source point-switch-link by flow be Q, in same meeting point-switch-link by flow be also Q, wherein Q is the integer (such as Q=100M) much larger than 1, if in switch-switch link by flow be 1, so the host A described in calculating and the incoherent path of link between host B have just been simplified to non-directed graph maximum flow problem, undertaken solving (" Dinic algorithm " refers to https: //en.wikipedia.org/wiki/Dinic%27s_algorithm) by Dinic algorithm.
The concrete form of the stream table of the independent pathway P that the SDN controller described in described step (7) generates is as follows:
Stream table is divided into level Four, every one-level stream table is made up of many stream list items, each stream list item is one hexa-atomic group, is namely made up of six fields, respectively: matching domain field, precedence field, counter Counter field, instruction field, timer timeout field and Cookies field;
Wherein, matching domain field is mainly used to coupling bag, formed by the incorporating aspects in ethernet type, IP protocol number, IPv4 source address, IPv4 destination address, tcp source port and TCP destination interface six parameters, be specially: the matching domain field of first order stream table is made up of ethernet type and IPv4 source address, the matching domain field of second level stream table is made up of ethernet type and IPv4 destination address, the matching domain field of third level stream table is made up of IP protocol number and TCP destination interface, and the matching domain field of fourth stage stream table is made up of IP protocol number and tcp source port;
Precedence field defines the priority of every bar stream list item, the stream list item priority match bag that priority is high;
Counter Counter field is mainly used to the number of adding up the packet that this stream list item mated;
Instruction field is divided into goto and output two kinds of instruction types, and goto instruction type is used for the first order, the second level and third level stream table, and be used to refer to next stage stream table, output instruction type is used for fourth stage stream table, is used to specify the switch ports themselves of output;
Timer timeout field is divided into idle_timeout and hard_timeout two kinds of timer types, and how long afterwards the idle_timeout timer type stated free time inefficacy of this stream list item, and hard_timeout timer specifies to flow the total residence time of list item;
Cookie field mainly can allow controller distinguish not homogeneous turbulence list item;
Second level stream table tableA represents, third level stream table tableB represents, fourth stage stream table tableC represents;
First order stream table has and only has one, is responsible for Match IP v4 source address, realizes the differentiation to sending network interface card, and the number of its stream list item equals the network interface card total number of communicating pair use; The value of its instruction goto field is tableA, i.e. second level stream table;
Matching domain IPv4 destination address is responsible for by second level stream table, achieves a butt joint and receives the differentiation of network interface card, and its number flowing list item equals the network interface card total number that communicating pair uses, and the value of its instruction goto field is tableB, i.e. third level stream table;
Coupling TCP destination interface is responsible for by third level stream table, and the value of its instruction goto field is tableC, i.e. fourth stage stream table;
Fourth stage stream table is responsible for mating tcp source port, and the value of its instruction output field is the port numbers in respective switch.
Be exemplified below:
(source IP address is 10.0.0.1 such as to there is a path being based upon between main frame 10.0.0.1 and main frame 10.0.0.2, source port number is 49407, object IP address is 10.0.0.2, destination slogan is 5001, ethernet type is 0x0800), then corresponding stream list items at different levels are as follows:
One-level stream list item is:
Matching domain field (ethernet type 0x0800, IPv4 source address 10.0.0.1)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableA)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Secondary streams list item (in stream table tableA) is:
Matching domain field (ethernet type 0x0800, IPv4 destination address 10.0.0.2)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableB)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Three grades of stream list items (in stream table tableB) are:
Matching domain (IP protocol number 6, TCP destination interface 5001)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableC)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Level Four stream list item (in stream table tableC) is:
Matching domain (IP protocol number 6, tcp source port 49407)
Precedence field (optional)
Counter Counter field
Instruction output field (n, n are the port numbers on concrete openflow switch)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
The particular content of described step (7) comprises following operator step:
(71) the SDN controller described in parses SYN message from the Packet_in message received, therefrom extract source IP address and object IP address, the network interface card information be connected with the MPTCP of current maintenance is mated, if the match is successful, then go to step (72), otherwise common path selection is carried out to it, is it and selects a best paths, carry out single path transmission;
(72) the SDN controller described in is according to source IP address and object IP address, judge the path whether can laid in addition in the independent pathway of the L bar optimum calculated at it, then do not stop, have from Packet_in message, then extract stream table number table_id, and judge it is the information which grade stream table is submitted to according to this stream table number table_id, if the information that first order stream table is submitted to then goes to step (73), if the information that second level stream table is submitted to then goes to step (74), if the information that third level stream table is submitted to then goes to step (75), if the information that fourth stage stream table is submitted to then goes to step (76), described stream table number table_id refers to the concrete numbering of secondary streams table tableA, three grades of stream table tableB and level Four stream table tableC,
(73) the SDN controller described in produces the stream table number table_id of new second and third, level Four stream table, records; Then issue the stream list item pointing to new second level stream table to the first order stream table of described submission information, and issue stream list item to new second and third, level Four stream table, go to step (77);
Be exemplified below:
Such as: the path that will set up is the new network interface card enabling source, and source IP address can not match with the stream list item in first order stream table; Specific as follows: a path be based upon between 10.0.1.1 and 10.0.0.2, source IP address is 10.0.1.1, and source port number is 48357, object IP addresses is 10.0.0.2, and destination slogan is 5001; Then corresponding stream list items at different levels are as follows:
One-level stream list item is:
Matching domain field (ethernet type 0x0800, IPv4 source address 10.0.1.1)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableA1, tableA1 represent the concrete stream table number table_id of pointed second level stream table)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Secondary streams list item (in stream table tableA1) is:
Matching domain field (ethernet type 0x0800, IPv4 destination address 10.0.0.2)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableB1, tableB1 represent the concrete stream table number table_id of pointed third level stream table)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Three grades of stream list items (in stream table tableB1) are:
Matching domain (IP protocol number 6, TCP destination interface 5001)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableC1, tableC1 represent the concrete stream table number table_id of pointed fourth stage stream table)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Level Four stream list item (in stream table tableC1) is:
Matching domain (IP protocol number 6, tcp source port 48357)
Precedence field (optional)
Counter Counter field
Instruction output field (n, n are the port numbers on concrete openflow switch)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
(74) the SDN controller described in produces the stream table number table_id of third and fourth grade of new stream table, records; Then the second level stream table to described submission information issues the stream list item pointing to new third level stream table, and issues stream list item to third and fourth grade of new stream table, goes to step (77);
Be exemplified below:
Such as: the path that will set up is the new network interface card enabling destination, and destination IP address can not match with the stream list item in the stream table of the second level; Specific as follows: a path be based upon between 10.0.0.1 and 10.0.1.2, source IP address is 10.0.0.1, and source port number is 47296, object IP addresses is 10.0.1.2, and destination slogan is 5001; Then corresponding stream list item at different levels is as follows:
Secondary streams list item is:
Matching domain field (ethernet type 0x0800, IPv4 destination address 10.0.1.2)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableB2, tableB2 represent the concrete stream table number table_id of pointed third level stream table)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Three grades of stream list items (in stream table tableB2) are:
Matching domain (IP protocol number 6, TCP destination interface 5001)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableC2, tableC2 represent the concrete stream table number table_id of pointed fourth stage stream table)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Level Four stream list item (in stream table tableC2) is:
Matching domain (IP protocol number 6, tcp source port 47296)
Precedence field (optional)
Counter Counter field
Instruction output field (n, n are the port numbers on concrete openflow switch)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
(75) the SDN controller described in produces the stream table number table_id of new fourth stage stream table, records; Then the third level stream table to described submission information issues the stream list item pointing to new fourth stage stream table, and issues stream list item to new fourth stage stream table, goes to step (77);
Be exemplified below:
Such as: the path that will set up is a pair new business of having enabled between network interface card, TCP destination interface can not match with the stream list item in third level stream table; Specific as follows: a path be based upon between 10.0.0.1 and 10.0.0.2, source IP address is 10.0.0.1, and source port number is 43728, object IP addresses is 10.0.0.2, and destination slogan is 45378; Then corresponding stream list item at different levels is as follows:
Three grades of stream list items are:
Matching domain (IP protocol number 6, TCP destination interface 45378)
Precedence field (optional)
Counter Counter field
Instruction goto field (gototableC3, tableC3 represent the concrete stream table number table_id of pointed fourth stage stream table)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
Level Four stream list item (in stream table tableC3) is:
Matching domain (IP protocol number 6, tcp source port 43728);
Precedence field (optional)
Counter Counter field
Instruction output field (n, n are the port numbers on concrete openflow switch)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
(76) the SDN controller described in issues stream list item to the fourth stage stream table of described submission information, goes to step (77);
Be exemplified below:
Such as: the new connection between network interface card has been enabled in the path that will set up for a pair, tcp source port can not match with the stream list item in fourth stage stream table; Instantiation is as follows: a path be based upon between 0.0.0.1 and 10.0.0.2, and source IP address is 10.0.0.1, and source port number is 45396, object IP addresses is 10.0.0.2, and destination slogan is 5001; Then corresponding level Four stream list item is: matching domain (IP protocol number 6, tcp source port 45396), outputn (n is the port numbers on concrete openflow switch);
Level Four stream list item is:
Matching domain (IP protocol number 6, tcp source port 45396)
Precedence field (optional)
Counter Counter field
Instruction output field (n, n are the port numbers on concrete openflow switch)
Timer timeout field (optional, such as idle_timeout=15)
Cookies field (optional)
(77) the openflow protocol switch that the SDN described in is relevant on described independent pathway P issues the stream list item carrying out forwarding.
In described step (8), the process of openflow protocol switch deletion stream list item is as follows: when the timer timeout field of described stream list item exceedes certain hour (such as 15 seconds), if do not have packet to flow through this stream list item, then this stream list item can be automatically left out.
Inventor tests on try net method of the present invention, through a large amount of experiments and emulation, obtains satisfied experimental result, and proved invention is feasible and very effective.

Claims (5)

1. based on a multi-path transmission method for software defined network, it is characterized in that: described method comprises following operative step:
(1) controller of software defined network SDN obtained by regular active probe described in the bandwidth of the topology diagram of software defined network, the time delay of every bar link and every bar link;
(2) host A and host B are by described software defined network under the control of SDN controller, adopt the mode of MPTCP agreement three-way handshake to set up main connection, i.e. First Contact Connections;
(3) host A and host B are by sending the mode of duplicate answer Dupack message, inform the additional NIC address information of the other side and SDN controller oneself, and described duplicate answer Dupack message comprises interpolation address option MP_Addaddress;
(4) the SDN controller described in calculates the independent pathway between host A and host B, N*M*num_flows bar independent pathway can be calculated at most between host A and host B, wherein N is the network interface card number of host A, M is the network interface card number of host B, and num_flows is the sub-connection number that between set often pair of network interface card, most multipotency is set up; The independent pathway of front L bar optimum selected by described SDN controller, and informs host A, and notification comprises the linking number between host A and host B often pair network interface card; L be greater than 1 natural number;
(5) host A contains the SYN message of MP_Join option to host B transmission L bar according to the information be apprised of;
(6) the stream table mismatch of the access side openflow protocol switch A of the SYN message described in and host A, so this openflow protocol switch A is by Packet_in message, sends to the controller of described software defined network SDN by this SYN message;
(7) after the SDN controller described in receives this Packet_in message, parse described SYN message, from described L bar independent pathway, the independent pathway P corresponding with described network interface card information is selected according to the network interface card information in SYN message, generate the stream table of this independent pathway P, and openflow protocol switch relevant on this independent pathway P issues stream table;
(8) host A and host B set up sub-connection and subflow carries out transfer of data on described independent pathway P; Within the time cycle of setting, if openflow protocol switch relevant on this independent pathway P does not have transfer of data on the stream list item corresponding to this independent pathway P, then this stream list item is deleted, and this stream list item deletion event is informed described SDN controller; All openflow protocol switch relevant on described independent pathway P are after the stream list item corresponding to this independent pathway P is all deleted, and described independent pathway P deletes by described SDN controller;
(9) host A is according to the data packet dispatching principle of setting, packet delivery on many independent pathways set up with host B; The data packet dispatching principle of described setting be the data that make to send on the whole fastest to reaching receiving terminal, i.e. host B.
2. a kind of multi-path transmission method based on software defined network according to claim 1, is characterized in that: in described step (4), the particular content of the independent pathway that SDN controller calculates between host A and host B is:
After described SDN controller gets the IP address information of all additional network interface card of host A and host B, determine that the access top-cross of described additional network interface card is changed planes according to this address information; Described switch marks out by SDN controller in the topology diagram of the SDN described in obtaining, the source point representing transmitting terminal is added in described topology diagram, add the meeting point representing receiving terminal, then add between the access top-cross of all network interface cards of source point and transmitting terminal is changed planes and connect, adding between the access top-cross of all network interface cards of meeting point and receiving terminal is changed planes equally and connect, so just obtaining the path computing structure chart for calculating the incoherent independent pathway of link;
Transmitting terminal and receiving terminal all have multiple network interface cards, be equivalent to the superposition of multiple 0-1 flow problem, according to foregoing path computing structure chart, if in source point-switch-link by flow be Q, in same meeting point-switch-link by flow be also Q, wherein Q is the integer much larger than 1, if in switch-switch link by flow be 1, so the host A described in calculating and the incoherent path of link between host B have just been simplified to non-directed graph maximum flow problem, solve by Dinic algorithm.
3. a kind of multi-path transmission method based on software defined network according to claim 1, is characterized in that: the concrete form of the stream table of the independent pathway P that the SDN controller described in described step (7) generates is as follows:
Stream table is divided into level Four, every one-level stream table is made up of many stream list items, each stream list item is one hexa-atomic group, is namely made up of six fields, respectively: matching domain field, precedence field, counter Counter field, instruction field, timer timeout field and Cookies field;
Wherein, matching domain field is mainly used to coupling bag, formed by the incorporating aspects in ethernet type, IP protocol number, IPv4 source address, IPv4 destination address, tcp source port and TCP destination interface six parameters, be specially: the matching domain field of first order stream table is made up of ethernet type and IPv4 source address, the matching domain field of second level stream table is made up of ethernet type and IPv4 destination address, the matching domain field of third level stream table is made up of IP protocol number and TCP destination interface, and the matching domain field of fourth stage stream table is made up of IP protocol number and tcp source port;
Precedence field defines the priority of every bar stream list item, the stream list item priority match bag that priority is high;
Counter Counter field is mainly used to the number of adding up the packet that this stream list item mated;
Instruction field is divided into goto and output two kinds of instruction types, and goto instruction type is used for the first order, the second level and third level stream table, and be used to refer to next stage stream table, output instruction type is used for fourth stage stream table, is used to specify the switch ports themselves of output;
Timer timeout field is divided into idle_timeout and hard_timeout two kinds of timer types, and how long afterwards the idle_timeout timer type stated free time inefficacy of this stream list item, and hard_timeout timer specifies to flow the total residence time of list item;
Cookie field mainly can allow controller distinguish not homogeneous turbulence list item;
Second level stream table tableA represents, third level stream table tableB represents, fourth stage stream table tableC represents;
First order stream table has and only has one, is responsible for Match IP v4 source address, realizes the differentiation to sending network interface card, and the number of its stream list item equals the network interface card total number of communicating pair use; The value of its instruction goto field is tableA, i.e. second level stream table;
Matching domain IPv4 destination address is responsible for by second level stream table, achieves a butt joint and receives the differentiation of network interface card, and its number flowing list item equals the network interface card total number that communicating pair uses, and the value of its instruction goto field is tableB, i.e. third level stream table;
Coupling TCP destination interface is responsible for by third level stream table, and the value of its instruction goto field is tableC, i.e. fourth stage stream table;
Fourth stage stream table is responsible for mating tcp source port, and the value of its instruction output field is the port numbers in respective switch.
4. a kind of multi-path transmission method based on software defined network according to claim 1, is characterized in that: the particular content of described step (7) comprises following operator step:
(71) the SDN controller described in parses SYN message from the Packet_in message received, therefrom extract source IP address and object IP address, the network interface card information be connected with the MPTCP of current maintenance is mated, if the match is successful, then go to step (72), otherwise common path selection is carried out to it, is it and selects a best paths, carry out single path transmission;
(72) the SDN controller described in is according to source IP address and object IP address, judge the path whether can laid in addition in the independent pathway of the L bar optimum calculated at it, then do not stop, have from Packet_in message, then extract stream table number table_id, and judge it is the information which grade stream table is submitted to according to this stream table number table_id, if the information that first order stream table is submitted to then goes to step (73), if the information that second level stream table is submitted to then goes to step (74), if the information that third level stream table is submitted to then goes to step (75), if the information that fourth stage stream table is submitted to then goes to step (76), described stream table number table_id refers to the concrete numbering of second level stream table tableA, third level stream table tableB and fourth stage stream table tableC,
(73) the SDN controller described in produces the stream table number table_id of new second and third, level Four stream table, records; Then issue the stream list item pointing to new second level stream table to the first order stream table of described submission information, and issue stream list item to new second and third, level Four stream table, go to step (77);
(74) the SDN controller described in produces the stream table number table_id of third and fourth grade of new stream table, records; Then the second level stream table to described submission information issues the stream list item pointing to new third level stream table, and issues stream list item to third and fourth grade of new stream table, goes to step (77);
(75) the SDN controller described in produces the stream table number table_id of new fourth stage stream table, records; Then the third level stream table to described submission information issues the stream list item pointing to new fourth stage stream table, and issues stream list item to new fourth stage stream table, goes to step (77);
(76) the SDN controller described in issues stream list item to the fourth stage stream table of described submission information, goes to step (77);
(77) the openflow protocol switch that the SDN described in is relevant on described independent pathway P issues the stream list item carrying out forwarding.
5. a kind of multi-path transmission method based on software defined network according to claim 1 or 3, it is characterized in that: in described step (8), the process of openflow protocol switch deletion stream list item is as follows: when the timer timeout field of described stream list item exceedes certain hour, if do not have packet to flow through this stream list item, then this stream list item can be automatically left out.
CN201510818810.2A 2015-11-23 2015-11-23 A kind of multi-path transmission method based on software defined network Active CN105337857B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510818810.2A CN105337857B (en) 2015-11-23 2015-11-23 A kind of multi-path transmission method based on software defined network

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510818810.2A CN105337857B (en) 2015-11-23 2015-11-23 A kind of multi-path transmission method based on software defined network

Publications (2)

Publication Number Publication Date
CN105337857A true CN105337857A (en) 2016-02-17
CN105337857B CN105337857B (en) 2018-05-25

Family

ID=55288164

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510818810.2A Active CN105337857B (en) 2015-11-23 2015-11-23 A kind of multi-path transmission method based on software defined network

Country Status (1)

Country Link
CN (1) CN105337857B (en)

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105827527A (en) * 2016-03-14 2016-08-03 清华大学 Discovery and adjustment method for shared bottleneck path of MPTCP sub flows in SDN
CN105933227A (en) * 2016-06-29 2016-09-07 中国电子科技集团公司第五十四研究所 Methods for routing decision and flow table consistency optimization in software defined satellite network
CN106302021A (en) * 2016-08-18 2017-01-04 清华大学深圳研究生院 A kind of network flow forwards method for detecting abnormality
CN106301921A (en) * 2016-08-16 2017-01-04 清华大学 Elephant flow transmission dispatching method based on tunnel and system
CN106559330A (en) * 2016-01-22 2017-04-05 国网智能电网研究院 A kind of dynamic path planning method based on SDN
CN107204924A (en) * 2016-03-18 2017-09-26 华为技术有限公司 Link discovery method and device
WO2017161982A1 (en) * 2016-03-25 2017-09-28 华为技术有限公司 Method and device for multi-flow transmission in sdn network
CN107995108A (en) * 2016-10-27 2018-05-04 南宁富桂精密工业有限公司 Network path optimization method and SDN controllers
CN108011822A (en) * 2016-10-31 2018-05-08 南宁富桂精密工业有限公司 Multimedia data stream transmission optimization method and SDN controllers
CN108199970A (en) * 2017-12-15 2018-06-22 浙江大学 Packet path reconstructing method in a kind of software defined network
CN108512766A (en) * 2018-03-26 2018-09-07 南京邮电大学 A kind of OpenFlow interchangers flow table adjusting method
CN108574615A (en) * 2017-03-13 2018-09-25 华为软件技术有限公司 A kind of content transmission method, equipment and system based on multipath MPTCP
CN108989219A (en) * 2018-07-11 2018-12-11 中国人民解放军陆军工程大学 A kind of multipriority route forwarding system and method based on multilevel flow table
CN109257282A (en) * 2018-08-09 2019-01-22 北京邮电大学 A kind of data transmission method and device
CN109417513A (en) * 2017-03-24 2019-03-01 华为技术有限公司 The system and method for dynamic detection opposite end in software defined network
WO2019104788A1 (en) * 2017-11-28 2019-06-06 中国科学院声学研究所 Programmable network technology-based multi-homed network routing and forwarding method
CN110417653A (en) * 2019-07-29 2019-11-05 迈普通信技术股份有限公司 Message forwarding method, device and message transmission control method, device
CN109067758B (en) * 2018-08-23 2020-07-10 江苏大学 SDN network data transmission privacy protection system and method based on multiple paths
CN112968843A (en) * 2021-02-03 2021-06-15 长春理工大学 Multi-path transmission control system and method based on SDN
CN117439953A (en) * 2023-12-20 2024-01-23 珠海星云智联科技有限公司 Equivalent cost multi-path selection system, method, equipment, cluster and medium

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103746892A (en) * 2013-11-27 2014-04-23 北京邮电大学 SDN virtualization platform uplink signaling flow label processing method based on OpenFlow
US20150009830A1 (en) * 2013-07-08 2015-01-08 Telefonaktiebolaget L M Ericsson (Publ) Methods of operating load balancing switches and controllers using matching patterns with unrestricted characters
CN104579968A (en) * 2013-10-26 2015-04-29 华为技术有限公司 Method of SDN (Software Defined Network) exchanges to obtain precise flow table items, SDN exchange, controller and system

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20150009830A1 (en) * 2013-07-08 2015-01-08 Telefonaktiebolaget L M Ericsson (Publ) Methods of operating load balancing switches and controllers using matching patterns with unrestricted characters
CN104579968A (en) * 2013-10-26 2015-04-29 华为技术有限公司 Method of SDN (Software Defined Network) exchanges to obtain precise flow table items, SDN exchange, controller and system
CN103746892A (en) * 2013-11-27 2014-04-23 北京邮电大学 SDN virtualization platform uplink signaling flow label processing method based on OpenFlow

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
孟鑫蕊: "光与无线融合接入网多路径技术研究", 《硕士论文》 *

Cited By (35)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106559330B (en) * 2016-01-22 2020-06-16 国网智能电网研究院 SDN-based dynamic path planning method
CN106559330A (en) * 2016-01-22 2017-04-05 国网智能电网研究院 A kind of dynamic path planning method based on SDN
CN105827527A (en) * 2016-03-14 2016-08-03 清华大学 Discovery and adjustment method for shared bottleneck path of MPTCP sub flows in SDN
CN105827527B (en) * 2016-03-14 2019-04-02 清华大学 SDN network MPTCP subflow shares the discovery method of adjustment in bottleneck path
US10797986B2 (en) 2016-03-18 2020-10-06 Huawei Technologies Co., Ltd. Link discovery method and apparatus
CN107204924A (en) * 2016-03-18 2017-09-26 华为技术有限公司 Link discovery method and device
CN107204924B (en) * 2016-03-18 2020-09-25 华为技术有限公司 Link discovery method and device
WO2017161982A1 (en) * 2016-03-25 2017-09-28 华为技术有限公司 Method and device for multi-flow transmission in sdn network
US10680928B2 (en) 2016-03-25 2020-06-09 Huawei Technologies Co., Ltd. Multi-stream transmission method and device in SDN network
CN105933227A (en) * 2016-06-29 2016-09-07 中国电子科技集团公司第五十四研究所 Methods for routing decision and flow table consistency optimization in software defined satellite network
CN106301921A (en) * 2016-08-16 2017-01-04 清华大学 Elephant flow transmission dispatching method based on tunnel and system
CN106301921B (en) * 2016-08-16 2019-05-14 清华大学 Elephant flow transmission dispatching method and system based on tunnel
CN106302021B (en) * 2016-08-18 2020-03-31 清华大学深圳研究生院 Network flow forwarding abnormity detection method
CN106302021A (en) * 2016-08-18 2017-01-04 清华大学深圳研究生院 A kind of network flow forwards method for detecting abnormality
CN107995108B (en) * 2016-10-27 2021-07-13 南宁富桂精密工业有限公司 Network path optimization method and SDN controller
CN107995108A (en) * 2016-10-27 2018-05-04 南宁富桂精密工业有限公司 Network path optimization method and SDN controllers
CN108011822A (en) * 2016-10-31 2018-05-08 南宁富桂精密工业有限公司 Multimedia data stream transmission optimization method and SDN controllers
CN108574615A (en) * 2017-03-13 2018-09-25 华为软件技术有限公司 A kind of content transmission method, equipment and system based on multipath MPTCP
CN109417513A (en) * 2017-03-24 2019-03-01 华为技术有限公司 The system and method for dynamic detection opposite end in software defined network
US11522784B2 (en) 2017-11-28 2022-12-06 Institute Of Acoustics, Chinese Academy Of Sciences Routing and forwarding method for multi-homed network based on programmable network technology
WO2019104788A1 (en) * 2017-11-28 2019-06-06 中国科学院声学研究所 Programmable network technology-based multi-homed network routing and forwarding method
CN108199970B (en) * 2017-12-15 2020-08-04 浙江大学 Method for reconstructing data packet path in software defined network
CN108199970A (en) * 2017-12-15 2018-06-22 浙江大学 Packet path reconstructing method in a kind of software defined network
CN108512766B (en) * 2018-03-26 2020-09-11 南京邮电大学 OpenFlow switch flow table adjusting method
CN108512766A (en) * 2018-03-26 2018-09-07 南京邮电大学 A kind of OpenFlow interchangers flow table adjusting method
CN108989219A (en) * 2018-07-11 2018-12-11 中国人民解放军陆军工程大学 A kind of multipriority route forwarding system and method based on multilevel flow table
CN108989219B (en) * 2018-07-11 2021-09-28 中国人民解放军陆军工程大学 Multi-priority routing forwarding system and method based on multi-level flow table
CN109257282B (en) * 2018-08-09 2020-07-14 北京邮电大学 Data transmission method and device
CN109257282A (en) * 2018-08-09 2019-01-22 北京邮电大学 A kind of data transmission method and device
CN109067758B (en) * 2018-08-23 2020-07-10 江苏大学 SDN network data transmission privacy protection system and method based on multiple paths
CN110417653A (en) * 2019-07-29 2019-11-05 迈普通信技术股份有限公司 Message forwarding method, device and message transmission control method, device
CN112968843A (en) * 2021-02-03 2021-06-15 长春理工大学 Multi-path transmission control system and method based on SDN
CN112968843B (en) * 2021-02-03 2023-02-28 长春理工大学 Multi-path transmission control system and method based on SDN
CN117439953A (en) * 2023-12-20 2024-01-23 珠海星云智联科技有限公司 Equivalent cost multi-path selection system, method, equipment, cluster and medium
CN117439953B (en) * 2023-12-20 2024-03-26 珠海星云智联科技有限公司 Equivalent cost multi-path selection system, method, equipment, cluster and medium

Also Published As

Publication number Publication date
CN105337857B (en) 2018-05-25

Similar Documents

Publication Publication Date Title
CN105337857A (en) Multi-path transmission method based on software-defined network
Lin et al. A west-east bridge based SDN inter-domain testbed
CN106936709B (en) Remote service access path control method and relevant device
CN104518967B (en) Method for routing, equipment and system
EP3066784B1 (en) Supporting operator commands in link aggregation group
EP3437251B1 (en) Multipoint to multipoint trees for computed spring multicast
CN105634956B (en) A kind of message forwarding method, device and system
CN105357046A (en) Network information detection method for software defined networking (SDN)
EP2099180B1 (en) Switching device and method for Layer-2 forwarding of OAM frames with multicast Layer-3 addresses
PH12015502297B1 (en) A method and system for updating distributed resilient network interconnect (drni) states
Fiţigău et al. Network performance evaluation for RIP, OSPF and EIGRP routing protocols
CN107534605A (en) Method for selecting network connection concentrator
CN104579894B (en) The IGMP Snooping implementation methods and device of the distributed virtual switch system
CN106330727A (en) Method, device and system for establishing link of SDN (Software Defined Network) device
CN104023006A (en) Multi-path transmission system and method based on application layer relaying
CN110266828A (en) A kind of method, apparatus and network system for establishing end to end network connection
CN111435922B (en) Bandwidth sharing method
Ochoa-Aday et al. ETDP: Enhanced topology discovery protocol for software-defined networks
CN105450447B (en) A kind of network system and network operation method
CN116436850A (en) Message forwarding method, message processing method and device
CN110324159A (en) Link configuration method and controller
CN102457404B (en) Detect the methods, devices and systems of communication path MTU
CN108566390A (en) The implementation method and satellite message of a kind of satellite application layer security protocol are monitored and distribution service system
CN107566277A (en) Topological determination method, message responding method, controller and interchanger
Damanik Fast-recovery and optimization multipath circuit networks environments using routing policies different administrative distance and internal BGP

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant