This application is related to U.S. application Ser. No. 16/548,116 entitled “DISTRIBUTED CACHE WITH IN-NETWORK PREFETCH”, filed on Aug. 22, 2019, which is hereby incorporated by reference in its entirety. This application is also related to U.S. application Ser. No. 16/697,019 entitled “FAULT TOLERANT DATA COHERENCE IN LARGE-SCALE DISTRIBUTED CACHE SYSTEMS”, filed on Nov. 26, 2019, which is hereby incorporated by reference in its entirety. This application is also related to U.S. application Ser. No. 16/916,730 titled “DEVICES AND METHODS FOR FAILURE DETECTION AND RECOVERY FOR A DISTRIBUTED CACHE”, filed on Jun. 30, 2020, which is hereby incorporated by reference in its entirety.
Although more recent, high-performance networking may enable distributed caching systems in data centers, challenges remain in sharing network resources among different types of processing nodes and different types of applications with varying traffic demands. For example, certain processing nodes such as Graphics Processing Units (GPUs) may request cache lines from a distributed cache at a rate that is 100 to 10,000 times greater than the cache line request rate of Central Processing Units (CPUs). As a result, such GPUs may monopolize network bandwidth or other network resources, thereby causing cache message loss or significant delay for applications executed by the CPUs. As another example, data intensive, distributed computing applications such as Hadoop or MapReduce may effectively block out less heavy cache demands for scatter-gather applications like web services by, for example, overloading the queues of network switches.
Conventional approaches for resource sharing in a distributed cache are generally not scalable to meet the demands of today's larger and more diverse data centers. Such conventional approaches can include, for example, a static flow scheduling, such as a hash-based flow scheduling, in a tightly time-synchronized environment. Such conventional approaches of network resource sharing are typically not practical for widely varying cache demands caused by different types of processing nodes and different types of applications executed by the processing nodes. For example, heterogeneous processing nodes usually have difficulty remaining synchronized and following an assigned remote memory access schedule for fair network bandwidth allocation. Conventional static flow scheduling is typically based on a maximum data rate of the devices, and the devices often continue to send data despite network bottlenecks and queue overflow at network switches. In addition, conventional hash-based flow scheduling with non-uniform communication can result in hash collisions, which reduce network bandwidth utilization. Accordingly, there is a need for an improved management of network traffic for large-scale distributed caches.
The features and advantages of the embodiments of the present disclosure will become more apparent from the detailed description set forth below when taken in conjunction with the drawings. The drawings and the associated descriptions are provided to illustrate embodiments of the disclosure and not to limit the scope of what is claimed.
In the following detailed description, numerous specific details are set forth to provide a full understanding of the present disclosure. It will be apparent, however, to one of ordinary skill in the art that the various embodiments disclosed may be practiced without some of these specific details. In other instances, well-known structures and techniques have not been shown in detail to avoid unnecessarily obscuring the various embodiments.
Network 112 can include, for example, a Storage Area Network (SAN), a Local Area Network (LAN), and/or a Wide Area Network (WAN), such as the Internet. In this regard, one or more of client devices 114, controller 102, and/or one or more of server racks 101 may not be physically co-located. Server racks 101, controller 102, and client devices 114 may communicate using one or more standards such as, for example, Ethernet, Fibre Channel, and/or InfiniBand.
As shown in the example of
Controller 102 communicates with each of the programmable switches 104 in system 100. In some implementations, controller 102 can include a Software Defined Networking (SDN) controller. As discussed in more detail below, controller 102 can manage network traffic for system 100 with the use of programmable switches 104 based on information provided to controller 102 from programmable switches 104. In addition, controller 102 in some implementations may also maintain a global cache directory for coherence in the permissions and states of cache lines stored in the distributed cache.
Those of ordinary skill in the art will appreciate that other implementations may include a different number or arrangement of memory devices 110, programmable switches 104, or server racks 101 than shown in the example of
Programmable switches 104A, 104B, and 104C route cache messages, such as put requests, get requests, and other communications between client devices 114 and memory devices 110. For example, such cache messages may include a get request for a specific memory address or a permission level request for a client device to modify a cache line requested from a memory device. As discussed in more detail in co-pending application Ser. Nos. 16/697,019 and 16/916,730 incorporated by reference above, such permission levels can be used to maintain the coherency of data across devices in the system.
In some implementations, programmable switches 104 can include, for example, a switch that can be programmed to handle different custom protocols. As discussed in more detail below with reference to
Data planes 106 of programmable switches 104 in the example of
Data planes 106 of programmable switches 104 are programmable and separate from higher-level control planes 108 that determine end-to-end routes for packets between devices in system 100. In this regard, control planes 108 may be used for handling different processes, such as the processes in
In one example, programmable switches 104 can be 64 port ToR P4 programmable switches, such as a Barefoot Networks Tofino Application Specific Integrated Circuit (ASIC) with ports configured to provide 40 Gigabit Ethernet (GE) frame rates. Other types of programmable switches that can be used as a programmable switch 104 can include, for example, a Cavium Xpliant programmable switch or a Broadcom Trident 3 programmable switch.
The use of a programmable switch allows for the configuration of high-performance and scalable memory centric architectures by defining customized packet formats and processing behavior, such as those discussed below with reference to
Controller 102 using global flow control 15 can provide global traffic flow control by, for example, determining cache message transmission rates for client devices 114 and/or weights for queues used by programmable switches 104 in determining an order for sending cache messages. As discussed in more detail below, each programmable switch 104 can provide controller 102 with cache request information extracted from cache messages received from the programmable switch. The extracted cache request information can include, for example, at least one of a cache message request rate for a client device 114, a number of pending cache requests at a client device 114 or memory device 110, a ratio between cache read requests and cache write requests for a client device 114 or memory device 110, and a capacity to receive cache messages at the client device 114 or memory device 110.
As discussed in more detail below with reference to
In addition, each programmable switch 104 can provide controller 102 with queue occupancy information based on the occupancies of its queues. As used herein, queue occupancy information can indicate, for example, an amount or level of pending cache messages in one or more queues used by the programmable switch 104. In some implementations, the queue occupancy information may indicate an average fullness, such as an average queue occupancy percentage, or availability of the queue to receive messages over a period of time. In other implementations, the queue occupancy information may indicate a number of times the queue reached a predetermined threshold level over a period of time. The adjustment of the weights used by programmable switches 104 can ordinarily help ensure that less data intensive applications do not lose cache messages due to more data intensive applications overflowing the queue.
As noted above, the in-line position of programmable switches 104 can provide a more centralized collection of information and management of network traffic, as compared to conventional network traffic management may occur at the end points of the client device 114 and the memory device 110. This can ordinarily provide for less software overhead at the end points, as compared to the use of Remote Direct Memory Access (RDMA). In addition, the processing resources of programmable switches, such as the use of Content Addressable Memory (CAM) or Ternary CAM (TCAM) tables, or other types of match-action tables, can ordinarily provide faster processing of such traffic information than can occur at the end points of the client device 114 or the memory device 110.
In some implementations, memory devices 110 can include, for example, Storage Class Memories (SCMs) or other types of memory, such as Dynamic Random Access Memory (DRAM) or Static RAM (SRAM), that can store and retrieve data at a byte-addressable size or cache line size, as opposed to a page or block size, as in storage devices such as Solid-State Drives (SSDs) or Hard Disk Drives (HDDs). SCMs can include, for example, Chalcogenide RAM (C-RAM), Phase Change Memory (PCM), Programmable Metallization Cell RAM (PMC-RAM or PMCm), Ovonic Unified Memory (OUM), Resistive RAM (RRAM), Ferroelectric Memory (FeRAM), Magnetoresistive RAM (MRAM), 3D-XPoint memory, and/or other types of solid-state memory. Recently developed SCMs can provide non-volatile storage with a fine granularity of access (i.e., byte-addressable or cache line level) and a shorter data access latency, as compared to storage devices, such as an SSD using conventional flash memory or an HDD using a rotating magnetic disk. However, in some implementations, memories such as flash memory, HDDs, other types of storage may be used by memory devices 110 for the distributed cache.
As will be appreciated by those of ordinary skill in the art with reference to the present disclosure, system 100 may include additional devices or a different number of devices than shown in the example of
Processor 1161 can execute instructions, such as instructions from distributed cache module 161, and application(s) 181, which may include an Operating System (OS) and/or other applications used by client device 1141. Processor 1161 can include circuitry such as a Central Processing Unit (CPU), a Graphics Processing Unit (GPU), a microcontroller, a Digital Signal Processor (DSP), an Application-Specific Integrated Circuit (ASIC), a Field Programmable Gate Array (FPGA), hard-wired logic, analog circuitry and/or a combination thereof. In some implementations, processor 1161 can include a System on a Chip (SoC), which may be combined with one or both of memory 1181 and interface 1221. Processor 1161 can include one or more cache levels (e.g., L1, L2, and/or L3 caches) where data is loaded from or flushed into memory 1181, or loaded from or flushed into memory devices 110, such as memory device 1101A in
Memory 1181 can include, for example, a volatile RAM such as SRAM, DRAM, a non-volatile RAM, or other solid-state memory that is used by processor 1161 as an internal main memory to store data. Data stored in memory 1181 can include data read from storage device 1201, data to be stored in storage device 1201, instructions loaded from distributed cache module 161 or application(s) 181 for execution by processor 1161, and/or data used in executing such applications. In addition to loading data from internal main memory 1181, processor 1161 also loads data from memory devices 110 as an external main memory or distributed cache. Such data may also be flushed after modification by processor 1161 or evicted without modification back into internal main memory 1181 or an external main memory device 110 via programmable switch 104A.
As shown in
Storage device 1201 serves as secondary storage that can include, for example, one or more rotating magnetic disks or non-volatile solid-state memory, such as flash memory. While the description herein refers to solid-state memory generally, it is understood that solid-state memory may comprise one or more of various types of memory devices such as flash integrated circuits, NAND memory (e.g., single-level cell (SLC) memory, multi-level cell (MLC) memory (i.e., two or more levels), or any combination thereof), NOR memory, EEPROM, other discrete Non-Volatile Memory (NVM) chips, or any combination thereof. As noted above internal main memory 1181 and external memory devices 110 typically provide faster data access and can provide more granular data access (e.g., cache line size or byte-addressable) than storage device 1201.
Interface 1221 is configured to interface client device 1141 with other devices in system 100, such as programmable switch 104A and memory devices 110. Interface 1221 may communicate using a standard such as, for example, Ethernet, Fibre Channel, or InfiniBand. In this regard, client device 1141, programmable switch 104A, controller 102, and memory device 1101A may not be physically co-located and may communicate over a network such as a LAN or a WAN. As will be appreciated by those of ordinary skill in the art, interface 1221 can be included as part of processor 1161.
Programmable switch 104A in some implementations can be a ToR switch for server rack 101A including memory device 1101A. In the example of
Memory 134A of programmable switch 104A can include, for example, a volatile RAM such as DRAM, or a non-volatile RAM or other solid-state memory such as register arrays that are used by circuitry 132A to execute instructions loaded from switch cache module 26A or firmware of programmable switch 104A, and/or data used in executing such instructions, such as cache directory 12A, queue information 27A, and extracted cache request information 33A. In this regard, and as discussed in more detail below, switch cache module 26A can include instructions for implementing processes such as those discussed with reference to
In the example of
In addition, cache memory module 301A may also be used to implement cache coherency processes and a communication protocol for interfacing with programmable switch 104A. Controller 1361A controls operation of memory device 1101A, and can include circuitry such as a microcontroller, a DSP, an FPGA, an ASIC, hard-wired logic, analog circuitry and/or a combination thereof. In some implementations, controller 1361A can include an SoC, which may be combined with interface 1401A, and/or SCM 1381A. Interface 1401A is configured to interface with at least one port of programmable switch 104A, and may interface according to a standard, such as Ethernet, Fibre Channel, or InfiniBand.
Controller 102 in the example of
In addition, controller 102 may use the collected global cache request information 23 and/or global queue information 24 to determine cache message transmission rates to regulate or control the rates at which client devices 114 and/or memory devices 110 send cache messages to programmable switches 104. As discussed in more detail in related application Ser. Nos. 16/697,019 and 16/916,730 incorporated by reference above, controller 102 may also maintain a global cache directory used for ensuring coherence of the data stored in the distributed cache. Controller 102 may periodically, or in response to changes in global cache request information 23 and/or global queue information 24, send one or more cache message transmission rates to one or more client devices 114 and/or memory devices 110 via a programmable switch 104 to adjust the rate at which the devices send cache messages.
Processor 124 of controller 102 executes global flow control 15 to adjust queue weights and cache message transmission rates, as needed. Processor 124 also executes cache controller module 22, which in some embodiments, may be used maintain a global cache directory or perform other processes for maintaining coherency of data in the distributed cache. In some implementations, global flow control 15 may form part of cache controller module 22. As noted above, controller 102 may be considered an SDN controller in some implementations.
Processor 124 can include circuitry such as a CPU, a GPU, a microcontroller, a DSP, an ASIC, an FPGA, hard-wired logic, analog circuitry and/or a combination thereof. In some implementations, processor 124 can include an SoC, which may be combined with one or both of memory 126 and interface 128. Memory 126 can include, for example, a volatile RAM such as DRAM, a non-volatile RAM, or other solid-state memory that is used by processor 124 to store data. Controller 102 communicates with programmable switches 104 via interface 128, which is configured to interface with ports of programmable switches 104, and may interface according to a standard, such as Ethernet, Fibre Channel, or InfiniBand.
As will be appreciated by those of ordinary skill in the art with reference to the present disclosure, other implementations may include a different arrangement or number of components, or modules than shown in the example of
In the example of
As noted above, the extracted cache request information may include information provided by a client device 114 or a memory device 110 to indicate a level of usage of the distributed cache by a client device 114 or a level of usage of a memory device 110 as part of the distributed cache. The cache request information can include, for example, at least one of a cache message request rate for the device, a number of pending cache requests at the device, a ratio between cache read requests and cache write requests for the device, and a capacity to receive cache messages at the device.
The priority indicator extracted by parser module 361 may include an indication of a type of the message or a class of service for the message. For example, parser module 361 may extract a priority indicator of an 802.1Q tag from an Ethernet packet having the format shown in the example of
In some cases, different priorities may be used to classify different types of cache messages for handling by different queues of programmable switch 104A. For example, web services applications needing relatively low latency access to the distributed cache may be assigned a first priority indicator by the client device sending the message for a time sensitive Quality of Service (QoS). Programmable switch 104A may then classify or add such packets to a first type of egress queue that serves or sends more packets per round or clock cycle than another type of queue.
As another example, more data intensive applications, such as distributed computing applications (e.g., Hadoop or MapReduce), may be assigned a second priority indicator for a data intensive service class so that programmable switch 104A classifies or adds such packets to a second type of egress queue that serves less packets per round or clock cycle that are part of a larger data flow. In some cases, controller 102 may dynamically adjust the priority indicators used by client devices 114 during operation to help ensure smaller data flows are not blocked by larger data flows.
In another example, certain applications may use a priority indicator for a class of service associated with a greater reliability. In such cases, programmable switch 104A may classify or add such packets to a relatively large egress queue that is less likely to overflow and drop packets. This is in contrast to a traditional First In First Out (FIFO) handling of packets by network switches that does not account for the size of data flows.
As shown in
As discussed in more detail below with reference to
Stages 362 and 363 can include, for example programmable Arithmetic Logic Units (ALUs) and one or more memories that store match-action tables for matching extracted values from the headers and performing different corresponding actions based on the values, such as performing particular updates to cache directory 12A stored in memory 134A of programmable switch 104A or forwarding extracted cache request information to controller 102. In some implementations, the stages of the ingress pipeline and the egress pipeline may share a single memory, such as memory 134A in
Traffic manager 38 routes the cache line messages to appropriate ports of programmable switch 104A. As shown in
In addition, the use of a first queue occupancy threshold value can allow programmable switch 104A to absorb additional cache messages that may be in transit following a lowering of the cache transmission rate of a client device 114 by controller 102. In some implementations, traffic manager 38 of programmable switch 104A may also monitor the packet reception rate for different egress queues, and send a pause frame to a client device 114 that has exceeded its assigned cache message transmission rate from controller 102 or a maximum bandwidth set by programmable switch 104 or controller 102 for the client device 114.
Traffic manager 38 in the example of
In the example of
As will be appreciated by those of ordinary skill in the art, other implementations may include a different arrangement of modules for a programmable switch. For example, other implementations may include more or less stages as part of the ingress or egress pipeline.
In the example of
In addition, each queue has, for example, a first threshold value 48 and a second threshold value 50. The threshold values may, for example, correspond to a number of cache messages pending in the queue, a number of remaining cache messages that can be queued, a percentage of queue fullness, or other indicator of queue occupancy. When the queued cache messages reach the first threshold value 48, programmable switch 104 sends a pause frame to at least one client device 114 to temporarily stop the at least one client device 114 from sending additional cache messages. The packet reception rate control of traffic manager 38 may identify a client device 114 filling the queue that has the greatest packet reception rate or that has exceeded a maximum bandwidth guarantee.
In other implementations, traffic manager 38 may send pause frames to each of the client devices 114 that have cache messages already queued in the queue. Programmable switch 104 may use, for example, an 802.1Qbb pause frame of a Priority-Based Flow Control (PFC) that may have an associated timer for how long the client device 114 should stop sending additional packets to the programmable switch 104, depending on the priority indicator of the packets. When the selection of queues by programmable switch 104 is made based on such priority indicators, programmable switch 104 may use the priority indicators to identify cache messages and client devices 114 filling queues that have reached a threshold value. In addition, the pause time for the different types of data traffic indicated by the priority indicators can correspond to times typically associated with clearing a queue or reducing the queued cache messages below a threshold value (e.g., threshold value 48). The use of different pause times for different priority indicators can facilitate better management of the queues based on the particular types of data flow, types of client devices 114, classes of service, and/or the sizes of the queues.
In this regard, different priority indicators may be associated with different applications via the distributed cache modules 16 executed by client devices 114. As discussed in more detail below with reference to the example packet format of
In the example of
In
The thresholds values 48 and 50 may initially be set by programmable switch 104 or controller 102 based on considerations such as, for example, a maximum cache message size, a buffer size for temporarily storing data of the queued cache messages, a bit rate of the port associated with the queue, a measured or estimated network latency for transmitting messages between a client device 114 and programmable switch 104, and a cache message processing latency of programmable switch 104. Programmable switch 104 or controller 102 may adjust threshold values 48 and 50 over time based on such considerations and/or the tendency of particular queues to reach one or both of threshold values 48 and 50, or to completely fill up.
Those of ordinary skill in the art will appreciate with reference to the present disclosure that other implementations of queues managed by programmable switch 104 may vary. For example, other implementations may use a different number of queues for a port, queues of all equal size, or only a different number of threshold values for sending pause frames, such as a single threshold value.
The payload of the example frame shown in
In some implementations, cache request information 64 may not be present in every cache message packet received by programmable switch. For example, client devices 114 and/or memory devices 110 may only send cache request information 64 at a particular interval, or when a particular condition is reached, such as when a queue of the client device 114 or memory device 110 reaches a threshold.
In some cases, a memory device 110 may include cache request information when a queue for performing write requests or a queue for performing read requests reaches a threshold indicating a delay in performing the write or read requests. If a cache message from the memory device 110 includes cache request information 64 that, for example, indicates a low read to write ratio and a full read request queue, controller 102 after receiving the cache request information may lower a cache message transmission rate for a client device 114 that has been sending cache write requests to the memory device 110 to allow the memory device 110 to perform more cache read requests. As another example, a client device 114 may include cache request information 64 in an outgoing packet when its queue for sending cache messages reaches a high threshold. Controller 102 may then increase the cache message transmission rate for that client device 114 after receiving the cache request information from programmable switch 104.
In other implementations, cache request information 64 may be included in every packet to provide a current view of the state of system 100. Programmable switch 104 may accumulate the cache request information to send to controller 102 in batches or may selectively send the extracted cache request information to controller 102 based on detected packet reception rates and/or queue occupancies. In some implementations, controller 102 may perform network sniffing or otherwise retrieve the cache request information 64 included in the packets.
The Ethernet packet format in the example of
In addition to the PCP field, the example of
As discussed above, the priority indicator can be used by programmable switch 104 to determine a queue for the cache message among a plurality of queues for transmission via a particular port of programmable switch 104. In the example of
Additionally or alternatively, priority indicator 60 can be used to indicate different types of client devices 114. For example, different types of client devices 114 such as FPGAs, CPUs, GPUs, or ASICs may be assigned a value for all of its priority indicators 60 or a range of values depending on the types of applications executed by the client device 114. The use of priority indicators across system 100 for the distributed cache can ordinarily allow for a more diverse or heterogenous use of different client devices 114, and a wider variety of applications that may have different demands on the distributed cache in terms of reliability, the rate of cache messages, and the size of message flows.
The OpCode field can indicate an operation type for an intended operation to be performed using a requested cache line or cache lines, such as an acquire to read or an acquire to read and write. In other cases, the OpCode field can indicate whether the packet is a probe to change the permission level of a client device 114 with respect to a cache line, or a probe acknowledgment to indicate that a permission level has been changed. In this regard, the parameter field of custom header 30 can indicate a current or requested permission level from the device sending the packet.
The size field of header 30 can indicate the size of the data requested (e.g., a number of cache lines or a size in bytes) or the size of the data provided in payload 32. The domain field in
As will be appreciated by those of ordinary skill in the art in light of the present disclosure, other message or packet formats can be used with programmable switches 104 for cache messages. For example, other implementations may include the priority indicator in the payload, as opposed to a separate 802.1Q tag.
The cache request information can indicate a usage of the distributed cache, such as by, for example, indicating at least one of a cache message request rate for cache messages sent from a client device 114 or cache messages received by a memory device 110, a number of pending cache requests waiting to be sent from the client device 114 or waiting to be performed by the memory device 110, a ratio between cache read requests and cache write requests sent by the client device 114 or received by the memory device 110, and a capacity to receive cache messages at the client device 114 or at the memory devices, such as an available queue size or queue occupancy for received cache messages.
The received cache messages are queued by the programmable switch 104 in egress queues before being sent out via a port of the programmable switch. In addition to considering the destination address for the cache message, the cache messages may be queued based on information included in the cache message, such as a priority indicator or the size of a current data flow that includes the cache message.
Programmable switch 104 sends the extracted cache request information to controller 102. In some implementations, programmable switch 104 may send all of the extracted cache request information to controller 102 for each cache message, such as by mirroring the extracted cache request information received by programmable switch to one or more ports used to communicate with controller 102. In other implementations, programmable switch 104 may accumulate extracted cache request information until reaching a certain amount of cache request information or until receiving a request from controller 102 for the cache request information. In yet other implementations, controller 102 may perform network sniffing to check on the cache request information stored at programmable switch 104.
In the example of
For its part, controller 102 determines at least one of one or more cache message transmission rates for at least one client device 114, and/or determines one or more weights for the queues used by programmable switch 104 in determining an order for sending cache messages. In some implementations, the determination of cache message transmission rates or weights for the queues may be based on one of or both of the received cache request information and queue occupancy information. In this regard, controller 102 may collect or aggregate cache request information and/or queue occupancy information from multiple programmable switches 104 in system 100 to estimate network traffic demand and avoid potential bottlenecks by proactively adjusting cache message transmission rates and/or queue weights during runtime.
Controller 102 sends the determined queue weights to programmable switch 104. In response, programmable switch 104 adjusts the weights used for servicing its queues based on the received weights from controller 102. In some implementations, the weights may indicate a certain number of cache messages serviced from each queue in a given round, as in a weighted round robin scheduling. In other implementations, the weights may indicate an order in which queues are serviced.
Controller 102 also sends the one or more determined cache message transmission rates to programmable switch 104 for forwarding to client devices 114. The cache message transmission rates may be adjusted dynamically as the client devices 114 operate. In this regard, the change to a cache message transmission rate may be temporary to quickly react (e.g., within microseconds) to network congestion and avoid a queue overflow.
Those of ordinary skill in the art will appreciate with reference to the present disclosure that the sequence of operations shown in
In block 702, programmable switch 104 receives cache messages for a distributed cache. As discussed above, programmable switch 104 can identify the cache messages as being for the distributed cache by, for example, parsing a header (e.g., header 62 in
In block 704, the received cache messages are queued in queues for sending the cache messages from ports of programmable switch 104. The cache messages may first be routed by match-action stages of the programmable switch to specific ports based on, for example, a MAC address for the destination client device 114 or destination memory device 110.
A priority indicator extracted from the cache message may be used to assign the cache message to a queue that is serviced by the port. As discussed above, the priority indicator may be used to dynamically assign (e.g., during operation of the client device 114) the message flows of a particular application to the same class of service, which can help reduce completion time for the application. In addition, message flows may be dynamically mapped based on the size or an expected size of the message flow. For example, a heavy message flow may be identified by controller 102 via cache request information received from programmable switch 104, and controller 102 may then send the client device 114 responsible for the heavy message flow a lower cache message transmission rate or a new priority indicator for the client device 114. Such dynamic traffic flow control can ordinarily better balance the use of network resources to help prevent smaller message flows or sole cache messages from being blocked by heavier message flows.
In block 706, programmable switch 104 generates queue occupancy information based on its monitoring of the queue occupancies of the queues. The queue occupancy information may indicate, for example, an average queue occupancy over a period of time or may indicate a number of low and high threshold values reached over the period of time. In other implementations, the queue occupancy information can include a relative scoring of the occupancies of the queues.
In block 708, programmable switch 104 sends the generated queue occupancy information to controller 102. The queue occupancy information is used by controller 102, such as by global flow control 15 in
In block 802, programmable switch 104 receives a cache message from a client device 114 or from a memory device 110. In this regard, the cache message may be received from a client device 114 to obtain one or more cache lines stored in the distributed cache, or from a memory device 110 to provide a client device 114 with one or more cache lines. In some cases, the cache message may include one or more cache lines that have been modified by the client device 114 for storage at a memory device 110. In yet other cases, the cache message may include a coherency message, such as an acknowledgment of an operation or a request for a permission level to modify one or more cache lines.
In block 804, programmable switch 104 extracts cache request information from the cache message. As discussed above, the cache request information may be extracted by ingress stages of the programmable switch (e.g., stages 362 and 363 in
In block 806, programmable switch 104 sends the extracted cache request information to controller 102 to determine at least one of one or more cache message transmission rates for client devices 114 and one or more queue weights used by programmable switch 104. The determined weights and/or cache message transmission rates can then be sent to programmable switch 104 for adjusting the operation of the queues and/or the transmission rates of cache messages. As with the queue occupancy information process of
In block 902, controller 102 receives queue occupancy information from at least one programmable switch 104. In this regard, controller 102 may receive queue occupancy information from multiple programmable switches 104, such as from each of programmable switches 104 in the example of
In block 904, controller 102 receives cache request information from at least one programmable switch 104. In this regard, controller 102 may receive cache request information from multiple programmable switches 104, such as from each programmable switch 104 in the example of
In block 906, controller 102 determines at least one of one or more cache message transmission rates for one or more client devices 114, and one or more queue weights for one or more programmable switches 104 based at least in part on the received queue occupancy information and/or the received cache request information. As discussed above, the collection of such information by controller 102 during operation of system 100 can ordinarily allow controller 102 to adjust the network traffic for the distributed cache to reduce network traffic congestion and improve the reliability of the distributed cache by avoiding queue overflow. In some cases, this can facilitate the use of Transmission Control Protocol (TCP) in large scale data centers that may provide less synchronization among devices and can have non-uniform or scatter-gather traffic flows.
Those of ordinary skill in the art with reference to the present disclosure will appreciate that the blocks of
In block 1002, controller 102 collects or aggregates at least one of queue occupancy information and cache request information that is received from at least one programmable switch 104. The collection or aggregation of queue occupancy information and/or cache request information may be through one or more programmable switches 104 periodically sending the information based on a schedule or in response to certain conditions at the programmable switch, such as a level of incoming cache messages or the level of occupancy of one or more queues used by the programmable switch for sending cache messages. In some cases, controller 102 may alternatively or additionally receive the information from one or more programmable switches through network sniffing to access the information stored at the programmable switch or by mirroring packets received at the programmable switch 104 to controller 102.
The collected or aggregated cache request information may be stored in a data structure in a memory of controller 102, such as in global cache request information 23 in memory 126 in the example of
In block 1004, controller 102 estimates network traffic based on the information collected in block 1002. Controller 102 may collect or aggregate the information for a particular period of time, such as for the previous five minutes or over a period of days, for example. In other implementations, the collection or aggregation of information may be only for the most recent, or a predetermined set of the most recent cache request information and/or queue occupancy information received from each programmable switch 104 in system 100.
In some cases, controller 102 may use both the queue occupancy information and the cache request information received from a programmable switch 104 to estimate network traffic for the programmable switch 104 that sent the information. In addition to adjusting cache message transmission rates and/or queue weights as discussed above, controller 102 may use the estimated network traffic to remap message or data flows in system 100. For example, controller 102 may use a global cache directory stored at controller 102 to identify copies of cache lines stored in different racks 101. Controller 102 may then reconfigure a programmable switch 104 of the higher traffic rack 101 to reroute cache request messages for cache lines to their copies in a lower traffic rack 101, or inform one or more client devices 114 of the address for the memory device 110 in the lower traffic rack 101 that stores the copy.
In block 1102, programmable switch 104 determines threshold values for one or more queues used by the programmable switch for sending cache messages from one or more ports. As indicated by the dashed line following block 1102, the determination of threshold values in block 1102 may be performed at a different time than the performance of blocks 1104 to 1112. The determination of the threshold values can be based on at least one of a maximum cache message size, a buffer size for storing data from queued cache messages, a bit rate for one or more ports of programmable switch 104, a network latency for transmitting messages between at least one client device 114 and programmable switch 104, and a cache message processing latency of programmable switch 104. In some implementations, one or more default values may be set based on some or all of the foregoing factors as part of an initialization process of programmable switch 104. The threshold values may then be adjusted during operation of the programmable switch based on updated values for some or all of the foregoing factors.
In block 1104, programmable switch 104 determines whether a queue occupancy threshold value has been reached. With reference to the example of queues A, B, and C discussed above for
On the other hand, if it is determined in block 1104 that the first threshold value has been reached, programmable switch 104 in block 1108 sends a pause frame to at least one client device 114 to temporarily stop the at least one client device 114 from sending additional cache messages to programmable switch 104. The pause frame may be sent to a client device 114 that is responsible for filling the queue that has the greatest incoming packet reception rate or that has exceeded a reception rate allocated to the client device 114. In some implementations, the pause frame may include an indication of how long the at least one client device 114 should stop sending additional cache messages, which may be associated with specific priority indicators or the particular queue that has reached the threshold value. In other implementations, all pause frames sent by programmable switch 104 may cause the client device 114 to stop sending additional cache messages for the same amount of time, regardless of the queue or priority indicator. The pause frame may include, for example, an 802.1Qbb pause frame.
In block 1110, programmable switch 104 determines whether the queue occupancy for the queue has reached an additional threshold hold value. With reference to the example of
On the other hand, if it is determined in block 1110 that the second threshold value has been reached, programmable switch 104 in block 1112 sends a pause frame to one or more additional client devices 114 to temporarily stop the one or more additional client devices 114 from sending additional cache messages to programmable switch 104. The pause frame may be sent to all the remaining client devices 114 responsible for filling the queue, or in some implementations, to the client device 114 or a predetermined number of client devices 114 that currently have the greatest incoming packet reception rate, or that have exceeded a reception rate allocated to the client device or devices 114.
The foregoing queue occupancy control process can ordinarily allow programmable switch 104 to quickly react to prevent the loss of packets or cache messages due to overflow of its queues. The implementation of such network traffic control from the centralized location of programmable switch 104 between client devices 114 and memory devices 110 further allows for a faster and more dynamic control of data flows and congestion than conventional, lossy Ethernet flow control that may be performed by the end nodes (e.g., client devices 114 and memory devices 110). In this regard, the use of programmable switch 104 for such flow control can also free up processing resources at the end nodes, while providing a faster response time.
Those of ordinary skill in the art will appreciate with reference to the present disclosure that other implementations may have a different order of blocks than shown in
In block 1202, programmable switch 104 receives a cache message from a device, such as a client device 114 or a memory device 110. The cache message may indicate a destination address, such as a MAC address for a destination client device 114 or destination memory device 110. Based on the parsed destination address, one or more ingress stages (e.g., ingress stage 362 or 363 in
In block 1204, programmable switch 104 determines whether a size of a message flow including the cache message is greater than a threshold size. Information included in cache messages of the message flow may indicate that the cache messages belong to the same message flow, or programmable switch 104 may identify the cache messages as belonging to the same cache flow by the receipt of a predetermined number of cache messages within a predetermined time window from the same sending device to be sent to the same destination device. Programmable switch 104 may keep track of the number of cache messages received from the same sending device that are to be sent to the same destination device within a predetermined window of time to update a message count indicating the size of the message flow.
If it is determined that the cache message received in block 1202 is part of a message flow that is greater than the threshold size, programmable switch 104 in block 1206 identifies a queue that is used for larger message flows from among a plurality of queues for the port. With reference to the example queues of
On the other hand, if the cache message received in block 1202 is not part of a message flow or is part of a message flow that is less than or equal to the threshold size in block 1204, programmable switch 104 in block 1208 extracts a priority indicator from the cache message. In some implementations, the priority indicator may include an 802.1Qbb priority tag that may indicate a class of service for the cache message. Other implementations may include a different type of priority indicator.
In block 1210, programmable switch 104 identifies a queue associated with the value of the priority indicator from among multiple queues used for the port. With reference to the example queues of
Those of ordinary skill in the art will appreciate that other implementations of the queue identification process of
As discussed above, the foregoing use of a centralized programmable switch (e.g., programmable switch 104) and centralized controller (e.g., controller 102) to dynamically monitor and control network traffic for a distributed cache can better manage the non-uniform traffic patterns and variety of client devices found in today's larger data centers. In addition, the use of the programmable switches, controller, and processes discussed above can ordinarily provide faster responses that prevent overflowing a queue and the resulting packet or cache message loss, while not incurring additional computational penalty at the end nodes (e.g., client devices 114 or memory devices 110).
Those of ordinary skill in the art will appreciate that the various illustrative logical blocks, modules, and processes described in connection with the examples disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. Furthermore, the foregoing processes can be embodied on a computer readable medium which causes processor or controller circuitry to perform or execute certain functions.
To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, and modules have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Those of ordinary skill in the art may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
The various illustrative logical blocks, units, modules, processor circuitry, and controller circuitry described in connection with the examples disclosed herein may be implemented or performed with a general purpose processor, a GPU, a DSP, an ASIC, an FPGA or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. Processor or controller circuitry may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, an SoC, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The activities of a method or process described in connection with the examples disclosed herein may be embodied directly in hardware, in a software module executed by processor or controller circuitry, or in a combination of the two. The steps of the method or algorithm may also be performed in an alternate order from those provided in the examples. A software module may reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable media, an optical media, or any other form of storage medium known in the art. An exemplary storage medium is coupled to processor or controller circuitry such that the processor or controller circuitry can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to processor or controller circuitry. The processor or controller circuitry and the storage medium may reside in an ASIC or an SoC.
The foregoing description of the disclosed example embodiments is provided to enable any person of ordinary skill in the art to make or use the embodiments in the present disclosure. Various modifications to these examples will be readily apparent to those of ordinary skill in the art, and the principles disclosed herein may be applied to other examples without departing from the spirit or scope of the present disclosure. The described embodiments are to be considered in all respects only as illustrative and not restrictive. In addition, the use of language in the form of “at least one of A and B” in the following claims should be understood to mean “only A, only B, or both A and B.”
Number | Name | Date | Kind |
---|---|---|---|
6044438 | Olnowich | Mar 2000 | A |
6078997 | Young et al. | Jun 2000 | A |
6108737 | Sharma et al. | Aug 2000 | A |
6209065 | Van Doren et al. | Mar 2001 | B1 |
6230243 | Elko et al. | May 2001 | B1 |
6263404 | Borkenhagen et al. | Jul 2001 | B1 |
6298418 | Fujiwara et al. | Oct 2001 | B1 |
6343346 | Olnowich | Jan 2002 | B1 |
6775804 | Dawson | Aug 2004 | B1 |
6829683 | Kuskin | Dec 2004 | B1 |
6868439 | Basu et al. | Mar 2005 | B2 |
6954844 | Lentz et al. | Oct 2005 | B2 |
6993630 | Williams et al. | Jan 2006 | B1 |
7032078 | Cypher et al. | Apr 2006 | B2 |
7376799 | Veazey et al. | May 2008 | B2 |
7673090 | Kaushik et al. | Mar 2010 | B2 |
7716425 | Uysal et al. | May 2010 | B1 |
7975025 | Szabo et al. | Jul 2011 | B1 |
8166251 | Luttrell | Apr 2012 | B2 |
8281075 | Arimilli et al. | Oct 2012 | B2 |
9088592 | Craft et al. | Jul 2015 | B1 |
9313604 | Holcombe | Apr 2016 | B1 |
9442850 | Rangarajan et al. | Sep 2016 | B1 |
9467380 | Hong et al. | Oct 2016 | B2 |
9712381 | Emanuel et al. | Jul 2017 | B1 |
9819739 | Hussain et al. | Nov 2017 | B2 |
9825862 | Bosshart | Nov 2017 | B2 |
9826071 | Bosshart | Nov 2017 | B2 |
9880768 | Bosshart | Jan 2018 | B2 |
9910615 | Bosshart | Mar 2018 | B2 |
9912610 | Bosshart et al. | Mar 2018 | B2 |
9923816 | Kim et al. | Mar 2018 | B2 |
9936024 | Malwankar et al. | Apr 2018 | B2 |
9940056 | Bosshart | Apr 2018 | B2 |
10038624 | Cruz et al. | Jul 2018 | B1 |
10044583 | Kim et al. | Aug 2018 | B2 |
10050854 | Licking et al. | Aug 2018 | B1 |
10063407 | Kodeboyina et al. | Aug 2018 | B1 |
10063479 | Kim et al. | Aug 2018 | B2 |
10063638 | Huang | Aug 2018 | B2 |
10067967 | Bosshart | Sep 2018 | B1 |
10075567 | Licking et al. | Sep 2018 | B1 |
10078463 | Bosshart | Sep 2018 | B1 |
10084687 | Sharif et al. | Sep 2018 | B1 |
10110454 | Kim et al. | Oct 2018 | B2 |
10127983 | Peterson et al. | Nov 2018 | B1 |
10133499 | Bosshart | Nov 2018 | B2 |
10146527 | Olarig et al. | Dec 2018 | B2 |
10158573 | Lee et al. | Dec 2018 | B1 |
10164829 | Watson et al. | Dec 2018 | B1 |
10169108 | Gou et al. | Jan 2019 | B2 |
10225381 | Bosshart | Mar 2019 | B1 |
10230810 | Bhide et al. | Mar 2019 | B1 |
10237206 | Agrawal et al. | Mar 2019 | B1 |
10257122 | Li et al. | Apr 2019 | B1 |
10268634 | Bosshart et al. | Apr 2019 | B1 |
10298456 | Chang | May 2019 | B1 |
10496566 | Olarig et al. | Dec 2019 | B2 |
10628353 | Prabhakar et al. | Apr 2020 | B2 |
10635316 | Singh et al. | Apr 2020 | B2 |
10761995 | Blaner et al. | Sep 2020 | B2 |
10812388 | Thubert et al. | Oct 2020 | B2 |
10880204 | Shalev et al. | Dec 2020 | B1 |
20030009637 | Arimilli et al. | Jan 2003 | A1 |
20030028819 | Chiu et al. | Feb 2003 | A1 |
20030158999 | Hauck et al. | Aug 2003 | A1 |
20040044850 | George et al. | Mar 2004 | A1 |
20040073699 | Hong et al. | Apr 2004 | A1 |
20040260883 | Wallin et al. | Dec 2004 | A1 |
20050058149 | Howe | Mar 2005 | A1 |
20060265568 | Burton | Nov 2006 | A1 |
20070067382 | Sun | Mar 2007 | A1 |
20080010409 | Rao et al. | Jan 2008 | A1 |
20090240664 | Dinker et al. | Sep 2009 | A1 |
20090240869 | O'Krafka et al. | Sep 2009 | A1 |
20090313503 | Atluri et al. | Dec 2009 | A1 |
20100008260 | Kim et al. | Jan 2010 | A1 |
20100223322 | Mott et al. | Sep 2010 | A1 |
20110004729 | Akkawi et al. | Jan 2011 | A1 |
20110093925 | Krishnamoorthy et al. | Apr 2011 | A1 |
20110238923 | Hooker et al. | Sep 2011 | A1 |
20120110108 | Li et al. | May 2012 | A1 |
20120155264 | Sharma | Jun 2012 | A1 |
20130254325 | Song et al. | Sep 2013 | A1 |
20130263249 | Song et al. | Oct 2013 | A1 |
20140219284 | Chau et al. | Aug 2014 | A1 |
20140241361 | Bosshart et al. | Aug 2014 | A1 |
20140269413 | Hui et al. | Sep 2014 | A1 |
20140269716 | Pruss et al. | Sep 2014 | A1 |
20140278575 | Anton et al. | Sep 2014 | A1 |
20140331001 | Liu et al. | Nov 2014 | A1 |
20140362709 | Kashyap et al. | Dec 2014 | A1 |
20150195216 | Di Pietro et al. | Jul 2015 | A1 |
20150301949 | Koka et al. | Oct 2015 | A1 |
20150319243 | Hussain et al. | Nov 2015 | A1 |
20150378919 | Anantaraman et al. | Dec 2015 | A1 |
20160050150 | Venkatesan et al. | Feb 2016 | A1 |
20160099872 | Kim et al. | Apr 2016 | A1 |
20160127492 | Malwankar et al. | May 2016 | A1 |
20160156558 | Hong et al. | Jun 2016 | A1 |
20160216913 | Bosshart | Jul 2016 | A1 |
20160246507 | Bosshart | Aug 2016 | A1 |
20160246535 | Bosshart | Aug 2016 | A1 |
20160294451 | Jung | Oct 2016 | A1 |
20160315964 | Shetty et al. | Oct 2016 | A1 |
20160323189 | Ahn | Nov 2016 | A1 |
20170026292 | Smith et al. | Jan 2017 | A1 |
20170054618 | Kim | Feb 2017 | A1 |
20170054619 | Kim | Feb 2017 | A1 |
20170063690 | Bosshart | Mar 2017 | A1 |
20170064047 | Bosshart | Mar 2017 | A1 |
20170093707 | Kim et al. | Mar 2017 | A1 |
20170093986 | Kim et al. | Mar 2017 | A1 |
20170093987 | Kaushalram et al. | Mar 2017 | A1 |
20170187846 | Shalev | Jun 2017 | A1 |
20170214599 | Seo et al. | Jul 2017 | A1 |
20170286363 | Joshua et al. | Oct 2017 | A1 |
20170371790 | Dwiel et al. | Dec 2017 | A1 |
20180034740 | Beliveau et al. | Feb 2018 | A1 |
20180060136 | Herdrich et al. | Mar 2018 | A1 |
20180173448 | Bosshart | Jun 2018 | A1 |
20180176324 | Kumar et al. | Jun 2018 | A1 |
20180234340 | Kim et al. | Aug 2018 | A1 |
20180234355 | Kim et al. | Aug 2018 | A1 |
20180239551 | Bosshart | Aug 2018 | A1 |
20180242191 | Lundqvist | Aug 2018 | A1 |
20180260330 | Felter et al. | Sep 2018 | A1 |
20180262459 | Wang et al. | Sep 2018 | A1 |
20180285275 | Barczak et al. | Oct 2018 | A1 |
20180329818 | Cheng et al. | Nov 2018 | A1 |
20180335953 | Ramaswamy et al. | Nov 2018 | A1 |
20180337860 | Kim et al. | Nov 2018 | A1 |
20180349163 | Gao et al. | Dec 2018 | A1 |
20180349285 | Ish et al. | Dec 2018 | A1 |
20190012278 | Sindhu et al. | Jan 2019 | A1 |
20190044878 | Steffen et al. | Feb 2019 | A1 |
20190050333 | Chacon et al. | Feb 2019 | A1 |
20190058646 | Kim et al. | Feb 2019 | A1 |
20190087341 | Pugsley et al. | Mar 2019 | A1 |
20190196987 | Shen et al. | Jun 2019 | A1 |
20190220429 | Ranjan et al. | Jul 2019 | A1 |
20190227921 | Frolikov | Jul 2019 | A1 |
20190342785 | Li et al. | Nov 2019 | A1 |
20190354402 | Bivens et al. | Nov 2019 | A1 |
20190370176 | Priyadarshi et al. | Dec 2019 | A1 |
20190391928 | Lin | Dec 2019 | A1 |
20190394261 | DeCusatis et al. | Dec 2019 | A1 |
20200007408 | Siddappa | Jan 2020 | A1 |
20200065269 | Balasubramani et al. | Feb 2020 | A1 |
20200068014 | Sarkar | Feb 2020 | A1 |
20200089619 | Hsu et al. | Mar 2020 | A1 |
20200097212 | Lakshman et al. | Mar 2020 | A1 |
20200151104 | Yang | May 2020 | A1 |
20200213156 | Cheng et al. | Jul 2020 | A1 |
20200226068 | Gellerich et al. | Jul 2020 | A1 |
20200250099 | Campbell et al. | Aug 2020 | A1 |
20200293499 | Kohli et al. | Sep 2020 | A1 |
20200313999 | Lee et al. | Oct 2020 | A1 |
20200349080 | Radi et al. | Nov 2020 | A1 |
20200379668 | Akaike et al. | Dec 2020 | A1 |
20210034250 | Mizuno et al. | Feb 2021 | A1 |
20210034270 | Gupta et al. | Feb 2021 | A1 |
20210049078 | Khan et al. | Feb 2021 | A1 |
20210051751 | Pawar | Feb 2021 | A1 |
20210073086 | Subraya et al. | Mar 2021 | A1 |
20210149807 | Gupta et al. | May 2021 | A1 |
20210173589 | Benisty et al. | Jun 2021 | A1 |
20210194828 | He et al. | Jun 2021 | A1 |
20210218623 | Jain et al. | Jul 2021 | A1 |
20210247935 | Beygi et al. | Aug 2021 | A1 |
20210266219 | Kim et al. | Aug 2021 | A1 |
20210294506 | Tadokoro | Sep 2021 | A1 |
20210318828 | Valtonen | Oct 2021 | A1 |
Number | Date | Country |
---|---|---|
102163279 | Oct 2020 | KR |
Entry |
---|
International Search Report and Written Opinion dated Oct. 28, 2021 from International Application No. PCT/US2021/039070, 7 pages. |
Liu et al.; “DistCache: provable load balancing for large-scale storage systems with distributed caching”; FAST '19: Proceedings of the 17th USENIX Conference on File and Storage Technologies; Feb. 2019; pp. 143-157 (Year 2019). |
Radi et al.; “OmniXtend: direct to caches over commodity fabric”; 2019 IEEE Symposium on High-Performance Interconnects (HOTI); Santa Clara, CA; Aug. 2019; pp. 59-62 (Year 2019). |
Wang et al.; “Concordia: Distributed Shared Memory with In-Network Cache Coherence”; 19th USENIX Conference on File and Storage Technologies; pp. 277-292; Feb. 2021. |
Ibrar et al.; “PrePass-Flow: A Machine Learning based Technique to Minimize ACL Policy Violation Due to Links Failure in Hybrid SDN”; Nov. 20, 2020; Computer Networks; available at https://doi.org/10.1016/j.comnet.2020.107706. |
Saif et al.; “IOscope: A Flexible I/O Tracer for Workloads' I/O Pattern Characterization”; Jan. 25, 2019; International Conference on High Performance Computing; available at https://doi.org/10.1007/978-3-030-02465-9_7. |
Zhang et al.; “PreFix Switch Failure Prediction in Datacenter Networks”; Mar. 2018; Proceedings of the ACM on the Measurement and Analysis of Computing Systems; available at: https://doi.org/10.1145/3179405. |
Pending U.S. Appl. No. 17/353,781, filed Jun. 21, 2021, entitled “In-Network Failure Indication and Recovery”, Marjan Radi et al. |
Pending U.S. Appl. No. 17/331,453, filed May 26, 2021, entitled “Distributed Cache Management”, Marjan Radi et al. |
Stefanovici et al.; “Software-Defined Caching: Managing Caches in Multi-Tenant Data Centers”; Aug. 2015; pp. 174-181; SoCC '15: Proceedings of the Sixth ACM Symposium on Cloud Computing; available at: http://dx.doi.org/10.1145/2806777.2806933. |
Mahmood et al.; “Efficient Caching through Stateful SDN in Named Data Networking”; Dec. 14, 2017; Transactions on Emerging Telecommunications Technologies; vol. 29, issue 1; available at: https://onlinelibrary.wiley.com/doi/abs/10.1002/ett.3271. |
Liu et al.; “DistCache: Provable Load Balancing for Large-Scale Storage Systems with Distributed Caching”; Feb. 2019; Proceedings of the 17th USENIX Conference on File and Storage Technologies; available at: https://www.usenix.org/conference/fast19/presentation/liu. |
Hashemi et al.; “Learning Memory Access Patters”; 15 pages; Mar. 6, 2018; available at https://arxiv.org/pdf/1803.02329.pdf. |
Kim, et al.; “A Framework for Data Prefetching using Off-line Training of Markovian Predictors”; Sep. 18, 2002; 8 pages; available at https://www.comp.nus.edu.sg/˜wongwf/papers/ICCD2002.pdf. |
Eisley et al.; “In-Network Cache Coherence”; 2006; pp. 321-332; Proceedings of the 39th Annual IEEE/ACM International Symposium on Microarchitecture. |
Jin et al.; “NetCache: Balancing Key-Value Stores with Fast In-Network Caching”; Oct. 28, 2017; pp. 121-136; Proceedings of the 26th Symposium on Operating Systems Principles. |
Li et al.; “Pegasus: Load-Aware Selective Replication with an In-Network Coherence Directory”; Dec. 2018; 15 pages; Technical Report UW-CSE-18-12-01, University of Washington CSE, Seattle, WA. |
Liu et al.; “IncBricks: Toward In-Network Computation with an In-Network Cache”; Apr. 2017; pp. 795-809; ACM SIGOPS Operating Systems Review 51, Jul. 26, No. 2. |
Pending U.S. Appl. No. 16/697,019, filed Nov. 26, 2019, entitled “Fault Tolerant Data Coherence in Large-Scale Distributed Cache Systems”, Marjan Radi et al. |
Vestin et al.; “FastReact: In-Network Control and Caching for Industrial Control Networks using Programmable Data Planes”; Aug. 21, 2018; pp. 219-226; IEEE 23rd International Conference on Emerging Technologies and Factory Automation (ETFA). vol. 1. |
Pending U.S. Appl. No. 16/548,116, filed Aug. 22, 2019, entitled “Distributed Cache With In-Network Prefetch”, Marjan Radi et al. |
Written Opinion dated Feb. 20, 2020 from International Application No. PCT/US2019/068360, 4 pages. |
Botelho et al.; “On the Design of Practical Fault-Tolerant SDN Controllers”; Sep. 2014; 6 pages; available at: http://www.di.fc.ul.pt/˜bessani/publications/ewsdn14-ftcontroller.pdf. |
Huynh Tu Dang; “Consensus Protocols Exploiting Network Programmability”; Mar. 2019; 154 pages; available at: https://doc.rero.ch/record/324312/files/2019INFO003.pdf. |
Jialin Li; “Co-Designing Distributed Systems with Programmable Network Hardware”; 2019; 205 pages; available at: https://digital.lib.washington.edu/researchworks/bitstream/handle/1773/44770/Li_washington_0250E_20677.pdf?sequence=1&isAllowed=y. |
Liu et al.; “Circuit Switching Under the Radar with REACToR”; Apr. 2-4, 2014; 16 pages; USENIX; available at: https://www.usenix.org/system/files/conference/nsdi14/nsdi14-paper-liu_he.pdf. |
Ivan Pepelnjak; Introduction to 802.1Qbb (Priority-based Flow Control—PFC); accessed on Jun. 25, 2020; available at: https://gestaltit.com/syndicated/ivan/introduction-802-1qbb-priority-based-flow-control-pfc/. |
Juniper Networks Inc.; Configuring Priority-Based Flow Control for an EX Series Switch (CLI Procedure); Sep. 25, 2019; available at: https://www.juniper.net/documentation/en_US/junos/topics/task/configuration/cos-priority-flow-control-cli-ex-series.html. |
Cisco White Paper; “Intelligent Buffer Management on Cisco Nexus 9000 Series Switches”; Jun. 6, 2017; 22 pages; available at: https://www.cisco.com/c/en/us/products/collateral/switches/nexus-9000-series-switches/white-paper-c11-738488.html. |
Pending U.S. Appl. No. 17/174,681, filed Feb. 12, 2021, entitled “Devices and Methods for Network Message Sequencing”, Marjan Radi et al. |
Pending U.S. Appl. No. 17/175,449, filed Feb. 12, 2021, entitled “Management of Non-Volatile Memory Express Nodes”, Marjan Radi et al. |
Leslie Lamport; “Paxos Made Simple”; Nov. 1, 2001; available at: https://lamport.azurewebsites.net/pubs/paxos-simple.pdf. |
Paul Krzyzanowski; “Understanding Paxos”; PK.org; Distributed Systems; Nov. 1, 2018; available at: https://www.cs.rutgers.edu/˜pxk/417/notes/paxos.html. |
Pending U.S. Appl. No. 16/916,730, filed Jun. 30, 2020, entitled “Devices and Methods for Failure Detection and Recovery for a Distributed Cache”, Marjan Radi et al. |
Wikipedia; Paxos (computer science); accessed on Jun. 27, 2020; available at: https://en.wikipedia.org/wiki/Paxos_ (computer_science). |
Written Opinion dated Apr. 27, 2020 from International Application No. PCT/US2019/068269, 3 pages. |
International Search Report and Written Opinion dated Jun. 1, 2022 from International Application No. PCT/US2022/017608, 7 pages. |
Intel Corporation; “In-Band Network Telemetry Detects Network Performance Issues”; White Paper, Dec. 18, 2020; available at: https://builders.intel.com/docs/networkbuilders/in-band-network-telemetry-detects-network-performance-issues.pdf. |
International Search Report and Written Opinion dated Jul. 7, 2022 from International Application No. PCT/US2022/017633, 7 pages. |
Sabella et al.; “Using eBPF for network traffic analysis”; available at: Year: 2018; https://www.ntop.org/wp-content/uploads/2018/10/Sabella.pdf. |
Number | Date | Country | |
---|---|---|---|
20210409506 A1 | Dec 2021 | US |