Embodiments of this application relate to the communications field, and in particular, to a packet processing method and a related device.
In a networking architecture of a fifth generation mobile communications technology 5G network, the 5G network requires parts such as a terminal device, a base station, a bearer network, a core network, and a data network. After application information for network access of a user is sent from the terminal device to the base station, the base station first encapsulates the application information on the terminal device into a general packet radio system tunneling protocol user plane (GTP-U) tunnel to obtain a GTP-U packet, and then sends the GTP-U packet to a user plane function (UPF) network element of the core network through the bearer network. After receiving the packet, the UPF network element decapsulates the GTP-U packet and sends the application information to an external data network of the 5G network, or the UPF network element decapsulates the GTP-U packet, encapsulates the application information of the user into a new GTP-U tunnel, and then relays the application information to another UPF network element.
In a conventional technology, no matter whether application information of a user is transmitted between a base station and a UPF network element, or is transmitted between UPF network elements, the application information is transmitted by using a GTP-U packet. However, a bearer network responsible for data transmission cannot obtain application information of an inner layer part of the GTP-U packet. Consequently, the bearer network cannot directly identify the application information, and cannot provide differentiated services for a large quantity of applications.
Embodiments of this application provide a packet processing method, a first network device, and a second network device, to resolve a problem that a second network device cannot provide diversified network services for a first network device based on application information.
A first aspect of the embodiments of this application provides a packet processing method, including: A first network device generates a first packet, where a packet header of the first packet carries application information; and the first network device sends the first packet to a second network device, where the first packet is used to indicate the second network device to provide a network service based on the application information.
In this embodiment of this application, the packet header of the first packet sent by the first network device to the second network device carries the application information, and the second network device can obtain the related application information from the packet header of the first packet, and provide differentiated network services based on the application information, so that a personalized network service is matched based on a transmission requirement, thereby improving a degree of refinement of a network transmission service.
With reference to the first aspect, in a first embodiment of the first aspect of the embodiments of this application, the first packet includes a general packet radio system tunneling protocol user plane GTP-U packet, and the GTP-U packet is used in a mobile communications network.
In the mobile communications network, a packet sent by a base station to a UPF network element through a bearer network device may be a GTP-U packet, and the bearer network device may identify application information in a packet header of the GTP-U packet. This resolves a problem that a bearer network device cannot obtain application information of an inner layer data part (application layer data part) of a GTP-U packet.
With reference to the first aspect or the first embodiment of the first aspect, in a second embodiment of the first aspect of the embodiments of this application, before the first network device generates the first packet, the first network device receives a second packet, where an inner layer part of the second packet includes the application information, and the inner layer part of the packet refers to content of a packet data part that cannot be obtained through parsing by the second network device.
With reference to any one of the first aspect or the first embodiment or the second embodiment of the first aspect, in a third embodiment of the first aspect of the embodiments of this application, the first network device obtains the application information from the inner layer part of the second packet, and the first network device updates the application information to the packet header, where an update manner may be copying, adding, or modifying.
Specifically, after encapsulating the packet header, the first network device updates the application information to the existing packet header, or adds a new packet header, or may update the application information to the packet header and then encapsulate the packet header to obtain the first packet. This is not specifically limited herein.
Specifically, the packet header of the first packet may be a GTP-U packet header encapsulated by the first network device, a UDP packet header and/or an IP packet header, and another packet header. A location of the application information may be a GTP-U extension packet header of the GTP-U packet header and/or an IP extension packet header of the IP packet header, where the IP extension packet header includes an internet protocol version 6 (IPv6) extension packet header and an internet protocol version 4 (IPv4) packet header.
In this embodiment of this application, the application information carried in the packet header of the first packet sent by the first network device can be obtained by updating the application information carried in the received second packet, and the second packet may come from user equipment or another network device. The first network device decapsulates and re-encapsulates the received second packet to obtain the first packet, and the first network device can identify the application information from the user equipment. This improves a capability of perceiving an application of the user equipment in network transmission.
With reference to any one of the first aspect or the first embodiment to the third embodiment of the first aspect, in a fourth embodiment of the first aspect of the embodiments of this application, the packet header of the first packet includes a GTP-U extension packet header, an internet protocol version 4 IPv4 packet header, or an internet protocol version 6 IPv6 extension packet header.
In this embodiment of this application, a plurality of extension packet headers in the packet header of the first packet all can carry the application information. This improves applicability and feasibility of the solution.
In this embodiment of this application, if the packet header of the first packet is an IPv4 packet header or an IPv6 extension packet header, the following technical problem may be further resolved: When a parameter value of a path maximum transmission unit (Path MTU) of a transmission path between the first network device and a target network device to which the first packet is to be transmitted is small, for the first packet, a data packet may be fragmented for transmission, and the IPv4 packet header or the IPv6 extension packet header can avoid a case in which after the data packet is fragmented, only the first fragment carries the application information, thereby avoiding a case in which the second network device can provide the network service based on only the application information in the first fragment. This improves applicability of the solution in this embodiment of this application to an application scenario.
In this embodiment of this application, if the packet header of the first packet is an IPv4 packet header or an IPv6 extension packet header, when the first network device performs encryption, by using an internet protocol security (IPsec) technology, with the target network device to which the first packet is to be transmitted, the IPv4 packet header or the IPv6 extension packet header can prevent, after the application information is encrypted, the second network device from failing to identify the application information carried in the packet header of the first packet. This improves applicability of the solution in this embodiment of this application to an application scenario.
With reference to the fourth embodiment of the first aspect, in a fifth embodiment of the first aspect of the embodiments of this application, the GTP-U extension packet header includes an extension header length field, a next extension header type field, and an application information field, and the application information field includes the application information.
With reference to the fourth embodiment of the first aspect, in a sixth embodiment of the first aspect of the embodiments of this application, the GTP-U extension packet header includes an extension header length field, a next extension header type field, a reserved field, and an application information field, and the application information field includes the application information.
With reference to the fifth embodiment or the sixth embodiment of the first aspect, in a seventh embodiment of the first aspect of the embodiments of this application, the application information field starts from a (4*N+1)th byte in the GTP-U extension packet header, where N is an integer greater than or equal to 1, and a total field length of the GTP-U extension packet header is 4*M bytes, where M is an integer greater than N.
In this embodiment of this application, the total field length of the GTP-U extension packet header is an integer multiple of four bytes, and the application information field can be four-byte aligned, so that hardware processing performance can be effectively improved.
With reference to any one of the fifth embodiment to the seventh embodiment of the first aspect, in an eighth embodiment of the first aspect of the embodiments of this application, the total field length of the GTP-U extension packet header is 4*L bytes, where L is an integer greater than or equal to 1.
In this embodiment of this application, the extension header length field and the next extension header type field of the GTP-U extension packet header are followed by the application information field, and there is no reserved field used for padding. This saves a length of the reserved field, and reduces transmission overheads of the GTP-U packet.
With reference to the fourth embodiment of the first aspect, in a ninth embodiment of the first aspect of the embodiments of this application, the IPv4 packet header includes an option type field, an option length field, and an application information field, and the application information field includes the application information.
With reference to the ninth embodiment of the first aspect, in a tenth embodiment of the first aspect of the embodiments of this application, the IPv4 packet header further includes a reserved field, the application information field starts from a (4*N+1)th, byte in the IPv4 packet header, and a total field length of the IPv4 packet header is 4*P bytes, where P is an integer greater than N.
With reference to the ninth embodiment of the first aspect, in an eleventh embodiment of the first aspect of the embodiments of this application, the application information field starts from a (2*N+1)th byte in the IPv4 packet header, and a total field length of the IPv4 packet header is Q bytes, where Q is an integer greater than or equal to 2*N+1.
In this embodiment of this application, a length of the application information field in the IPv4 packet header is an integer multiple of four bytes, and the application information field can be four-byte aligned, so that hardware processing performance can be effectively improved.
With reference to any one of the first aspect or the first embodiment to the eleventh embodiment of the first aspect, in a twelfth embodiment of the first aspect of the embodiments of this application, the first network device includes a base station or a user plane function UPF.
With reference to any one of the first aspect or the first embodiment to the twelfth embodiment of the first aspect, in a thirteenth embodiment of the first aspect of the embodiments of this application, the second network device includes a bearer network device.
With reference to any one of the first aspect or the first embodiment to the thirteenth embodiment of the first aspect, in a fourteenth embodiment of the first aspect of the embodiments of this application, the application information includes one or more of a service-level agreement level SLA level, an application identifier APP ID, a user identifier user ID, a flow identifier flow ID, and a network performance parameter.
In this embodiment of this application, the packet header of the first packet may carry a plurality of types of application information. The second network device can provide diversified network transmission services for the first network device only based on rich application information. The rich application information improves accuracy and a degree of refinement of a network service.
A second aspect of the embodiments of this application provides a packet processing method, including: A second network device receives a first packet sent by a first network device, where a packet header of the first packet carries application information, and the second network device provides a network service for the first packet based on the application information.
In this embodiment of this application, the second network device can identify the application information in the packet header of the first packet, and provide differentiated network services based on the application information, so that a personalized network service is matched based on a transmission requirement, thereby improving a degree of refinement of a network transmission service.
With reference to the second aspect, in a first embodiment of the second aspect of the embodiments of this application, the second network device determines, based on the application information, a network slice used to transmit the first packet, where the network slice has a performance requirement corresponding to the application information.
In this embodiment of this application, the second network device can determine the network slice of the first packet based on the application information, where the network slice is a network resource dynamically allocated by a communications service operator, so that network transmission value of user equipment is improved to a maximum extent.
With reference to the second aspect or the first embodiment of the second aspect, in a second embodiment of the second aspect of the embodiments of this application, the second network device selects a quality of service QoS priority or a bandwidth guarantee policy for the first packet based on the application information.
In this embodiment of this application, the second network device can select the quality of service QoS priority or the bandwidth guarantee policy based on the application information. This ensures a transmission bandwidth, reduces a transmission delay, and reduces a packet loss rate, a delay jitter, and the like of data.
With reference to any one of the second aspect or the first embodiment or the second embodiment of the second aspect, in a third embodiment of the second aspect of the embodiments of this application, the second network device selects a traffic engineering TE transmission path for the first packet based on the application information.
In this embodiment of this application, the second network device can select the transmission path based on the application information, and dynamically reallocate a service flow quickly, accurately, and effectively based on a network topology. In particular, when a network line or device fault occurs, reliability of a network transmission process is improved.
With reference to any one of the second aspect or the first embodiment to the third embodiment of the second aspect, in a fourth embodiment of the second aspect of the embodiments of this application, the second network device enables in-situ flow information telemetry iFIT transmission quality monitoring based on the application information.
In this embodiment of this application, the second network device enables the in-situ flow information telemetry iFIT transmission quality monitoring based on the application information, to sense network service quality in real time, thereby fast demarcating and locating a network transmission service fault, and improving network quality of service.
With reference to any one of the second aspect or the first embodiment to the fourth embodiment of the second aspect, in a fifth embodiment of the second aspect of the embodiments of this application, the second network device performs traffic load balancing based on the application information, to determine the transmission path of the first packet.
In this embodiment of this application, the second network device performs traffic load balancing based on the application information, to more accurately eliminate load imbalance between servers, thereby improving a reaction speed and overall performance of a network system.
With reference to the first embodiment of the second aspect, in a sixth embodiment of the second aspect of the embodiments of this application, the second network device maps the application information to single network slice selection assistance information S-NSSAI, where the S-NSSAI identifies the network slice.
With reference to the fifth embodiment of the second aspect, in a sixth embodiment of the second aspect of the embodiments of this application, the second network device performs traffic load balancing by using the application information as a hash calculation parameter, to determine the transmission path of the first packet.
In this embodiment of this application, the second network device performs traffic load balancing by using the application information as the hash calculation parameter. The hash calculation parameter is added, so that hash calculation accuracy is improved, and a traffic load balancing result is optimized.
A third aspect of the embodiments of this application provides a first network device, where the first network device is used in a mobile communications network system, and the first network device includes:
a processing unit, configured to generate a first packet, where a packet header of the first packet carries application information; and
a sending unit, configured to send the first packet to a second network device, where the first packet is used to indicate the second network device to provide a network service based on the application information.
With reference to the third aspect, in a second embodiment of the third aspect of the embodiments of this application, the first network device includes a receiving unit, configured to receive a second packet, where an inner layer part of the second packet includes the application information.
With reference to the third aspect or the first embodiment of the third aspect, in a second embodiment of the third aspect of the embodiments of this application, the processing unit is further configured to obtain the application information from the inner layer part of the second packet, and the first network device updates the application information to the packet header of the first packet.
With reference to the third aspect or the first embodiment or the second embodiment of the third aspect, in a third embodiment of the third aspect of the embodiments of this application, the first packet includes a general packet radio system tunneling protocol user plane GTP-U packet.
A fourth aspect of the embodiments of this application provides a second network device, including:
a receiving unit, configured to receive a first packet sent by a first network device, where a packet header of the first packet carries application information; and
a processing unit, configured to provide a network service for the first packet based on the application information.
With reference to the fourth aspect, in a first embodiment of the fourth aspect of the embodiments of this application, the processing unit of the second network device is configured to perform one or more of the following:
determining, based on the application information, a network slice used to transmit the first packet, where the network slice has a performance requirement corresponding to the application information;
selecting a quality of service QoS priority or a bandwidth guarantee policy for the first packet based on the application information;
selecting a traffic engineering TE transmission path for the first packet based on the application information;
enabling in-situ flow information telemetry iFIT transmission quality monitoring based on the application information; or
performing traffic load balancing based on the application information, to determine a path for sending the first packet.
With reference to the fourth aspect or the first embodiment or the second embodiment of the fourth aspect, in a third embodiment of the fourth aspect of the embodiments of this application, the processing unit is configured to map the application information to single network slice selection assistance information S-NSSAI, where the S-NSSAI identifies the network slice.
With reference to the fourth aspect or the first embodiment to the third embodiment of the fourth aspect, in a fourth embodiment of the fourth aspect of the embodiments of this application, the processing unit of the second network device is configured to perform traffic load balancing by using the application information as a hash calculation parameter, to determine the path for sending the first packet.
A fifth aspect of the embodiments of this application provides a first network device, including a processor and a communications interface, where the processor is configured to execute instructions, so that the first network device performs the method provided in any one of the first aspect or the optional manners of the first aspect, and the communications interface is configured to receive or send a packet. For details of the first network device provided in the fifth aspect, refer to any one of the first aspect or the optional manners of the first aspect. Details are not described herein again.
A sixth aspect of the embodiments of this application provides a second network device, including a processor and a communications interface, where the processor is configured to execute instructions, so that the second network device performs the method provided in any one of the second aspect or the optional manners of the second aspect, and the communications interface is configured to receive or send a packet. For details of the second network device provided in the sixth aspect, refer to any one of the second aspect or the optional manners of the second aspect. Details are not described herein again.
A seventh aspect of the embodiments of this application provides a computer-readable storage medium. The computer-readable storage medium stores a program. When executing the program, a computer performs the method provided in any one of the first aspect or the optional manners of the first aspect.
An eighth aspect of the embodiments of this application provides a computer-readable storage medium. The computer-readable storage medium stores a program. When executing the program, a computer performs the method provided in any one of the second aspect or the optional manners of the second aspect.
A ninth aspect of the embodiments of this application provides a computer program product. When the computer program product is executed on a computer, the computer performs the method provided in any one of the first aspect or the optional manners of the first aspect.
A tenth aspect of the embodiments of this application provides a computer program product. When the computer program product is executed on a computer, the computer performs the method provided in any one of the second aspect or the optional manners of the second aspect.
An eleventh aspect of the embodiments of this application provides a chip. When the chip runs on a device, the device is enabled to perform the method provided in any one of the first aspect or the optional manners of the first aspect.
A twelfth aspect of the embodiments of this application provides a chip. When the chip runs on a device, the device is enabled to perform the method provided in any one of the second aspect or the optional manners of the second aspect.
An eleventh aspect of the embodiments of this application provides a network system. The network system includes the first network device provided in the third aspect or the fifth aspect and the second network device provided in the fourth aspect or the sixth aspect.
The following clearly and completely describes technical solutions in embodiments of this application with reference to the accompanying drawings in embodiments of this application. It is clear that the described embodiments are merely some but not all of embodiments of this application.
In this application, terms such as “first”, “second”, “third”, and “fourth” (if exists) in the specification, the claims, and the accompanying drawings are intended to distinguish between similar objects but do not necessarily indicate a specific order or sequence. It should be understood that data termed in such a way is interchangeable in proper circumstances so that embodiments described herein can be implemented in orders other than the order illustrated or described herein. Moreover, terms “include”, “contain” and any variants thereof mean to cover non-exclusive inclusion. For example, a process, method, system, product, or device that includes a list of operations or units is not necessarily limited to those expressly listed operations or units, but may include other operations or units that are not expressly listed or inherent to the process, method, product, or device.
In embodiments of this application, the word “example” or “for example” is used to represent giving an example, an illustration, or a description. Any embodiment or design scheme described as “in an example” or “for example” in embodiments of this application should not be explained as being more preferred or having more advantages than another embodiment or design scheme. Exactly, use of the word “example” or “for example” or the like is intended to present a relative concept in a specific manner.
Some terms in this application are described below, to help a person skilled in the art have a better understanding.
A terminal is also referred to as user equipment (UE), and is a device that provides a user with voice and/or data connectivity, for example, a handheld device or a vehicle-mounted device with a wireless connection function. Currently, some terminals are, for example, a mobile phone, a tablet computer, a notebook computer, a palmtop computer, a mobile Internet device (MID), and a wearable device such as a smart watch, a smart band, and a pedometer.
A radio access network (RAN) is a part of a network that connects a terminal to a wireless network. A RAN node or device is a node or device in the radio access network, and may also be referred to as a base station. The RAN implements a radio access technology. Conceptually, the RAN resides between a device (such as a mobile phone, a computer, or any remotely controlled machine), and provides a connection to a core network of the RAN. The RAN device includes but is not limited to: a node B in 5G (gNodeB, gNB), an evolved NodeB (eNB), a radio network controller (RNC), a node B (NB), a base station controller (BSC), a base transceiver station (BTS), a home base station (for example, home evolved NodeB, or home NodeB, HNB), a baseband unit (BBU), a transmitting and receiving point (TRP), a transmitting point (TP), a mobile switching center, and the like, and may further include a wireless fidelity (Wi-Fi) access point (AP) and the like.
A bearer network is a service data transmission network between an access network and a data network in a mobile communications network. A bearer network device includes but is not limited to a network edge device, a network core device, and a backbone device, for example, router products such as a broadband remote access server (BRAS), a cell site gateway (CSG), and a service router switch (SR).
The following describes related technologies in this application.
After user data for network access of a user is sent from the user equipment to the base station, the base station first encapsulates the user data into a GTP-U tunnel to generate a GTP-U packet, and then sends the GTP-U packet to a UPF network element in the core network. The user data in the GTP-U packet includes application information. That is, GTP-U inner layer data (namely, application layer data) includes the application information. The UPF network element processes the GTP-U packet and finally sends the user data to an external data network of the 5G network. After terminating a GTP-U tunnel from a wireless base station, the UPF network element may alternatively relay the GTP-U packet to another UPF network element through a new GTP-U tunnel, and then the UPF network element sends the user data to the data network.
N2 and N3 shown in
After receiving the packet sent by the user equipment, the base station first removes the 5G access protocol header to obtain an inner layer part of the packet, namely, an application layer data part. The base station then encapsulates a GTP-U packet header, a user datagram protocol (UDP) packet header and/or an internet protocol (IP) packet header, and another packet header based on the inner layer part of the packet to obtain a first packet. Then, the first packet is sent to a UPF network element of a core network through a bearer network device.
In
A packet header of the first packet is a packet header encapsulated by the base station, and includes but is not limited to the GTP-U packet header, the UDP packet header, or the IP packet header. First packets including the GTP-U packet header are collectively referred to as a GTP-U packet.
After receiving the first packet, the UPF network element in the core network decapsulates or removes a packet header of the first packet, and then forwards content corresponding to the first packet to the external data network. Alternatively, the UPF network element encapsulates a new GTP-U packet header, a new UDP packet header and/or a new IP packet header, and another packet header and then forwards content corresponding to the first packet obtained after the encapsulation to a next UPF network element, where UPFs of N6 interfaces are referred to as PDU session anchors. Between the base station and a UPF network element and between two UPF network elements, the bearer network device is responsible for transmitting the packet encapsulated in the GTP-U tunnel.
The base station maps the slice identifier S-NSSAI to a virtual local area network (VLAN) identifier or a differentiated services code point (DSCP) identifier of a GTP-U tunnel in an outer layer, and sends a packet of the GTP-U tunnel to a bearer network.
A bearer network device may process and forward a data packet by using a specified slice resource based on the VLAN identifier or the DSCP identifier, or a bearer network device may indirectly identify application information based on the VLAN identifier or the DSCP identifier. The bearer network device may transmit the first packet by using a slice network corresponding to the slice identifier (slice ID), for example, slice networks corresponding to a slice ID 1, a slice ID 2, and a slice ID 3. The bearer network device may alternatively forward the first packet through a virtual private network (VPN) or virtual routing and forwarding (VRF).
The following describes the technical solution provided in the embodiments by using a method 400.
401: A first network device receives a second packet.
For application to the network scenario shown in
The second packet received by the base station is a packet sent by user equipment to the base station.
In an example, the user equipment encapsulates a 5G access protocol header into a packet carrying application information, to obtain the second packet, the user equipment sends the second packet to the base station, and the base station receives the second packet sent by the user equipment.
402: The first network device generates a first packet, where a packet header of the first packet carries the application information.
The application information included in the first packet generated by the first network device may include one or more of the following, for example, a service-level agreement level (SLA level), an application identifier (APP ID), a user identifier (user ID), a flow identifier (flow ID), and a network performance parameter.
In an example, the first network device may generate the first packet, for example, a network connectivity detection packet, and add the application information to the packet, to indicate that the packet is the network connectivity detection packet. That is, operation 401 is an optional operation.
In another example, the first network device may receive the second packet sent by another device, and generate the first packet based on the second packet. The first network device generates the first packet based on the second packet in the following two cases:
Example A: The second packet sent by the user equipment may not carry the application information. In this case, after determining the application information based on the received second packet, the first network device may update the application information based on the second packet, to generate the first packet.
Example B: An inner layer part of the second packet carries the application information. The base station may update, to the packet header, the application information carried in the inner layer part of the second packet sent by the user equipment, to generate the first packet.
After receiving the second packet, the base station may first remove the 5G access protocol header of the second packet, to obtain the inner layer part of the second packet. The base station encapsulates the packet header into the inner layer part of the second packet to obtain the first packet, and the base station updates the packet header of the first packet.
The base station may update the packet header of the first packet before encapsulating the packet header or after encapsulating the packet header, or may update and encapsulate the packet header simultaneously. This is not specifically limited herein. There are a plurality of manners of updating the packet header by the base station, which may be copying, adding, or modifying. This is not specifically limited herein. Copying is used as an example. The base station may copy the application information of the inner layer part of the second packet to a GTP-U extension packet header, an IPv6 extension packet header, or an IPv4 packet header of the packet header of the first packet. This is not specifically limited herein.
A format of the GTP-U extension packet header, the IPv6 extension packet header, or the IPv4 packet header obtained through the copying is consistent with a corresponding packet format described in this embodiment of this application.
The base station may copy the application information to one location in the packet header of the first packet, or may copy the application information to a plurality of locations. This is not specifically limited herein.
In an example, the application information may be carried in inner layer data, namely, application layer data, of the second packet. When the application information is carried in the inner layer data of the second packet, the application information may be carried in an IPv6 extension header of an IPv6 service packet, and may be carried in an IPv6 hop-by-hop option extension header, an IPv6 destination option extension header, an IPv6 routing extension header, another IPv6 extension header, or a TLV extensible sub-option thereof. This is not specifically limited herein.
In this embodiment of this application, a network in which the application information is carried in the extension header of the IPv6 service packet may be referred to as application-aware IPv6 networking (APN6), and the application information carried in the packet of the APN6 is referred to as APN6 application information.
In an example, if a packet of user equipment is to carry the application information, a 5G network system may complete a pre-process of user plane work, including: an application provider or an application user purchases an application-aware IPv6 networking (APN6) service. A network service provider allocates APN6 application information, the application provider delivers the application information to or pre-configures the application information for an application (APP) of the user equipment, and the network service provider configures, in a 5G network, a network resource or service required by the APN6 service, for example, a slice, quality of service (QoS), a transmission path, or in-situ flow information telemetry (iFIT) performance monitoring. The network service provider associates the resource with the APN6 service.
After the foregoing pre-process is completed, the APP of the user equipment notifies, by using a software development kit (SDK), an operating system application programming interface (API), or a device driver interface, a terminal device of the APN6 application information that is to be carried in a data packet to be sent by the terminal device.
For carrying the application information in the packet header of the first packet, the following uses the APN6 application information as an example. When the first packet is a GTP-U packet, a format of an extension header carrying the application information in the packet header of the first packet is described.
1. GTP-U Extension Packet Header
In this embodiment of this application, the GTP-U extension packet header includes two formats, which are separately described below.
2.1. Format 1 of the GTP-U Extension Packet Header
The GTP-U extension packet header in the first format starts with an extension header length field of one byte and ends with a next extension header type field of one byte.
The GTP-U extension packet header in the first format further includes a reserved field and an application information field, and the GTP-U extension packet header has a length of an integer multiple of four bytes and/or is four-byte aligned after a line break. The application information field starts after a line break following the extension header length field and is four-byte aligned. A field part that is less than four bytes in each line is padded with a reserved field.
It can be understood that, the application information field in the GTP-U extension packet header in
The application information field in the format 1 starts after a line break following the extension header length field and is four-byte aligned. This helps improve hardware processing performance.
2.2. Format 2 of the GTP-U Extension Packet Header
The GTP-U extension packet header in the second format starts with an extension header length field of one byte and ends with a next extension header type field of one byte.
The GTP-U extension packet header in the second format further includes a reserved field and an application information field, and the GTP-U extension packet header has a length of an integer multiple of four bytes and is four-byte aligned after a line break. The application information field follows the extension header length field, and a field part whose end line is less than four bytes is padded with a reserved field.
In the format 2, the application information field does not have a line break after the extension header length field, so that a reserved field without an actual meaning is reduced. This can reduce transmission overheads. The format 1 may be used when a benefit of reducing the transmission overheads of the reserved field is not obvious.
2. IPv4 Packet Header
In this embodiment of this application, the IPv4 packet header includes two formats, which are separately described below.
2.1. Format 1 of the IPv4 Packet Header
The IPv4 packet header in the first format starts with an option type field with one byte and an option length field with one byte. The option type field and the option length field are followed by a reserved field and an application information field. The application information field starts after a line break following the reserved field and is four-byte aligned. The entire IPv4 packet header field has a length of an integer multiple of four bytes and follows a line break by four bytes. A field part that is less than four bytes in each line is padded with a reserved field.
3.2. Format 2 of an Option Extension Header of IPv4
The IPv4 packet header in the second format starts with an option type field with one byte and an option length field with one byte.
The option type field and the option length field are followed by an application information field, and there is no other field in between. The application information field starts after a line break following the option length field and is four-byte aligned.
3. IPv6 Extension Packet Header
The IPv6 extension packet header in this embodiment of this application includes a next extension header field, an extension header length field, an option type field, an option length field, and an application information field. The entire IPv6 extension packet has a length of an integer multiple of four bytes and is four-byte aligned.
403: The first network device sends the first packet to a second network device, where the packet header of the first packet carries the application information.
For application to the scenario shown in
404: The second network device provides a network service based on the application information in the packet header of the first packet.
For application to the scenario shown in
The bearer network device may provide a plurality of forms of network services based on the application information in the packet header of the first packet. The network services include: determining, based on the application information, a network slice used to transmit the first packet, selecting a quality of service QoS priority or a bandwidth guarantee policy for the first packet, selecting a transmission path for the first packet, enabling in-situ flow information telemetry iFIT transmission quality monitoring, and performing traffic load balancing, to determine the transmission path for the first packet. This is not specifically limited herein.
In this embodiment of this application, the bearer network device may provide the plurality of forms of network services based on the application information. The network services are separately described below.
1. The bearer network device determines a network slice based on the application information.
That the bearer network device determines a network slice based on the application information includes: the bearer network device maps the application information to the network slice. Several different mapping rules are separately described below.
Table 1 provides an example of five pieces of application information, respectively corresponding to five applications. For example, “SLA Level=7, App ID=1, User ID=3, Flow ID=6” corresponds to game 1. Numbers in the table represent ID numbers, and meanings of the numbers may be predefined.
1.1. One Piece of Application Information is Mapped to One Slice to Form an Application-Level Slice
The application information in Table 1 is used as an example. The bearer network device may map each piece of application information to a single network slice to form an application-level slice.
Table 2 provides an example of mapping the five pieces of application information in Table 1 to five network slices. After allocation, each application exclusively uses one network slice and a network service corresponding to the slice.
1.2. A Plurality of Pieces of Application Information are Mapped to a Group of Slices to Form Application Type-Level Slices
The application information in Table 1 is used as an example. The bearer network device may map a group of application information to a single network slice to form an application type-level slice.
In Table 3, three pieces of application information corresponding to the applications “game 1”, “game 2”, and “game 3” are used as a group of application information and mapped to “slice 6”. Application information corresponding to the applications “live broadcast 1” and “live broadcast 2” is mapped to “slice 7”. After mapping, application information of a same type of application shares one network slice, and the bearer network may provide a corresponding network service based on an application type.
1.3. All Application Information is Mapped to One Slice to Form an Application Awareness-Level Slice
The application information in Table 1 is used as an example. The bearer network device may map all the application information to a single network slice to form an application awareness-level slice.
Table 4 maps all the application information to “slice 8”. After mapping, all the application information shares one network slice.
1.4. A Plurality of Pieces of Application Information is Mapped to One Slice Based on Content of the Application Information to Form an Application Quality of Service-Level Slice
The application information in Table 1 is used as an example. The bearer network device may map application information whose values of “SLA level” are the same in the plurality of pieces of application information to a single network slice to form an application quality of service-level slice.
In Table 5, application information with a same “SLA level” value in the five pieces of application information is mapped to “slice 10”. After mapping, applications with the same “SLA level” value share one network slice.
Referring to Table 6, the bearer network device may alternatively map one or a combination of a plurality of values of “SLA Level”, “App ID”, “User ID”, or “Flow ID” in the plurality of pieces of application information, as a group of information, to a single network slice, to form a quality of service-level network slice.
2. The Bearer Network Device Uses Different QoS Levels Based on Application Information
The application information in Table 1 is used as an example. The bearer network device selects a QoS priority based on the application information.
Table 7 provides an example of quality of service QoS priorities corresponding to a plurality of pieces of application information.
3. The Bearer Network Device Uses a Bandwidth Guarantee Policy Based on Application Information
The application information in Table 1 is used as an example. The bearer network device may select a bandwidth guarantee policy based on the application information.
Table 8 provides an example of bandwidth policies corresponding to a plurality of pieces of application information. For example, the bearer network device selects, based on application information “SLA Level=7, App ID=1, User ID=3, Flow ID=6” corresponding to “game 1”, a corresponding bandwidth transmission policy of 100 Mbit/s for a first packet including the application information.
4. The Bearer Network Device Selects a Transmission Path Based on the Application Information
The application information in Table 1 is used as an example. The bearer network device may select a transmission path based on the application information.
Path 1: R1→R2→R5
Path 2: R1→R5
Path 3: R1→R3→R4→R5
Table 9 provides an example of selecting, by the bearer network device, a traffic engineering transmission path for the first packet based on application information.
5. The Bearer Network Device Enables In-Situ Flow Information Telemetry iFIT Transmission Quality Monitoring Based on the Application Information
Table 10 provides an example of enabling, by the bearer network device, an in-situ flow information telemetry iFIT service based on application information.
The bearer network device may enable in-situ flow information telemetry iFIT transmission quality monitoring based on the application information. For example, an in-situ flow information telemetry iFIT service enabled by the bearer network device based on application information “SLA Level=7, App ID=1, User ID=3, Flow ID=6” corresponding to “game 1” is “The iFIT service is enabled and detection is performed once every second”.
6. The Bearer Network Device Performs Traffic Load Balancing Based on the Application Information, to Determine a Transmission Path of the First Packet
The network topology shown in
The bearer network device may perform hash calculation for a source IP address, a destination IP address, a transport layer protocol type, a transport layer source port number, a transport layer destination port number, and the application information, may perform hash calculation for a source IP address, a destination IP address, and the application information, or may perform hash calculation only for the application information. This is not specifically limited herein.
For example, the bearer network device performs hash calculation for the source IP address, the destination IP address, and the application information. For example, the five pieces of application information in Table 1 correspond to traffic of five types of application information with a same source IP address and a same destination IP address. If only the source IP address and the destination IP address are used for hash calculation, a same result is obtained, and normalized mapping to only one transmission path can be implemented based on the result. However, after the bearer network device uses the application information as an input parameter for the hash calculation, five different results are obtained. That is, five types of traffic may be mapped to three transmission paths to achieve traffic load balancing.
After operation 404 is performed, the bearer network device forwards the first packet to a UPF network element, and the UPF network element may decapsulate the packet header of the first packet, then encapsulate a new packet header into the first packet, and send the first packet to another UPF network element through the bearer network device. A process of encapsulating the packet header is similar to a operation performed by the base station in operation 402, and details are not described herein again.
The UPF may alternatively decapsulate the packet header of the first packet, and process the first packet for sending to a data network.
In the foregoing embodiment, a working process is in an uplink direction from user equipment to the data network. A data plane working process in a downlink direction from the data network to the user equipment is similar thereto, and details are not described herein again.
The foregoing describes the packet processing method in the embodiments of this application. The following describes a network device in the embodiments of this application. The network device described below has any function of the first network device or the second network device in the packet processing method.
The modules in the network device 1800 and the foregoing other operations and/or functions are respectively used to implement various operations and methods implemented by the first network device in the method embodiments. For details, refer to the foregoing packet processing method. For brevity, details are not described herein again.
When the network device 1800 processes a packet, division of the foregoing functional modules is used only as an example for description. During actual application, the foregoing functions may be allocated to different functional modules for accomplishment according to a requirement, that is, an internal structure of the network device 1800 is divided into different functional modules, to accomplish all or some of the functions described above. In addition, the network device 1800 provided in the foregoing embodiment and the foregoing packet processing method belong to a same concept. For an embodiment of a process thereof, refer to the method 400. Details are not described herein again.
The modules in the network device 1900 and the foregoing other operations and/or functions are respectively used to implement various operations and methods implemented by the second network device in the method embodiments. For details, refer to the foregoing packet processing method. For brevity, details are not described herein again.
When the network device 1900 processes a packet, division of the foregoing functional modules is used only as an example for description. During actual application, the foregoing functions may be allocated to different functional modules for accomplishment according to a requirement, that is, an internal structure of the network device 1900 is divided into different functional modules, to accomplish all or some of the functions described above. In addition, the network device 1900 provided in the foregoing embodiment and the foregoing packet processing method belong to a same concept. For an example embodiment, refer to the foregoing packet processing method. Details are not described herein again.
Corresponding to the method embodiment and the virtual apparatus embodiment provided in this application, an embodiment of this application further provides a network device. The following describes a hardware structure of the network device.
A network device 2000 or a network device 2100 described below corresponds to the first network device or the second network device in the foregoing method embodiments. Hardware and modules in the network device 2000 or the network device 2100, and the foregoing other operations and/or functions are respectively used to implement various operations and methods implemented by the network device 2000 or the network device 2100 in the method embodiments. For an example of a detailed procedure of how the network device 2000 or the network device 2100 processes a packet, refer to the foregoing method embodiments. For brevity, details are not described herein again. The operations of the foregoing packet processing method are completed by using an integrated logic circuit of hardware or instructions in a form of software in a processor of the network device 2000 or the network device 2100. The operations in the methods disclosed with reference to embodiments of this application may be directly performed and completed by a hardware processor, or may be performed and completed by a combination of hardware in the processor and a software module. The software module may be located in a mature storage medium in the art, such as a random access memory, a flash memory, a read-only memory, a programmable read-only memory, an electrically erasable programmable memory, or a register. The storage medium is located in the memory, and the processor reads information in the memory and completes the operations of the foregoing method in combination with hardware of the processor. To avoid repetition, details are not described herein again.
The network device 2000 or the network device 2100 corresponds to the network device 1800 or the network device 1900 in the foregoing virtual apparatus embodiments, and each functional module of the network device 1800 or the network device 1900 is implemented by using software of the network device 2000 or the network device 2100. In other words, the functional modules included in the network device 1800 or the network device 1900 are generated after the processor of the network device 2000 or the network device 2100 reads program code stored in a memory.
The network device 2000 includes at least one processor 2001, a communications bus 2002, a memory 2003, and at least one communications interface 2004.
The processor 2001 may be a general-purpose CPU, an NP, or a microprocessor, or may be one or more integrated circuits configured to implement the solutions of this application, for example, an application-specific integrated circuit (ASIC), a programmable logic device (PLD), or a combination thereof. The PLD may be a complex programmable logic device (CPLD), a field-programmable gate array (FPGA), generic array logic (GAL), or any combination thereof.
The communications bus 2002 is configured to transfer information between the foregoing components. The communications bus 2002 may be classified into an address bus, a data bus, a control bus, or the like. For ease of representation, only one bold line is used to represent the bus in the figure, but it does not mean that there is only one bus or only one type of bus.
The memory 2003 may be a read-only memory (ROM) or another type of static storage device that can store static information and/or instructions, or a random access memory (RAM) or another type of dynamic storage device that can store information and/or instructions. Alternatively, the memory 2003 may be an electrically erasable programmable read-only memory (EEPROM), a compact disc read-only memory (CD-ROM) or another compact disc storage, an optical disc storage (including a compact optical disc, a laser disc, an optical disc, a digital versatile disc, a Blu-ray disc, and the like), a magnetic disk storage medium or another magnetic storage device, or any other medium that can be configured to carry or store expected program code in a form of an instruction or a data structure and that can be accessed by a computer. However, the memory 2003 is not limited thereto. The memory 2003 may exist independently, and is connected to the processor 2001 by using the communications bus 2002. The memory 2003 may alternatively be integrated with the processor 2001.
The communications interface 2004 is configured to communicate with another device or a communications network by using any transceiver-type apparatus. The communications interface 2004 includes a wired communications interface, and may further include a wireless communications interface. The wired communications interface may be, for example, an Ethernet interface. The Ethernet interface may be an optical interface, an electrical interface, or a combination thereof. The wireless communications interface may be a wireless local area network (WLAN) interface, a cellular network communications interface, a combination thereof, or the like.
In an embodiment, the processor 2001 may include one or more CPUs, such as a CPU 0 and a CPU 1 shown in
In an embodiment, the network device 2000 may include a plurality of processors, for example, a processor 2001 and a processor 2005 shown in
In an embodiment, the network device 2000 may further include an output device 2006 and an input device 2007. The output device 2006 communicates with the processor 2001, and may display information in a plurality of manners. For example, the output device 2006 may be a liquid crystal display (LCD), a light emitting diode (LED) display device, a cathode ray tube (CRT) display device, or a projector. The input device 2007 communicates with the processor 2001 and may receive input from a user in a plurality of manners. For example, the input device 2007 may be a mouse, a keyboard, a touchscreen device, or a sensor device.
In some embodiments, the memory 2003 is configured to store program code 2010 for executing the solutions of this application, and the processor 2001 may execute the program code 2010 stored in the memory 2003. In other words, the network device 2000 may implement the packet processing method provided in the method embodiments by using the processor 2001 and the program code 2010 in the memory 2003.
The network device 2000 in this embodiment of this application may correspond to the first network device or the second network device in the foregoing method embodiments, and the processor 2001, the communications interface 2004, and the like in the network device 2000 may implement functions of the first network device or the second network device in the foregoing method embodiments and/or various operations and methods implemented in the foregoing method embodiments. For ease of brevity, details are not described herein again.
The sending unit 1802 in the network device 1800 is equivalent to the communications interface 2004 in the network device 2000. The processing unit 1801 in the network device 1800 may be equivalent to the processor 2001 in the network device 2000.
The receiving unit 1901 in the network device 1900 is equivalent to the communications interface 2004 in the network device 2000. The processing unit 1902 in the network device 1900 may be equivalent to the processor 2001 in the network device 2000.
The main control board 2110 is also referred to as a main processing unit (MPU) or a route processor card. The main control board 2110 is configured to control and manage components in the network device 2100, including route computation, device management, device maintenance, and a protocol-based processing function. The main control board 2110 includes a central processing unit 2111 and a memory 2112.
The interface board 2130 is also referred to as a line processing unit (LPU), a line card, or a service board. The interface board 2130 is configured to provide various service interfaces, and forward a data packet. The service interface includes but is not limited to an Ethernet interface, a POS (Packet over SONET/SDH) interface, and the like. The Ethernet interface is, for example, a flexible Ethernet service interface (Flexible Ethernet Clients, FlexE Clients). The interface board 2130 includes a central processing unit 2131, a network processor 2132, a forwarding entry memory 2134, and a physical interface card (PIC) 2133.
The central processing unit 2131 on the interface board 2130 is configured to control and manage the interface board 2130 and communicate with the central processing unit 2111 on the main control board 2110.
The network processor 2132 is configured to implement forwarding processing of a packet. A form of the network processor 2132 may be a forwarding chip. Specifically, the network processor 2132 is configured to forward a received packet based on a forwarding table stored in the forwarding entry memory 2134. If a destination address of the packet is an address of the network device 2100, the network processor 2132 sends the packet to a CPU (for example, the central processing unit 2111) for processing. If the destination address of the packet is not the address of the network device 2100, the network processor 2132 searches for, based on the destination address, a next hop and an outbound interface corresponding to the destination address in the forwarding table, and forwards the packet to the outbound interface corresponding to the destination address. An uplink packet is processed as follows: Processing is performed over an inbound interface of the packet, and the forwarding table is searched. A downlink packet is processed as follows: The forwarding table is searched, and so on.
The physical interface card 2133 is configured to implement a physical layer interconnection function. Original traffic enters the interface board 2130 from the physical interface card 2133, and a processed packet is sent out from the physical interface card 2133. The physical interface card 2133, also referred to as a subcard, may be installed on the interface board 2130, and is responsible for converting a photoelectric signal into a packet, performing a validity check on the packet, and forwarding the packet to the network processor 2132 for processing. In some embodiments, the central processing unit may also perform a function of the network processor 2132, for example, implement software forwarding based on a general-purpose CPU, so that the network processor 2132 is not required in the physical interface card 2133.
In some embodiments, the network device 2100 includes a plurality of interface boards. For example, the network device 2100 further includes an interface board 2140. The interface board 2140 includes a central processing unit 2141, a network processor 2142, a forwarding entry memory 2144, and a physical interface card 2143.
In some embodiments, the network device 2100 further includes a switching board 2120. The switching board 2120 may also be referred to as a switch fabric unit (SFU). When the network device has a plurality of interface boards 2130, the switching board 2120 is configured to implement data exchange between the interface boards. For example, the interface board 2130 and the interface board 2140 may communicate with each other by using the switching board 2120.
The main control board 2110 is coupled to the interface board 2130. For example, the main control board 2110, the interface board 2130, the interface board 2140, and the switching board 2120 are connected to a system backplane by using a system bus. In a possible embodiment, an inter-process communication (IPC) channel is established between the main control board 2110 and the interface board 2130, and communication is performed between the main control board 2110 and the interface board 2130 through the IPC channel.
Logically, the network device 2100 includes a control plane and a forwarding plane. The control plane includes the main control board 2110 and the central processing unit 2131. The forwarding plane includes components that perform forwarding, such as the forwarding entry memory 2134, the physical interface card 2133, and the network processor 2132. The control plane performs functions such as a function of a router, generating a forwarding table, processing signaling and protocol packets, and configuring and maintaining a status of the device. The control plane delivers the generated forwarding table to the forwarding plane. On the forwarding plane, the network processor 2132 searches the forwarding table delivered by the control plane to forward a packet received by the physical interface card 2133. The forwarding table delivered by the control plane may be stored in the forwarding entry memory 2134. In some embodiments, the control plane and the forwarding plane may be totally separated, and are not on a same device.
If the network device 2100 is configured as the first network device, the physical interface card 2133 receives a second packet, and sends the second packet to the network processor 2132. The network processor 2132 generates a first packet based on the second packet, and sends the packet out by using the physical interface card 2133, so that the first packet is transmitted to a second network device.
If the network device 2100 is configured as the second network device, the physical interface card 2133 receives the first packet, and sends the first packet to the network processor 2132. The network processor 2132 obtains application information from a packet header of the first packet, and provides a network service for the first packet based on the application information.
The sending unit 1802 in the network device 1800 is equivalent to the physical interface card 2133 in the network device 2100. The processing unit 1801 in the network device 1800 may be equivalent to the network processor 2132 or the central processing unit 2111.
The receiving unit 1901 in the network device 1900 is equivalent to the physical interface card 2133 in the network device 2100. The processing unit 1902 in the network device 1900 may be equivalent to the network processor 2132 or the central processing unit 2111.
In this embodiment of this application, an operation on the interface board 2140 is consistent with an operation on the interface board 2130. For brevity, details are not described again. The network device 2100 in this embodiment may correspond to the first network device or the second network device in the foregoing method embodiments. The main control board 2110 and the interface board 2130 and/or the interface board 2140 in the network device 2100 may implement functions of the first network device or the second network device and/or various operations implemented in the foregoing method embodiments. For brevity, details are not described herein again.
It should be noted that, there may be one or more main control boards. When there are a plurality of main control boards, the main control boards may include an active main board and a standby main board. There may be one or more interface boards. The network device having a stronger data processing capability provides more interface boards. There may also be one or more physical interface cards on the interface board. There may be no switching board, or there may be one or more switching boards. When there are a plurality of switching boards, load sharing and redundancy backup may be implemented together. In a centralized forwarding architecture, the network device may not need the switching board, and the interface board provides a function of processing service data in an entire system. In a distributed forwarding architecture, the network device may have at least one switching board, and data exchange between a plurality of interface boards is implemented by using the switching board, to provide a large-capacity data exchange and processing capability. Therefore, a data access and processing capability of the network device in the distributed architecture is greater than that of a device in the centralized architecture. In some embodiments, the network device may alternatively be in a form in which there is only one card. To be specific, there is no switching board, and functions of the interface board and the main control board are integrated on the card. In this case, a central processing unit on the interface board and a central processing unit on the main control board may be combined to form one central processing unit on the card, to perform functions obtained after the two central processing units are combined. This form of device (for example, a network device such as a low-end switch or a router) has a weak data exchange and processing capability. A specific architecture that is to be used depends on a specific networking deployment scenario. This is not limited herein.
In some possible embodiments, the first network device or the second network device may be implemented as a virtualized device.
For example, the virtualized device may be a virtual machine (VM) on which a program having a packet sending function is run, and the virtual machine is deployed on a hardware device (for example, a physical server). The virtual machine is a complete computer system that is simulated by software, that has a complete hardware system function, and that runs in a totally isolated environment. The virtual machine may be configured as the first network device or the second network device. For example, the first network device or the second network device may be implemented based on a general-purpose physical server in combination with a network functions virtualization (NFV) technology. The first network device or the second network device is a virtual host, a virtual router, or a virtual switch. After reading this application, with reference to the NFV technology, a person skilled in the art may virtualize, on the general-purpose physical server, the first network device or the second network device having the foregoing functions. Details are not described herein again.
For example, the virtualized device may be a container, and the container is an entity used to provide an isolated virtualized environment. For example, the container may be a docker container. The container may be configured as the first network device or the second network device. For example, the first network device or the second network device may be created by using a corresponding image, for example, two container instances, respectively a container instance proxy-container 1 and a container instance proxy-container 2, may be created for a proxy-container by using an image of the proxy-container (a container that provides a proxy service). The container instance proxy-container 1 is provided as the first network device or a first computing device, and the container instance proxy-container 2 is provided as the second network device or a second computing device. When a container technology is used for implementation, the first network device or the second network device may run by using a kernel of a physical machine, and a plurality of first network devices or second network devices may share an operating system of the physical machine. Different first network devices or different second network devices may be isolated by using the container technology. A containerized first network device or second network device may run in a virtualized environment, for example, may run in a virtual machine. Alternatively, the containerized first network device or second network device may directly run in the physical machine.
For example, the virtualized device may be a pod. The pod is a basic unit of Kubernetes (Kubernetes is an open-source container orchestration engine of Google, and may be referred to as K8s) for deploying, managing, and orchestrating a containerized application. The pod may include one or more containers. All containers in a same pod are usually deployed on a same host. Therefore, all the containers in the same pod may communicate with each other through the host, and may share storage resources and network resources of the host. The pod may be configured as the first network device or the second network device. For example, a container as a service may be instructed (CaaS, which is a container-based PaaS service) to create a Pod, and the pod is provided as the first network device or the second network device.
Certainly, the first network device or the second network device may alternatively be another virtualized device, which is not enumerated herein one by one.
In some possible embodiments, the first network device or the second network device may alternatively be implemented by a general-purpose processor. For example, the general-purpose processor may be in a form of a chip. Specifically, the general-purpose processor implementing the first network device or the second network device includes a processing circuit, and an input interface and an output interface that are internally connected to and communicated with the processing circuit. The processing circuit is configured to perform the packet generation operation in the foregoing method embodiments by using the input interface. The processing circuit is configured to perform the receiving operation in the foregoing method embodiments by using the input interface. The processing circuit is configured to perform the sending operation in the foregoing method embodiments by using the output interface. In some embodiments, the general-purpose processor may further include a storage medium. The processing circuit is configured to perform the storage operation in the foregoing method embodiments by using the storage medium. The storage medium may store instructions executed by the processing circuit. The processing circuit is configured to execute the instructions stored in the storage medium, to perform the foregoing method embodiments.
Referring to
An embodiment of this application provides a computer program product. When the computer program product runs on a first network device or a second network device, the first network device or the second network device is enabled to perform the packet processing method in the foregoing method embodiments.
The network devices in the foregoing product forms respectively have any functions of the first network device or the second network device in the foregoing method embodiments. Details are not described herein again.
A person of ordinary skill in the art may be aware that, the method operations and units described in embodiments disclosed in this specification may be implemented by electronic hardware, computer software, or a combination thereof. To clearly describe the interchangeability between the hardware and the software, the foregoing has generally described operations and compositions of each embodiment based on functions. Whether the functions are performed by hardware or software depends on particular applications and design constraints of the technical solutions. A person of ordinary skill in the art may use different methods to implement the described functions for each particular application, but it should not be considered that the implementation goes beyond the scope of this application.
It can be clearly understood by a person skilled in the art that, for the purpose of convenient and brief descriptions, for a detailed working process of the foregoing described system, apparatus, and unit, refer to a corresponding process in the foregoing method embodiment. Details are not described herein again.
In the several embodiments provided in this application, the disclosed system, apparatus, and method may be implemented in other manners. For example, the described apparatus embodiments are merely examples. For example, the division into units is merely logical function division and may be other division during actual implementation. For example, a plurality of units or components may be combined or integrated into another system, or some features may be ignored or not performed. In addition, the displayed or discussed mutual couplings or direct couplings or communication connections may be implemented through some interfaces. The indirect couplings or communication connections between the apparatuses or units may be implemented in an electrical form, a mechanical form, or other forms.
The units described as separate components may or may not be physically separated, and components displayed as units may or may not be physical units. To be specific, the components may be located at one location, or may be distributed on a plurality of network units. Some or all of the units may be selected based on an actual requirement to achieve the objectives of the solutions in embodiments in this application.
In addition, functional units in embodiments of this application may be integrated into one processing unit, each of the units may exist alone physically, or two or more units may be integrated into one unit. The integrated unit may be implemented in a form of hardware, or may be implemented in a form of a software function unit.
When the integrated unit is implemented in a form of a software function unit and sold or used as an independent product, the integrated unit may be stored in a computer-readable storage medium. Based on such an understanding, the technical solutions in this application essentially, or the part contributing to the prior art, or all or some of the technical solutions may be implemented in a form of a software product. The computer software product is stored in a storage medium and includes several instructions for instructing a computer device (which may be a personal computer, a server, a network device, or the like) to perform all or some of the operations of the methods in embodiments of this application. The foregoing storage medium includes any medium that can store program code, such as a USB flash drive, a removable hard disk, a read-only memory (ROM), a random access memory (RAM), a magnetic disk, or an optical disc.
The foregoing descriptions are merely examples of this application, but are not intended to limit the protection scope of this application. Any modification or replacement readily figured out by a person skilled in the art within the technical scope disclosed in this application shall fall within the protection scope of this application. Therefore, the protection scope of this application shall be subject to the protection scope of the claims.
All or some of the foregoing embodiments may be implemented by software, hardware, firmware, or any combination thereof. When software is used to implement embodiments, embodiments may be implemented completely or partially in a form of a computer program product. The computer program product includes one or more computer program instructions. When the computer program instructions are loaded and executed on a computer, the procedures or functions according to embodiments of this application are all or partially generated. The computer may be a general-purpose computer, a special-purpose computer, a computer network, or another programmable apparatus. The computer instructions may be stored in a computer-readable storage medium or may be transmitted from a computer-readable storage medium to another computer-readable storage medium. For example, the computer program instructions may be transmitted from a website, computer, server, or data center to another website, computer, server, or data center in a wired or wireless manner. The computer-readable storage medium may be any usable medium accessible by a computer, or a data storage device, such as a server or a data center, integrating one or more usable media. The usable medium may be a magnetic medium (for example, a floppy disk, a hard disk, or a magnetic tape), an optical medium (for example, a digital video disc (DVD)), a semiconductor medium (for example, a solid-state drive), or the like.
A person of ordinary skill in the art may understand that all or some of the operations of the foregoing embodiments may be implemented by hardware or a program instructing related hardware. The program may be stored in a computer-readable storage medium. The storage medium may be a read-only memory, a magnetic disk, an optical disc, or the like.
The foregoing descriptions are merely optional embodiments of this application, but are not intended to limit this application. Any modification, equivalent replacement, or improvement made without departing from the spirit and principle of this application should fall within the protection scope of this application.
It can be clearly understood by a person skilled in the art that, for the purpose of convenient and brief descriptions, for a detailed working process of the foregoing described system, apparatus, and unit, refer to a corresponding process in the foregoing method embodiment. Details are not described herein again.
In the several embodiments provided in this application, it should be understood that the disclosed system, apparatus, and method may be implemented in other manners. For example, the described apparatus embodiments are merely examples. For example, division into units is merely logical function division and may be other division during actual implementation. For example, a plurality of units or components may be combined or integrated into another system, or some features may be ignored or not performed. In addition, the displayed or discussed mutual couplings or direct couplings or communication connections may be implemented through some interfaces. The indirect couplings or communication connections between the apparatuses or units may be implemented in an electrical form, a mechanical form, or other forms.
The units described as separate components may or may not be physically separate, and components displayed as units may or may not be physical units. To be specific, the components may be located at one location, or may be distributed on a plurality of network units. Some or all of the units may be selected based on an actual requirement to achieve the objectives of the solutions in embodiments.
In addition, functional units in embodiments of this application may be integrated into one processing unit, each of the units may exist alone physically, or two or more units may be integrated into one unit. The integrated unit may be implemented in a form of hardware, or may be implemented in a form of a software function unit.
When the integrated unit is implemented in a form of a software function unit and sold or used as an independent product, the integrated unit may be stored in a computer-readable storage medium. Based on such an understanding, the technical solutions in this application essentially, or the part contributing to the prior art, or all or some of the technical solutions may be implemented in a form of a software product. The computer software product is stored in a storage medium and includes several instructions for instructing a computer device (which may be a personal computer, a server, a network device, or the like) to perform all or some of the operations of the methods in embodiments of this application. The foregoing storage medium includes any medium that can store program code, such as a USB flash drive, a removable hard disk, a read-only memory (ROM), a random access memory (RAM), a magnetic disk, or an optical disc.
Number | Date | Country | Kind |
---|---|---|---|
202010966675.7 | Sep 2020 | CN | national |
This application is a continuation of International Application No. PCT/CN2021/117912, filed on Sep. 13, 2021, which claims priority to Chinese Patent Application No. 202010966675.7, filed on Sep. 15, 2020. The disclosures of the aforementioned applications are hereby incorporated by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2021/117912 | Sep 2021 | US |
Child | 17980096 | US |