CN111314311A - Method, system, equipment and medium for improving performance of switch - Google Patents
Method, system, equipment and medium for improving performance of switch Download PDFInfo
- Publication number
- CN111314311A CN111314311A CN202010060869.0A CN202010060869A CN111314311A CN 111314311 A CN111314311 A CN 111314311A CN 202010060869 A CN202010060869 A CN 202010060869A CN 111314311 A CN111314311 A CN 111314311A
- Authority
- CN
- China
- Prior art keywords
- socket
- switch
- layer
- data packet
- protocol stack
- 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.)
- Pending
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
- H04L69/161—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
- H04L69/162—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields involving adaptations of sockets based mechanisms
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/30—Definitions, standards or architectural aspects of layered protocol stacks
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种提高交换机性能的方法、系统、设备和存储介质,方法包括以下步骤:响应于接收到数据包,将交换机的协议栈调整为用户态;响应于用户态加载完成,基于CPU核心的数量,启动不同数量的线程;在线程中确定处于监听状态的绑定套接字,并基于绑定套接字建立与数据包的连接;以及基于绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对数据包进行处理。本发明提出的提高交换机性能的方法、系统、设备及介质通过将协议栈调整为用户态,并且增加附加哈希层,有效提高了交换机性能。
The invention discloses a method, system, device and storage medium for improving switch performance. The method includes the following steps: in response to receiving a data packet, adjusting the protocol stack of the switch to user mode; in response to the completion of user mode loading, based on CPU The number of cores, start different numbers of threads; determine the bound socket in the listening state in the thread, and establish a connection with the packet based on the bound socket; and based on the bound socket in the underlying hash layer Add an additional hash layer and process packets based on a double-layer hash layer. The method, system, device and medium for improving the performance of the switch proposed by the present invention effectively improve the performance of the switch by adjusting the protocol stack to the user state and adding an additional hash layer.
Description
技术领域technical field
本发明涉及交换机领域,更具体地,特别是指一种提高交换机性能的方法、系统、计算机设备及可读介质。The present invention relates to the field of switches, and more particularly, to a method, a system, a computer device and a readable medium for improving the performance of a switch.
背景技术Background technique
随着网络带宽的逐渐增加,使用Linux内核处理数据包的性能下降,并且没有特别好的处理方法。目前硬件越来越廉价,但是当前linux内核的TCP/IP协议处理能力并没有随着硬件性能提高成线性增长。内核协议栈PPS性能曲线呈现严重上凸,并且内核协议栈的CPS(TCP每秒新建连接数)随着CPU核数的增加几乎没有什么变化。As the network bandwidth gradually increases, the performance of processing packets using the Linux kernel degrades, and there is no particularly good way to handle it. At present, the hardware is getting cheaper and cheaper, but the TCP/IP protocol processing capability of the current Linux kernel does not increase linearly with the improvement of hardware performance. The PPS performance curve of the kernel protocol stack shows a serious upward convexity, and the CPS (TCP new connections per second) of the kernel protocol stack hardly changes with the increase of the number of CPU cores.
交换机的部分L2协议和L3协议需要通过OS(系统)处理交换协议,数据包自交换芯片通过PCIE(peripheral component interconnect express,一种高速串行计算机扩展总线标准)传输到OS后,首先经过OS层协议栈,通过协议栈的处理,向上交给协议处理逻辑,协议栈是交换协议处理必经通道,因此TCP/IP协议栈严重影响交换机的处理性能,当前的协议栈存在瓶颈。Part of the L2 protocol and L3 protocol of the switch needs to process the switching protocol through the OS (system). After the data packet is transmitted from the switching chip to the OS through PCIE (peripheral component interconnect express, a high-speed serial computer expansion bus standard), it first passes through the OS layer. The protocol stack is handed over to the protocol processing logic through the processing of the protocol stack. The protocol stack is the necessary channel for exchange protocol processing. Therefore, the TCP/IP protocol stack seriously affects the processing performance of the switch, and the current protocol stack has a bottleneck.
发明内容SUMMARY OF THE INVENTION
有鉴于此,本发明实施例的目的在于提出一种提高交换机性能的方法、系统、计算机设备及计算机可读存储介质,通过将协议栈调整为用户态,并且增加附加哈希层,有效提高了交换机性能。In view of this, the purpose of the embodiments of the present invention is to provide a method, system, computer device and computer-readable storage medium for improving switch performance. switch performance.
基于上述目的,本发明实施例的一方面提供了一种提高交换机性能的方法,包括如下步骤:响应于接收到数据包,将交换机的协议栈调整为用户态;响应于所述用户态加载完成,基于CPU核心的数量,启动不同数量的线程;在所述线程中确定处于监听状态的绑定套接字,并基于所述绑定套接字建立与所述数据包的连接;以及基于所述绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对所述数据包进行处理。Based on the above purpose, one aspect of the embodiments of the present invention provides a method for improving the performance of a switch, including the following steps: in response to receiving a data packet, adjusting the protocol stack of the switch to a user mode; in response to the completion of the user mode loading , based on the number of CPU cores, start different numbers of threads; determine the binding socket in the listening state in the thread, and establish a connection with the data packet based on the binding socket; and based on the The binding socket adds an additional hash layer to the basic hash layer, and processes the data packet based on the double-layer hash layer.
在一些实施方式中,所述将交换机的协议栈调整为用户态包括:将所述协议栈的配置文件转换成适合用户态的格式。In some embodiments, the adjusting the protocol stack of the switch to the user mode includes: converting the configuration file of the protocol stack into a format suitable for the user mode.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:发送复位信号,并在哈希表中确定所述绑定套接字。In some implementations, the determining the bound socket in the listening state in the thread includes sending a reset signal, and determining the bound socket in a hash table.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:对哈希表中的目标端口进行迭代以确定匹配的绑定套接字。In some implementations, the determining a bound socket in a listening state in the thread comprises: iterating over target ports in a hash table to determine a matching bound socket.
在一些实施方式中,所述基于双层哈希层对所述数据包进行处理包括:确定所述数据包的类型,并基于所述类型采用相应的响应。In some embodiments, the processing of the data packet based on the double-layer hash layer includes: determining a type of the data packet, and adopting a corresponding response based on the type.
本发明实施例的另一方面,还提供了一种提高交换机性能的系统,包括:调整模块,配置用于响应于接收到数据包,将交换机的协议栈调整为用户态;线程模块,配置用于响应于所述用户态加载完成,基于CPU核心的数量,启动不同数量的线程;连接模块,配置用于在所述线程中确定处于监听状态的绑定套接字,并基于所述绑定套接字建立与所述数据包的连接;以及哈希模块,配置用于基于所述绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对所述数据包进行处理。Another aspect of the embodiments of the present invention further provides a system for improving the performance of a switch, including: an adjustment module configured to adjust the protocol stack of the switch to a user state in response to receiving a data packet; a thread module configured to In response to the user state loading being completed, different numbers of threads are started based on the number of CPU cores; the connection module is configured to determine the binding socket in the listening state in the thread, and based on the binding a socket establishes a connection with the data packet; and a hash module configured to add an additional hash layer to the base hash layer based on the bound socket, and to perform an additional hash layer on the data based on the double-layer hash layer package is processed.
在一些实施方式中,所述将交换机的协议栈调整为用户态包括:将所述协议栈的配置文件转换成适合用户态的格式。In some embodiments, the adjusting the protocol stack of the switch to the user mode includes: converting the configuration file of the protocol stack into a format suitable for the user mode.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:发送复位信号,并在哈希表中确定所述绑定套接字。In some implementations, the determining the bound socket in the listening state in the thread includes sending a reset signal, and determining the bound socket in a hash table.
本发明实施例的又一方面,还提供了一种计算机设备,包括:至少一个处理器;以及存储器,所述存储器存储有可在所述处理器上运行的计算机指令,所述指令由所述处理器执行时实现如上方法的步骤。In yet another aspect of the embodiments of the present invention, there is also provided a computer device, comprising: at least one processor; and a memory, where the memory stores computer instructions that can be executed on the processor, and the instructions are executed by the processor. The processor implements the steps of the above method when executed.
本发明实施例的再一方面,还提供了一种计算机可读存储介质,计算机可读存储介质存储有被处理器执行时实现如上方法步骤的计算机程序。In yet another aspect of the embodiments of the present invention, a computer-readable storage medium is also provided, where the computer-readable storage medium stores a computer program that implements the above method steps when executed by a processor.
本发明具有以下有益技术效果:通过将协议栈调整为用户态,并且增加附加哈希层,有效提高了交换机性能。The invention has the following beneficial technical effects: by adjusting the protocol stack to the user state and adding an additional hash layer, the performance of the switch is effectively improved.
附图说明Description of drawings
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的实施例。In order to explain the embodiments of the present invention or the technical solutions in the prior art more clearly, the following briefly introduces the accompanying drawings that need to be used in the description of the embodiments or the prior art. Obviously, the accompanying drawings in the following description are only These are some embodiments of the present invention. For those of ordinary skill in the art, other embodiments can also be obtained according to these drawings without creative efforts.
图1为本发明提供的提高交换机性能的方法的实施例的示意图;FIG. 1 is a schematic diagram of an embodiment of a method for improving switch performance provided by the present invention;
图2为本发明提供的提高交换机性能的方法的实施例的硬件结构示意图。FIG. 2 is a schematic diagram of a hardware structure of an embodiment of a method for improving switch performance provided by the present invention.
具体实施方式Detailed ways
为使本发明的目的、技术方案和优点更加清楚明白,以下结合具体实施例,并参照附图,对本发明实施例进一步详细说明。In order to make the objectives, technical solutions and advantages of the present invention more clearly understood, the embodiments of the present invention will be further described in detail below with reference to the specific embodiments and the accompanying drawings.
需要说明的是,本发明实施例中所有使用“第一”和“第二”的表述均是为了区分两个相同名称非相同的实体或者非相同的参量,可见“第一”“第二”仅为了表述的方便,不应理解为对本发明实施例的限定,后续实施例对此不再一一说明。It should be noted that all expressions using "first" and "second" in the embodiments of the present invention are for the purpose of distinguishing two entities with the same name but not the same or non-identical parameters. It can be seen that "first" and "second" It is only for the convenience of expression and should not be construed as a limitation to the embodiments of the present invention, and subsequent embodiments will not describe them one by one.
基于上述目的,本发明实施例的第一个方面,提出了一种提高交换机性能的方法的实施例。图1示出的是本发明提供的提高交换机性能的方法的实施例的示意图。如图1所示,本发明实施例包括如下步骤:Based on the above objective, in the first aspect of the embodiments of the present invention, an embodiment of a method for improving the performance of a switch is provided. FIG. 1 shows a schematic diagram of an embodiment of a method for improving switch performance provided by the present invention. As shown in Figure 1, the embodiment of the present invention includes the following steps:
S1、响应于接收到数据包,将交换机的协议栈调整为用户态;S1, in response to receiving the data packet, adjust the protocol stack of the switch to the user state;
S2、响应于用户态加载完成,基于CPU核心的数量,启动不同数量的线程;S2. In response to the completion of user mode loading, different numbers of threads are started based on the number of CPU cores;
S3、在线程中确定处于监听状态的绑定套接字,并基于绑定套接字建立与数据包的连接;以及S3. Determine the bound socket in the listening state in the thread, and establish a connection with the data packet based on the bound socket; and
S4、基于绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对数据包进行处理。S4. An additional hash layer is added to the basic hash layer based on the binding socket, and the data packets are processed based on the double-layer hash layer.
Internet的飞速发展需要高性能的网络处理能力,内核绕过引起了越来越多的关注。内核旁路的主要思想是Linux仅用于处理控制流,所有数据流都在用户空间中处理。因此,内核旁路可以避免由于内核数据包复制,线程调度,系统调用和中断而导致的性能瓶颈。此外,内核旁路可以通过多种优化方法获得更高的性能。TCP/IP(TransmissionControl Protocol/Internet Protocol,传输控制协议/网际协议)是指能够在多个不同网络间实现信息传输的协议簇。TCP/IP协议不仅仅指的是TCP和IP两个协议,而是指一个由FTP、SMTP、TCP、UDP、IP等协议构成的协议簇,只是因为在TCP/IP协议中TCP协议和IP协议最具代表性,所以被称为TCP/IP协议。The rapid development of the Internet requires high-performance network processing capabilities, and kernel bypass has attracted more and more attention. The main idea of kernel bypass is that Linux is only used to handle control flow, all data flow is handled in user space. Therefore, kernel bypass can avoid performance bottlenecks due to kernel packet copying, thread scheduling, system calls and interrupts. In addition, kernel bypass can achieve higher performance through various optimization methods. TCP/IP (Transmission Control Protocol/Internet Protocol, Transmission Control Protocol/Internet Protocol) refers to a protocol suite capable of realizing information transmission among multiple different networks. The TCP/IP protocol not only refers to the two protocols of TCP and IP, but also refers to a protocol cluster composed of FTP, SMTP, TCP, UDP, IP and other protocols, just because the TCP protocol and the IP protocol in the TCP/IP protocol The most representative, so it is called the TCP/IP protocol.
响应于接收到数据包,将交换机的协议栈调整为用户态。在接收到数据包后,可以修改交换机系统中的TCP/IP协议栈,可以将协议栈自内核态调整为用户态。在一些实施方式中,所述将交换机的协议栈调整为用户态包括:将所述协议栈的配置文件转换成适合用户态的格式。例如,可以将协议栈的配置文件转换成ko。In response to receiving the data packet, the protocol stack of the switch is adjusted to user mode. After receiving the data packet, the TCP/IP protocol stack in the switch system can be modified, and the protocol stack can be adjusted from the kernel mode to the user mode. In some embodiments, the adjusting the protocol stack of the switch to the user mode includes: converting the configuration file of the protocol stack into a format suitable for the user mode. For example, the configuration file of the protocol stack can be converted to ko.
响应于用户态加载完成,基于CPU核心的数量,启动不同数量的线程。用户态加载完成后,根据CPU的核心数量,启动不同的线程,保证协议的处理能力。In response to the user mode loading being completed, different numbers of threads are started based on the number of CPU cores. After the user mode is loaded, different threads are started according to the number of CPU cores to ensure the processing capability of the protocol.
在线程中确定处于监听状态的绑定套接字,并基于绑定套接字建立与数据包的连接。在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:发送复位信号,并在哈希表中确定所述绑定套接字。在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:对哈希表中的目标端口进行迭代以确定匹配的绑定套接字。Determine the bound socket in the listening state in the thread, and establish a connection with the packet based on the bound socket. In some implementations, the determining the bound socket in the listening state in the thread includes sending a reset signal, and determining the bound socket in a hash table. In some implementations, the determining a bound socket in a listening state in the thread comprises: iterating over target ports in a hash table to determine a matching bound socket.
在协议处理时会确定处于监听状态的绑定套接字,如果没有找到处于监听状态的绑定套接字,可以发送复位信号,例如RST,然后在哈希表中找到绑定套接字。可以通过将目标端口用作哈希来实现,并在哈希表中选择一个适当的通道,然后线性地进行迭代以确定匹配的绑定套接字。When the protocol is processed, the binding socket in the listening state will be determined. If the binding socket in the listening state is not found, a reset signal can be sent, such as RST, and the binding socket can be found in the hash table. This can be achieved by using the destination port as a hash, and selecting an appropriate channel in the hash table, then iterating linearly to determine the matching bound socket.
基于绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对数据包进行处理。在一些实施方式中,所述基于双层哈希层对所述数据包进行处理包括:确定所述数据包的类型,并基于所述类型采用相应的响应。如果数据包时SYN并且监听状态的绑定套接字存在,可以采用SYN+ACK响应。Based on the binding socket, an additional hash layer is added to the basic hash layer, and the data packet is processed based on the double-layer hash layer. In some embodiments, the processing of the data packet based on the double-layer hash layer includes: determining a type of the data packet, and adopting a corresponding response based on the type. If the packet is SYN and the bound socket in the listening state exists, a SYN+ACK response can be used.
需要特别指出的是,上述提高交换机性能的方法的各个实施例中的各个步骤均可以相互交叉、替换、增加、删减,因此,这些合理的排列组合变换之于提高交换机性能的方法也应当属于本发明的保护范围,并且不应将本发明的保护范围局限在实施例之上。It should be particularly pointed out that the steps in each embodiment of the above-mentioned method for improving switch performance can be crossed, replaced, added, and deleted. The protection scope of the present invention should not be limited to the embodiments.
基于上述目的,本发明实施例的第二个方面,提出了一种提高交换机性能的系统,包括:调整模块,配置用于响应于接收到数据包,将交换机的协议栈调整为用户态;线程模块,配置用于响应于所述用户态加载完成,基于CPU核心的数量,启动不同数量的线程;连接模块,配置用于在所述线程中确定处于监听状态的绑定套接字,并基于所述绑定套接字建立与所述数据包的连接;以及哈希模块,配置用于基于所述绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对所述数据包进行处理。Based on the above purpose, in a second aspect of the embodiments of the present invention, a system for improving the performance of a switch is proposed, including: an adjustment module configured to adjust the protocol stack of the switch to a user state in response to receiving a data packet; a thread The module is configured to start different numbers of threads based on the number of CPU cores in response to the completion of the user mode loading; the connection module is configured to determine the binding socket in the listening state in the thread, and based on the number of CPU cores the bound socket establishes a connection with the data packet; and a hash module configured to add an additional hash layer to the base hash layer based on the bound socket, and based on the double-layer hash layer The data packets are processed.
在一些实施方式中,所述将交换机的协议栈调整为用户态包括:将所述协议栈的配置文件转换成适合用户态的格式。In some embodiments, the adjusting the protocol stack of the switch to the user mode includes: converting the configuration file of the protocol stack into a format suitable for the user mode.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:发送复位信号,并在哈希表中确定所述绑定套接字。In some implementations, the determining the bound socket in the listening state in the thread includes sending a reset signal, and determining the bound socket in a hash table.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:对哈希表中的目标端口进行迭代以确定匹配的绑定套接字。In some implementations, the determining a bound socket in a listening state in the thread comprises: iterating over target ports in a hash table to determine a matching bound socket.
在一些实施方式中,所述基于双层哈希层对所述数据包进行处理包括:确定所述数据包的类型,并基于所述类型采用相应的响应。In some embodiments, the processing of the data packet based on the double-layer hash layer includes: determining a type of the data packet, and adopting a corresponding response based on the type.
基于上述目的,本发明实施例的第三个方面,提出了一种计算机设备,包括:至少一个处理器;以及存储器,存储器存储有可在处理器上运行的计算机指令,指令由处理器执行以实现如下步骤:S1、响应于接收到数据包,将交换机的协议栈调整为用户态;S2、响应于用户态加载完成,基于CPU核心的数量,启动不同数量的线程;S3、在线程中确定处于监听状态的绑定套接字,并基于绑定套接字建立与数据包的连接;以及S4、基于绑定套接字在基础哈希层增加附加哈希层,并基于双层哈希层对数据包进行处理。Based on the above objective, in a third aspect of the embodiments of the present invention, a computer device is provided, including: at least one processor; and a memory, where the memory stores computer instructions that can be executed on the processor, and the instructions are executed by the processor to The following steps are implemented: S1, in response to receiving the data packet, adjust the protocol stack of the switch to the user mode; S2, in response to the completion of the user mode loading, start different numbers of threads based on the number of CPU cores; S3, determine in the thread The binding socket in the listening state, and establishing a connection with the data packet based on the binding socket; and S4, adding an additional hash layer to the basic hash layer based on the binding socket, and based on double-layer hashing Layers process packets.
在一些实施方式中,所述将交换机的协议栈调整为用户态包括:将所述协议栈的配置文件转换成适合用户态的格式。In some embodiments, the adjusting the protocol stack of the switch to the user mode includes: converting the configuration file of the protocol stack into a format suitable for the user mode.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:发送复位信号,并在哈希表中确定所述绑定套接字。In some implementations, the determining the bound socket in the listening state in the thread includes sending a reset signal, and determining the bound socket in a hash table.
在一些实施方式中,所述在所述线程中确定处于监听状态的绑定套接字包括:对哈希表中的目标端口进行迭代以确定匹配的绑定套接字。In some implementations, the determining a bound socket in a listening state in the thread comprises: iterating over target ports in a hash table to determine a matching bound socket.
在一些实施方式中,所述基于双层哈希层对所述数据包进行处理包括:确定所述数据包的类型,并基于所述类型采用相应的响应。In some embodiments, the processing of the data packet based on the double-layer hash layer includes: determining a type of the data packet, and adopting a corresponding response based on the type.
如图2所示,为本发明提供的上述提高交换机性能的方法的一个实施例的硬件结构示意图。As shown in FIG. 2 , it is a schematic diagram of a hardware structure of an embodiment of the method for improving the performance of a switch provided by the present invention.
以如图2所示的装置为例,在该装置中包括一个处理器301以及一个存储器302,并还可以包括:输入装置303和输出装置304。Taking the device shown in FIG. 2 as an example, the device includes a
处理器301、存储器302、输入装置303和输出装置304可以通过总线或者其他方式连接,图2中以通过总线连接为例。The
存储器302作为一种非易失性计算机可读存储介质,可用于存储非易失性软件程序、非易失性计算机可执行程序以及模块,如本申请实施例中的提高交换机性能的方法对应的程序指令/模块。处理器301通过运行存储在存储器302中的非易失性软件程序、指令以及模块,从而执行服务器的各种功能应用以及数据处理,即实现上述方法实施例的提高交换机性能的方法。As a non-volatile computer-readable storage medium, the
存储器302可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据提高交换机性能的方法的使用所创建的数据等。此外,存储器302可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实施例中,存储器302可选包括相对于处理器301远程设置的存储器,这些远程存储器可以通过网络连接至本地模块。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。The
输入装置303可接收输入的用户名和密码等信息。输出装置304可包括显示屏等显示设备。The
一个或者多个提高交换机性能的方法对应的程序指令/模块存储在存储器302中,当被处理器301执行时,执行上述任意方法实施例中的提高交换机性能的方法。The program instructions/modules corresponding to one or more methods for improving switch performance are stored in the
执行上述提高交换机性能的方法的计算机设备的任何一个实施例,可以达到与之对应的前述任意方法实施例相同或者相类似的效果。Any embodiment of the computer device that executes the above method for improving switch performance can achieve the same or similar effects as any of the foregoing method embodiments corresponding to it.
本发明还提供了一种计算机可读存储介质,计算机可读存储介质存储有被处理器执行时执行如上方法的计算机程序。The present invention also provides a computer-readable storage medium, where the computer-readable storage medium stores a computer program that executes the above method when executed by a processor.
最后需要说明的是,本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关硬件来完成,提高交换机性能的方法的程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,程序的存储介质可为磁碟、光盘、只读存储记忆体(ROM)或随机存储记忆体(RAM)等。上述计算机程序的实施例,可以达到与之对应的前述任意方法实施例相同或者相类似的效果。Finally, it should be noted that those of ordinary skill in the art can understand that all or part of the process in the method of the above-mentioned embodiments can be implemented by instructing the relevant hardware through a computer program, and the program of the method for improving the performance of the switch can be stored in a computer readable In the storage medium, when the program is executed, it may include the processes of the foregoing method embodiments. Wherein, the storage medium of the program may be a magnetic disk, an optical disk, a read only memory (ROM) or a random access memory (RAM) or the like. The above computer program embodiments can achieve the same or similar effects as any of the foregoing method embodiments corresponding thereto.
此外,根据本发明实施例公开的方法还可以被实现为由处理器执行的计算机程序,该计算机程序可以存储在计算机可读存储介质中。在该计算机程序被处理器执行时,执行本发明实施例公开的方法中限定的上述功能。In addition, the methods disclosed according to the embodiments of the present invention may also be implemented as a computer program executed by a processor, and the computer program may be stored in a computer-readable storage medium. When the computer program is executed by the processor, the above-mentioned functions defined in the methods disclosed in the embodiments of the present invention are executed.
此外,上述方法步骤以及系统单元也可以利用控制器以及用于存储使得控制器实现上述步骤或单元功能的计算机程序的计算机可读存储介质实现。In addition, the above-mentioned method steps and system units can also be implemented by using a controller and a computer-readable storage medium for storing a computer program that enables the controller to implement the functions of the above-mentioned steps or units.
此外,应该明白的是,本文的计算机可读存储介质(例如,存储器)可以是易失性存储器或非易失性存储器,或者可以包括易失性存储器和非易失性存储器两者。作为例子而非限制性的,非易失性存储器可以包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦写可编程ROM(EEPROM)或快闪存储器。易失性存储器可以包括随机存取存储器(RAM),该RAM可以充当外部高速缓存存储器。作为例子而非限制性的,RAM可以以多种形式获得,比如同步RAM(DRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据速率SDRAM(DDRSDRAM)、增强SDRAM(ESDRAM)、同步链路DRAM(SLDRAM)、以及直接Rambus RAM(DRRAM)。所公开的方面的存储设备意在包括但不限于这些和其它合适类型的存储器。In addition, it should be understood that computer-readable storage media (eg, memory) herein can be volatile memory or non-volatile memory, or can include both volatile and non-volatile memory. By way of example and not limitation, nonvolatile memory may include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), or flash memory memory. Volatile memory may include random access memory (RAM), which may act as external cache memory. By way of example and not limitation, RAM is available in various forms such as synchronous RAM (DRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDRSDRAM), enhanced SDRAM (ESDRAM), synchronous Link DRAM (SLDRAM), and Direct Rambus RAM (DRRAM). The storage devices of the disclosed aspects are intended to include, but not be limited to, these and other suitable types of memory.
本领域技术人员还将明白的是,结合这里的公开所描述的各种示例性逻辑块、模块、电路和算法步骤可以被实现为电子硬件、计算机软件或两者的组合。为了清楚地说明硬件和软件的这种可互换性,已经就各种示意性组件、方块、模块、电路和步骤的功能对其进行了一般性的描述。这种功能是被实现为软件还是被实现为硬件取决于具体应用以及施加给整个系统的设计约束。本领域技术人员可以针对每种具体应用以各种方式来实现的功能,但是这种实现决定不应被解释为导致脱离本发明实施例公开的范围。Those skilled in the art will also appreciate that the various exemplary logical blocks, modules, circuits, and algorithm steps described in connection with the disclosure herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described generally in terms of their functionality. Whether such functionality is implemented as software or hardware depends on the specific application and design constraints imposed on the overall system. Those skilled in the art may implement the functions in various ways for each specific application, but such implementation decisions should not be interpreted as causing a departure from the scope of the disclosed embodiments of the present invention.
结合这里的公开所描述的各种示例性逻辑块、模块和电路可以利用被设计成用于执行这里功能的下列部件来实现或执行:通用处理器、数字信号处理器(DSP)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)或其它可编程逻辑器件、分立门或晶体管逻辑、分立的硬件组件或者这些部件的任何组合。通用处理器可以是微处理器,但是可替换地,处理器可以是任何传统处理器、控制器、微控制器或状态机。处理器也可以被实现为计算设备的组合,例如,DSP和微处理器的组合、多个微处理器、一个或多个微处理器结合DSP和/或任何其它这种配置。The various exemplary logical blocks, modules, and circuits described in connection with the disclosure herein can be implemented or executed using the following components designed to perform the functions herein: general purpose processors, digital signal processors (DSPs), application specific integrated circuits (ASIC), Field Programmable Gate Array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination of these components. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, eg, a combination of a DSP and a microprocessor, multiple microprocessors, one or more microprocessors in combination with a DSP, and/or any other such configuration.
结合这里的公开所描述的方法或算法的步骤可以直接包含在硬件中、由处理器执行的软件模块中或这两者的组合中。软件模块可以驻留在RAM存储器、快闪存储器、ROM存储器、EPROM存储器、EEPROM存储器、寄存器、硬盘、可移动盘、CD-ROM、或本领域已知的任何其它形式的存储介质中。示例性的存储介质被耦合到处理器,使得处理器能够从该存储介质中读取信息或向该存储介质写入信息。在一个替换方案中,存储介质可以与处理器集成在一起。处理器和存储介质可以驻留在ASIC中。ASIC可以驻留在用户终端中。在一个替换方案中,处理器和存储介质可以作为分立组件驻留在用户终端中。The steps of a method or algorithm described in connection with the disclosures herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module may reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, removable disk, CD-ROM, or any other form of storage medium known in the art. An exemplary storage medium is coupled to the processor, such that the processor can read information from, and write information to, the storage medium. In an alternative, the storage medium may be integrated with the processor. The processor and storage medium may reside in an ASIC. The ASIC may reside in the user terminal. In an alternative, the processor and storage medium may reside in the user terminal as discrete components.
在一个或多个示例性设计中,功能可以在硬件、软件、固件或其任意组合中实现。如果在软件中实现,则可以将功能作为一个或多个指令或代码存储在计算机可读介质上或通过计算机可读介质来传送。计算机可读介质包括计算机存储介质和通信介质,该通信介质包括有助于将计算机程序从一个位置传送到另一个位置的任何介质。存储介质可以是能够被通用或专用计算机访问的任何可用介质。作为例子而非限制性的,该计算机可读介质可以包括RAM、ROM、EEPROM、CD-ROM或其它光盘存储设备、磁盘存储设备或其它磁性存储设备,或者是可以用于携带或存储形式为指令或数据结构的所需程序代码并且能够被通用或专用计算机或者通用或专用处理器访问的任何其它介质。此外,任何连接都可以适当地称为计算机可读介质。例如,如果使用同轴线缆、光纤线缆、双绞线、数字用户线路(DSL)或诸如红外线、无线电和微波的无线技术来从网站、服务器或其它远程源发送软件,则上述同轴线缆、光纤线缆、双绞线、DSL或诸如红外线、无线电和微波的无线技术均包括在介质的定义。如这里所使用的,磁盘和光盘包括压缩盘(CD)、激光盘、光盘、数字多功能盘(DVD)、软盘、蓝光盘,其中磁盘通常磁性地再现数据,而光盘利用激光光学地再现数据。上述内容的组合也应当包括在计算机可读介质的范围内。In one or more exemplary designs, functions may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media includes both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage medium can be any available medium that can be accessed by a general purpose or special purpose computer. By way of example and not limitation, the computer-readable medium may include RAM, ROM, EEPROM, CD-ROM or other optical disk storage devices, magnetic disk storage devices or other magnetic storage devices, or may be used to carry or store instructions in the form of or data structures and any other medium that can be accessed by a general purpose or special purpose computer or a general purpose or special purpose processor. Also, any connection is properly termed a computer-readable medium. For example, if coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave are used to send software from a website, server, or other remote source, the above coaxial cable Cable, fiber optic cable, twisted pair, DSL or wireless technologies such as infrared, radio and microwave are all included in the definition of medium. As used herein, magnetic disks and optical disks include compact disks (CDs), laser disks, optical disks, digital versatile disks (DVDs), floppy disks, blu-ray disks, where disks usually reproduce data magnetically, while optical disks reproduce data optically with lasers . Combinations of the above should also be included within the scope of computer-readable media.
以上是本发明公开的示例性实施例,但是应当注意,在不背离权利要求限定的本发明实施例公开的范围的前提下,可以进行多种改变和修改。根据这里描述的公开实施例的方法权利要求的功能、步骤和/或动作不需以任何特定顺序执行。此外,尽管本发明实施例公开的元素可以以个体形式描述或要求,但除非明确限制为单数,也可以理解为多个。The above are exemplary embodiments of the present disclosure, but it should be noted that various changes and modifications may be made without departing from the scope of the disclosure of the embodiments of the present invention as defined in the claims. The functions, steps and/or actions of the method claims in accordance with the disclosed embodiments described herein need not be performed in any particular order. Furthermore, although elements disclosed in the embodiments of the present invention may be described or claimed in the singular, unless explicitly limited to the singular, the plural may also be construed.
应当理解的是,在本文中使用的,除非上下文清楚地支持例外情况,单数形式“一个”旨在也包括复数形式。还应当理解的是,在本文中使用的“和/或”是指包括一个或者一个以上相关联地列出的项目的任意和所有可能组合。It should be understood that, as used herein, the singular form "a" is intended to include the plural form as well, unless the context clearly supports an exception. It will also be understood that "and/or" as used herein is meant to include any and all possible combinations of one or more of the associated listed items.
上述本发明实施例公开实施例序号仅仅为了描述,不代表实施例的优劣。The above-mentioned embodiments of the present invention disclose the serial numbers of the embodiments only for description, and do not represent the advantages and disadvantages of the embodiments.
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。Those of ordinary skill in the art can understand that all or part of the steps of implementing the above embodiments can be completed by hardware, or can be completed by instructing relevant hardware through a program, and the program can be stored in a computer-readable storage medium. The storage medium can be a read-only memory, a magnetic disk or an optical disk, and the like.
所属领域的普通技术人员应当理解:以上任何实施例的讨论仅为示例性的,并非旨在暗示本发明实施例公开的范围(包括权利要求)被限于这些例子;在本发明实施例的思路下,以上实施例或者不同实施例中的技术特征之间也可以进行组合,并存在如上的本发明实施例的不同方面的许多其它变化,为了简明它们没有在细节中提供。因此,凡在本发明实施例的精神和原则之内,所做的任何省略、修改、等同替换、改进等,均应包含在本发明实施例的保护范围之内。Those of ordinary skill in the art should understand that the discussion of any of the above embodiments is only exemplary, and is not intended to imply that the scope (including the claims) disclosed by the embodiments of the present invention is limited to these examples; under the idea of the embodiments of the present invention , the technical features in the above embodiments or different embodiments can also be combined, and there are many other changes in different aspects of the above embodiments of the present invention, which are not provided in detail for the sake of brevity. Therefore, any omission, modification, equivalent replacement, improvement, etc. made within the spirit and principle of the embodiments of the present invention should be included within the protection scope of the embodiments of the present invention.
Claims (10)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010060869.0A CN111314311A (en) | 2020-01-19 | 2020-01-19 | Method, system, equipment and medium for improving performance of switch |
PCT/CN2020/111236 WO2021143139A1 (en) | 2020-01-19 | 2020-08-26 | Method and system for improving performance of switch, device, and medium |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010060869.0A CN111314311A (en) | 2020-01-19 | 2020-01-19 | Method, system, equipment and medium for improving performance of switch |
Publications (1)
Publication Number | Publication Date |
---|---|
CN111314311A true CN111314311A (en) | 2020-06-19 |
Family
ID=71146843
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010060869.0A Pending CN111314311A (en) | 2020-01-19 | 2020-01-19 | Method, system, equipment and medium for improving performance of switch |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN111314311A (en) |
WO (1) | WO2021143139A1 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2021143139A1 (en) * | 2020-01-19 | 2021-07-22 | 苏州浪潮智能科技有限公司 | Method and system for improving performance of switch, device, and medium |
WO2023030178A1 (en) * | 2021-08-31 | 2023-03-09 | 华为技术有限公司 | Communication method based on user-mode protocol stack, and corresponding apparatus |
CN117608818A (en) * | 2023-10-20 | 2024-02-27 | 中科驭数(北京)科技有限公司 | Multithreading data processing method, device, equipment and medium |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101409715A (en) * | 2008-10-22 | 2009-04-15 | 中国科学院计算技术研究所 | Method and system for communication using InfiniBand network |
CN103312720A (en) * | 2013-07-01 | 2013-09-18 | 华为技术有限公司 | Data transmission method, equipment and system |
CN108289063A (en) * | 2017-09-11 | 2018-07-17 | 上海金融期货信息技术有限公司 | A kind of low latency communication system |
CN109040207A (en) * | 2018-07-20 | 2018-12-18 | 广东浪潮大数据研究有限公司 | A kind of method, device and equipment accessing User space Network File System |
US20190020501A1 (en) * | 2017-07-14 | 2019-01-17 | Nicira, Inc. | In-band management interface with user space datapath |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102143083A (en) * | 2011-04-02 | 2011-08-03 | 南京邮电大学 | Method for designing and realizing double buffer in Ares protocol analysis system |
CN103533025A (en) * | 2013-09-18 | 2014-01-22 | 北京航空航天大学 | Method for reducing lock contention during TCP (transmission control protocol) connection building on multi-core system |
US10467118B2 (en) * | 2017-09-28 | 2019-11-05 | Intel Corporation | Techniques for performance analysis of processor instruction execution |
CN109672584B (en) * | 2018-11-30 | 2020-08-11 | 广州市百果园信息技术有限公司 | Data packet detection method, device, system, equipment and storage medium |
CN110096363B (en) * | 2019-04-29 | 2021-11-30 | 亚信科技(成都)有限公司 | Method and device for associating network event with process |
CN111314311A (en) * | 2020-01-19 | 2020-06-19 | 苏州浪潮智能科技有限公司 | Method, system, equipment and medium for improving performance of switch |
-
2020
- 2020-01-19 CN CN202010060869.0A patent/CN111314311A/en active Pending
- 2020-08-26 WO PCT/CN2020/111236 patent/WO2021143139A1/en active Application Filing
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101409715A (en) * | 2008-10-22 | 2009-04-15 | 中国科学院计算技术研究所 | Method and system for communication using InfiniBand network |
CN103312720A (en) * | 2013-07-01 | 2013-09-18 | 华为技术有限公司 | Data transmission method, equipment and system |
US20190020501A1 (en) * | 2017-07-14 | 2019-01-17 | Nicira, Inc. | In-band management interface with user space datapath |
CN108289063A (en) * | 2017-09-11 | 2018-07-17 | 上海金融期货信息技术有限公司 | A kind of low latency communication system |
CN109040207A (en) * | 2018-07-20 | 2018-12-18 | 广东浪潮大数据研究有限公司 | A kind of method, device and equipment accessing User space Network File System |
Non-Patent Citations (1)
Title |
---|
江盛杰: "用户空间协议栈的移植与性能优化", 《中国优秀硕士学位论文全文数据库信息科技辑》 * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2021143139A1 (en) * | 2020-01-19 | 2021-07-22 | 苏州浪潮智能科技有限公司 | Method and system for improving performance of switch, device, and medium |
WO2023030178A1 (en) * | 2021-08-31 | 2023-03-09 | 华为技术有限公司 | Communication method based on user-mode protocol stack, and corresponding apparatus |
CN117608818A (en) * | 2023-10-20 | 2024-02-27 | 中科驭数(北京)科技有限公司 | Multithreading data processing method, device, equipment and medium |
Also Published As
Publication number | Publication date |
---|---|
WO2021143139A1 (en) | 2021-07-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9614930B2 (en) | Virtual machine mobility using OpenFlow | |
US9237110B2 (en) | Dynamic maximum transmission unit size adaption | |
CN112491717B (en) | Service routing method and device | |
US8544025B2 (en) | Efficient data transfer on local network connections using a pseudo socket layer | |
US10237130B2 (en) | Method for processing VxLAN data units | |
US9491265B2 (en) | Network communication protocol processing optimization system | |
JP2003333076A (en) | Offloading method of network stack | |
JP2004030612A (en) | Method for uploading a state object of offloaded network stack and method for synchronizing the same | |
CN111314311A (en) | Method, system, equipment and medium for improving performance of switch | |
CN110753095B (en) | Data processing method, device and storage medium of network card | |
CN110838935B (en) | High-availability SDN controller clustering method, system, storage medium and equipment | |
US11121956B1 (en) | Methods and systems for optimizing bidirectional forwarding detection in hardware | |
CN110691094A (en) | Method, equipment and medium for transmitting data based on ISCSI protocol | |
CN110932997B (en) | Method, device and medium for reducing network traffic packet loss | |
CN111708482B (en) | Method, system, device and medium for limiting bandwidth in distributed storage | |
CN116708597A (en) | Data processing method and device | |
JP2016515361A (en) | Network transmission coordination based on transmission metadata provided by the application | |
US10924423B2 (en) | Adaptive mechanism to adjust UDT packet size based on actual network condition | |
US20060215656A1 (en) | Method, device and program storage medium for controlling communication | |
US20180287850A1 (en) | Techniques for network multicasting with buffering | |
CN116089656A (en) | Stream table management method, apparatus, device and computer readable storage medium | |
US20170265103A1 (en) | Communication device, communication method, and non-transitory computer readable medium | |
CN117729274A (en) | Message processing methods, devices, equipment and readable storage media | |
WO2024207870A1 (en) | Data transmission method and related device | |
CN118612223A (en) | Data processing method, device, system, computer equipment and storage medium |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20200619 |