US8417817B1 - Preventing server overload - Google Patents

Preventing server overload Download PDF

Info

Publication number
US8417817B1
US8417817B1 US12/882,903 US88290310A US8417817B1 US 8417817 B1 US8417817 B1 US 8417817B1 US 88290310 A US88290310 A US 88290310A US 8417817 B1 US8417817 B1 US 8417817B1
Authority
US
United States
Prior art keywords
requests
request
queue
counter value
determining
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.)
Expired - Fee Related, expires
Application number
US12/882,903
Inventor
Aaron Jacobs
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google LLC
Original Assignee
Google LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Google LLC filed Critical Google LLC
Priority to US12/882,903 priority Critical patent/US8417817B1/en
Assigned to GOOGLE INC. reassignment GOOGLE INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: JACOBS, AARON
Application granted granted Critical
Publication of US8417817B1 publication Critical patent/US8417817B1/en
Assigned to GOOGLE LLC reassignment GOOGLE LLC CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: GOOGLE INC.
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/28Timers or timing mechanisms used in protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services

Definitions

  • This specification relates to computer server systems.
  • a server receives requests from various users and allocates computing resources, e.g., memory and processing time, to handle the requests in a timely manner.
  • a web server providing a search service receives search requests from users. For each search query the web server receives, the web server must identify relevant search results and return those results to the user who submitted the query. For some queries, the web server allocates a large amount of memory to identify relevant search results. For example, where the search results for a query include images, the web server allocates memory for each image, e.g., a server that creates map images may need to allocate an image buffer of several megabytes, and the buffer may last for several hundred milliseconds.
  • resource allocations may cause the server to run out of physical memory or exceed a memory quota imposed on the process by another system, and the server process may be terminated. If the server process is terminated for this reason, the server may not reply gracefully with an error message to the users who have requests in flight when it was terminated, but instead may never reply. This degrades the user experience.
  • a server receives requests from client devices and puts the requests into a queue.
  • the server does not allocate more than a minimum amount of memory for a request while it is in the queue.
  • the server pops requests off the queue, allocates computing resources for the requests, and handles the requests while tracking the total number of requests that the server is handling. If the total number of requests exceeds a threshold number of requests, the server ceases popping requests off the queue until the server has handled enough requests to reduce the total number of requests being handled below the threshold.
  • the server determines whether the age of the request exceeds a threshold age. If the request is too old, the server does not allocate resources for the request and discards the request. The server sends an error message to the user who sent the request.
  • one innovative aspect of the subject matter described in this specification can be embodied in methods that include the actions of placing each request of a plurality of requests into a queue; popping requests from the queue, and for each popped request, in response to popping the request: incrementing a counter value indicating a number of requests being handled; allocating computing resources for the request; determining that a condition for which computing resources allocated for the request can be de-allocated has occurred; and decrementing the counter value after the condition occurs; determining whether the counter value exceeds a threshold number of requests being handled; in response to determining that the counter value does not exceed a threshold number of requests being handled, continuing to pop requests from the queue; and in response to determining that the counter value exceeds the threshold number of requests being handled, ceasing to pop requests from the queue until the counter value is decremented to or below the threshold number.
  • Other embodiments of this aspect include corresponding systems, apparatus, and computer programs, configured to perform the actions of the methods, encoded on computer storage devices.
  • Popping requests from the queue further includes, for each popped request: determining a difference between a time stamp of the request and a current time; and if the difference exceeds a threshold difference, discarding the request without allocating computing resources for the request or determining a response for the request. Discarding the request includes sending an error message to a device that sent the request. Placing each request of the plurality of requests into the queue comprises receiving the requests from a plurality of client devices in an order and placing the requests into the queue in the order they are received. The response includes one or more images.
  • Allocating computing resources for a request includes allocating an amount of memory for the request, and the threshold number of requests being handled is based on a maximum amount of memory per request and an amount of available memory. Placing one or more additional requests into the queue is independent of ceasing to pop requests from the queue.
  • Each request is a search query and each response includes a plurality of search results. Determining that a condition for which computing resources allocated for the request can be de-allocated has occurred comprises determining a response for the request. Decrementing the counter value after the condition occurs further comprises de-allocating the computing resources allocated for the request.
  • a server can be prevented from allocating more computing resources than it has available, and thus abrupt server terminations are avoided.
  • the server can hold the requests to respond to later or send error messages to requesting client devices, which informs the users of the client devices of the errors.
  • the server can move through a queue of requests by discarding requests older than a certain age, thus responding to more recent requests. This also avoids an overall decrease in server response time to outstanding requests. Additionally, this remedial operation is inexpensive, and allows the server to quickly catch up to the region of the queue that has not yet become too old.
  • FIG. 1 is a block diagram of an example environment in which a server queues incoming requests and handles the requests after popping them off the queue.
  • FIG. 2 is a flow diagram of an example process for receiving requests.
  • FIG. 3 is a flow diagram of an example process for managing a request queue.
  • FIG. 4 is a flow diagram of an example process for handling requests.
  • FIG. 1 is a block diagram of an example environment 100 in which a server 102 queues incoming requests and handles the requests after popping them off the queue.
  • the server 102 includes one or more data processing apparatus.
  • a network 116 e.g. a local area network (LAN), a wide area network (WAN), or the Internet connects client devices 114 and the server 102 .
  • LAN local area network
  • WAN wide area network
  • the server 102 receives requests from the client devices 114 and returns responses to the requests to the client devices 114 .
  • the server 102 may be a search engine, and the server 102 receives search queries and provides search results responsive to the search queries.
  • the server 102 may provide email services or social networking services, and the server 102 receives requests for email messages or social network status updates and provides the email messages and status updates.
  • a client device 114 typically includes a user application, such as a web browser or other application, to facilitate the sending and receiving of data over the network 116 .
  • the server 102 includes various modules 104 , 106 , and 108 , e.g., executable software programs, that are executed by the server 102 .
  • the server 102 includes a receiving module 104 for receiving requests, a queue manager 106 for managing a request queue 110 , and a request handler 108 for allocating computing resources 112 and handling requests.
  • Each module runs, for example, as part of the operating system on the server 102 , as an application on the server 102 , or as part of the operating system and part of an application on the server 102 .
  • modules 104 , 106 , and 108 are illustrated, there may be fewer or more modules.
  • the sever 102 may include more than one computer device, i.e., the server may include multiple computer devices that are logically represented as a single server, and the modules can be distributed on one or more data processing apparatus connected by one or more networks or other suitable communication mediums.
  • the receiving module 104 receives requests from client devices 114 .
  • the receiving module 104 places each received request into the request queue 110 , which is a first in, first out data structure. For example, in the case where a request is a Hypertext Transfer Protocol (HTTP) request, the receiving module 104 may place the text of the HTTP request in the queue 110 .
  • the receiving module 104 may create a function pointer to an executable function that initiates request handling for the request and place the function pointer in the queue 110 .
  • the request handler 108 can then execute the function when the function pointer is popped off the queue by the queue manager 106 .
  • the receiving module 104 appends a time stamp to each request place on the queue 110 , e.g., a time when the request was received or placed into the queue.
  • the receiving module 104 runs independently of, and in parallel with, the queue manager 106 and the request handler 108 . Thus, the receiving module 104 continues to add requests to the queue 110 even when the queue manager 106 ceases to pop requests from the queue 110 .
  • the queue manager 106 pops requests from the queue 110 .
  • the queue manager 106 maintains a counter value indicating a number of requests being handled.
  • the queue manager 106 increments the counter value.
  • the queue manager 106 decrements the counter value.
  • the queue manager 106 determines that the counter value exceeds a threshold number of requests being handled, the queue manager 106 ceases to pop requests from the queue until the counter value is decremented to or below the threshold number. While the queue manager 106 ceases to pop requests from the queue 110 , the queue manager 106 continues to decrement the counter value as the request handler 108 handles requests that the queue manager previously popped off the queue 110 .
  • the threshold number of requests is, in some implementations, based on a total amount of computing resources 112 for the server.
  • the computing resources 112 include, for example, memory and scheduled processing time on one or more processors.
  • the threshold number of requests is based on the total amount of memory available to the server 102 divided by the size of the largest set of objects that may be allocated for any request.
  • the total number of requests that can be processed at any one time is set to a configurable value, N, and the memory usage of the sever 102 is approximately bounded by N*M, where M is the size of the largest set of objects that may be allocated for any user request.
  • N and M can be set by system administrators, and are based on the resources available to the server and the estimated largest set of objects that may be allocated for any user request.
  • the later parameter can be determined, for example, from empirical data or by an administrator.
  • the queue manager 106 determines, for each request it pops off the queue 110 , a difference between a time stamp of the request and the current time. If the difference exceeds a threshold difference, the queue manager 106 discards the request. The request handler 108 does not allocate computing resources for discarded requests or determine responses for discarded requests. In this manner, when the server 102 receives a spike in the rate of incoming requests, and/or if the queue begins to grow too large, the server 102 can quickly process the requests in the queue 110 to catch up to requests that are recent. In some implementations, when the queue manager 106 discards a request, the queue manager 106 sends an error message to the requesting client device 114 .
  • the request handler 108 determines responses for requests popped off the queue 110 by the queue manager 106 . For example, if the server 102 is a search engine and the request is a search query, the request handler 108 identifies search results responsive to the search query. The request handler 108 allocates computing resources 112 for each request. For example, the request handler 108 may allocate an amount of memory for each request, schedule processing time on one or more processors, or both. Some requests require a significant allocation of computing resources, for example, where a response to a search query includes images or other audiovisual content and that is stored in memory on the server 102 .
  • the computing resources 112 in FIG. 1 are shown as being connected to the request handler 108 because the request handler 108 allocates computing resources for responses to requests.
  • the computing resources 112 can also be used by the receiving module 104 and the queue manager 106 and other components of the server 102 .
  • one or more processors included in the computing resources 112 may be used to execute the receiving module 104 or the queue manager 106 or both in parallel.
  • the request queue 110 may be stored in memory included in the computing resources 112 .
  • FIG. 2 is a flow diagram of an example process 200 for receiving requests.
  • the process 200 is performed by a server, e.g., the server 102 of FIG. 1 executing the receiving module 104 .
  • the process 200 will be described with respect to a server that performs the process 200 .
  • the server receives a request from a client device, e.g., one of the client devices 114 of FIG. 1 ( 202 ).
  • the server places the request into a queue, e.g., the request queue 110 of FIG. 1 ( 204 ).
  • the server repeats the process 200 for each request that it receives.
  • the server can execute the process 200 independently of, and in parallel with, other processes executing on the server.
  • FIG. 3 is a flow diagram of an example process 300 for managing a request queue.
  • the process 300 is performed by a server, e.g., the server 102 of FIG. 1 executing the queue manager 106 .
  • the process 300 will be described with respect to a server that performs the process 300 .
  • the server can execute the process 300 independently of, and in parallel with, other processes executing on the server.
  • the server initializes a counter value ( 302 ).
  • the counter value indicates a number of requests being handled by the server. As described herein, a request is considered as being handled by the server after the server has allocated computing resources for a response to the request. Typically, the server initializes the counter value by setting it to zero.
  • the server determines whether any requests have been completed ( 304 ).
  • the server completes requests, for example, while executing a request handler (e.g., the request handler 108 of FIG. 1 ) in parallel with the process 300 .
  • a request is completed, for example, when results to the request are sent to a client device from which a request was received, or upon any other occurrence of a system condition that allows for the de-allocation of the resources allocated for the request.
  • the server decrements the counter value ( 306 ).
  • the server determines whether the counter value is below a threshold value ( 308 ). If the server determines that the counter value is not below the threshold value, the server returns to step 304 to determine whether any requests have been completed so that the counter value can be decremented below the threshold value. By repeating steps 304 - 308 , the server can wait for requests to complete before popping additional requests off a request queue.
  • the server pops a request off a request queue, e.g., the request queue 110 of FIG. 1 ( 310 ).
  • the server determines whether the age of the request exceeds a threshold age ( 312 ), for example, by determining a difference between a time stamp of the request and a current time.
  • the server determines that the age of the request exceeds the threshold age, the server discards the request ( 318 ) without allocating computing resources for the request or determining a response for the request. The server then returns to step 304 . By discarding a number of requests without allocating resources and determining responses for the requests, the server can quickly begin handling requests that are more recent after receiving a sudden increase in incoming requests.
  • the server determines that the age of the request does not exceed the threshold age, the server increments the counter value ( 314 ) and notifies a request handler that the request is ready to be handled ( 316 ). The server then returns to step 304 so that the server can pop additional requests from the queue as long as the counter value remains below the threshold.
  • the age threshold check can be omitted. In other implementations, the age threshold check can be done only if the queue size exceed a threshold queue size S, which may occur when the server 102 receives a spike in requests. Spikes in request can occur, for example, where a major news event occurs, or at certain times of the day.
  • FIG. 4 is a flow diagram of an example process 400 for handling requests.
  • the process 400 is performed by a server, e.g., the server 102 of FIG. 1 executing the request handler 108 .
  • the process 400 will be described with respect to a server that performs the process.
  • the server can execute the process 400 independently of, and in parallel with, other processes executing on the server.
  • the server identifies a popped request ( 402 ). For example, the server may pop the request from a queue while executing the process 300 illustrated in FIG. 3 in parallel with the process 400 .
  • the server allocates computing resources for a response to the request ( 404 ).
  • the server determines a response to the request ( 406 ).
  • the server provides the response to the requesting client device ( 408 ). For example, the server may make the response available for download by the requesting client device.
  • the server releases the computing resources allocated to the request.
  • the server notifies a queue manager process that the request is complete ( 412 ).
  • Embodiments of the subject matter and the operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them.
  • Embodiments of the subject matter described in this specification can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on computer storage medium for execution by, or to control the operation of, data processing apparatus.
  • the program instructions can be encoded on an artificially-generated propagated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus for execution by a data processing apparatus.
  • a computer storage medium can be, or be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them.
  • a computer storage medium is not a propagated signal, a computer storage medium can be a source or destination of computer program instructions encoded in an artificially-generated propagated signal.
  • the computer storage medium can also be, or be included in, one or more separate physical components or media (e.g., multiple CDs, disks, or other storage devices).
  • the operations described in this specification can be implemented as operations performed by a data processing apparatus on data stored on one or more computer-readable storage devices or received from other sources.
  • the term “data processing apparatus” encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing
  • the apparatus can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
  • the apparatus can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them.
  • the apparatus and execution environment can realize various different computing model infrastructures, such as web services, distributed computing and grid computing infrastructures.
  • a computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment.
  • a computer program may, but need not, correspond to a file in a file system.
  • a program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code).
  • a computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
  • the processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform actions by operating on input data and generating output.
  • the processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
  • processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
  • a processor will receive instructions and data from a read-only memory or a random access memory or both.
  • the essential elements of a computer are a processor for performing actions in accordance with instructions and one or more memory devices for storing instructions and data.
  • a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • a computer need not have such devices.
  • Devices suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
  • semiconductor memory devices e.g., EPROM, EEPROM, and flash memory devices
  • magnetic disks e.g., internal hard disks or removable disks
  • magneto-optical disks e.g., CD-ROM and DVD-ROM disks.
  • the processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
  • a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer.
  • a display device e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor
  • keyboard and a pointing device e.g., a mouse or a trackball
  • Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
  • a computer can interact with a user by sending documents to and receiving documents from a device that is used by the user; for example, by sending web pages to a
  • Embodiments of the subject matter described in this specification can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described in this specification, or any combination of one or more such back-end, middleware, or front-end components.
  • the components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network.
  • Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), an inter-network (e.g., the Internet), and peer-to-peer networks (e.g., ad hoc peer-to-peer networks).
  • LAN local area network
  • WAN wide area network
  • inter-network e.g., the Internet
  • peer-to-peer networks e.g., ad hoc peer-to-peer networks.
  • the computing system can include clients and servers.
  • a client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
  • a server transmits data (e.g., an HTML page) to a client device (e.g., for purposes of displaying data to and receiving user input from a user interacting with the client device).
  • client device e.g., for purposes of displaying data to and receiving user input from a user interacting with the client device.
  • Data generated at the client device e.g., a result of the user interaction

Abstract

Methods, systems, and apparatus, including computer programs encoded on a computer storage medium, for preventing server overload. In one aspect, a method includes placing each request of a plurality of requests into a queue. Requests are popped from the queue, and for each popped request, in response to popping the request: a counter value is incremented; computing resources are allocated for the request; a determination is made that a condition for which computing resources allocated for the request can be de-allocated has occurred; and the counter value is decremented after the condition occurs. In response to determining that the counter value does not exceed a threshold number, requests continue to be popped from the queue. In response to determining that the counter value exceeds the threshold number, requests are not popped from the queue until the counter value is decremented to or below the threshold number.

Description

BACKGROUND
This specification relates to computer server systems.
A server receives requests from various users and allocates computing resources, e.g., memory and processing time, to handle the requests in a timely manner. For example, a web server providing a search service receives search requests from users. For each search query the web server receives, the web server must identify relevant search results and return those results to the user who submitted the query. For some queries, the web server allocates a large amount of memory to identify relevant search results. For example, where the search results for a query include images, the web server allocates memory for each image, e.g., a server that creates map images may need to allocate an image buffer of several megabytes, and the buffer may last for several hundred milliseconds. These resource allocations may cause the server to run out of physical memory or exceed a memory quota imposed on the process by another system, and the server process may be terminated. If the server process is terminated for this reason, the server may not reply gracefully with an error message to the users who have requests in flight when it was terminated, but instead may never reply. This degrades the user experience.
SUMMARY
A server receives requests from client devices and puts the requests into a queue. The server does not allocate more than a minimum amount of memory for a request while it is in the queue. The server pops requests off the queue, allocates computing resources for the requests, and handles the requests while tracking the total number of requests that the server is handling. If the total number of requests exceeds a threshold number of requests, the server ceases popping requests off the queue until the server has handled enough requests to reduce the total number of requests being handled below the threshold.
When the server pops a request off the queue, the server determines whether the age of the request exceeds a threshold age. If the request is too old, the server does not allocate resources for the request and discards the request. The server sends an error message to the user who sent the request.
In general, one innovative aspect of the subject matter described in this specification can be embodied in methods that include the actions of placing each request of a plurality of requests into a queue; popping requests from the queue, and for each popped request, in response to popping the request: incrementing a counter value indicating a number of requests being handled; allocating computing resources for the request; determining that a condition for which computing resources allocated for the request can be de-allocated has occurred; and decrementing the counter value after the condition occurs; determining whether the counter value exceeds a threshold number of requests being handled; in response to determining that the counter value does not exceed a threshold number of requests being handled, continuing to pop requests from the queue; and in response to determining that the counter value exceeds the threshold number of requests being handled, ceasing to pop requests from the queue until the counter value is decremented to or below the threshold number. Other embodiments of this aspect include corresponding systems, apparatus, and computer programs, configured to perform the actions of the methods, encoded on computer storage devices.
These and other embodiments can each optionally include one or more of the following features. Popping requests from the queue further includes, for each popped request: determining a difference between a time stamp of the request and a current time; and if the difference exceeds a threshold difference, discarding the request without allocating computing resources for the request or determining a response for the request. Discarding the request includes sending an error message to a device that sent the request. Placing each request of the plurality of requests into the queue comprises receiving the requests from a plurality of client devices in an order and placing the requests into the queue in the order they are received. The response includes one or more images. Allocating computing resources for a request includes allocating an amount of memory for the request, and the threshold number of requests being handled is based on a maximum amount of memory per request and an amount of available memory. Placing one or more additional requests into the queue is independent of ceasing to pop requests from the queue. Each request is a search query and each response includes a plurality of search results. Determining that a condition for which computing resources allocated for the request can be de-allocated has occurred comprises determining a response for the request. Decrementing the counter value after the condition occurs further comprises de-allocating the computing resources allocated for the request.
Particular embodiments of the subject matter described in this specification can be implemented so as to realize one or more of the following advantages. A server can be prevented from allocating more computing resources than it has available, and thus abrupt server terminations are avoided. When the server receives more requests than it can allocate computing resources to handle, the server can hold the requests to respond to later or send error messages to requesting client devices, which informs the users of the client devices of the errors. To prevent the queue from growing extremely large, the server can move through a queue of requests by discarding requests older than a certain age, thus responding to more recent requests. This also avoids an overall decrease in server response time to outstanding requests. Additionally, this remedial operation is inexpensive, and allows the server to quickly catch up to the region of the queue that has not yet become too old.
The details of one or more embodiments of the subject matter described in this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of an example environment in which a server queues incoming requests and handles the requests after popping them off the queue.
FIG. 2 is a flow diagram of an example process for receiving requests.
FIG. 3 is a flow diagram of an example process for managing a request queue.
FIG. 4 is a flow diagram of an example process for handling requests.
Like reference numbers and designations in the various drawings indicate like elements.
DETAILED DESCRIPTION
FIG. 1 is a block diagram of an example environment 100 in which a server 102 queues incoming requests and handles the requests after popping them off the queue. The server 102 includes one or more data processing apparatus. A network 116, e.g. a local area network (LAN), a wide area network (WAN), or the Internet connects client devices 114 and the server 102.
The server 102 receives requests from the client devices 114 and returns responses to the requests to the client devices 114. For example, the server 102 may be a search engine, and the server 102 receives search queries and provides search results responsive to the search queries. In another example, the server 102 may provide email services or social networking services, and the server 102 receives requests for email messages or social network status updates and provides the email messages and status updates. A client device 114 typically includes a user application, such as a web browser or other application, to facilitate the sending and receiving of data over the network 116.
The server 102 includes various modules 104, 106, and 108, e.g., executable software programs, that are executed by the server 102. As shown, the server 102 includes a receiving module 104 for receiving requests, a queue manager 106 for managing a request queue 110, and a request handler 108 for allocating computing resources 112 and handling requests. Each module runs, for example, as part of the operating system on the server 102, as an application on the server 102, or as part of the operating system and part of an application on the server 102. Although several modules 104, 106, and 108 are illustrated, there may be fewer or more modules. Moreover, although only one server 102 is shown, the sever 102 may include more than one computer device, i.e., the server may include multiple computer devices that are logically represented as a single server, and the modules can be distributed on one or more data processing apparatus connected by one or more networks or other suitable communication mediums.
The receiving module 104 receives requests from client devices 114. The receiving module 104 places each received request into the request queue 110, which is a first in, first out data structure. For example, in the case where a request is a Hypertext Transfer Protocol (HTTP) request, the receiving module 104 may place the text of the HTTP request in the queue 110. In another example, the receiving module 104 may create a function pointer to an executable function that initiates request handling for the request and place the function pointer in the queue 110. The request handler 108 can then execute the function when the function pointer is popped off the queue by the queue manager 106. In some implementations, the receiving module 104 appends a time stamp to each request place on the queue 110, e.g., a time when the request was received or placed into the queue.
In some implementations, the receiving module 104 runs independently of, and in parallel with, the queue manager 106 and the request handler 108. Thus, the receiving module 104 continues to add requests to the queue 110 even when the queue manager 106 ceases to pop requests from the queue 110.
The queue manager 106 pops requests from the queue 110. The queue manager 106 maintains a counter value indicating a number of requests being handled. When the queue manager 106 pops a request from the queue 110, the queue manager 106 increments the counter value. After the request handler 108 determines a response for the request, the queue manager 106 decrements the counter value.
When the queue manager 106 determines that the counter value exceeds a threshold number of requests being handled, the queue manager 106 ceases to pop requests from the queue until the counter value is decremented to or below the threshold number. While the queue manager 106 ceases to pop requests from the queue 110, the queue manager 106 continues to decrement the counter value as the request handler 108 handles requests that the queue manager previously popped off the queue 110.
The threshold number of requests is, in some implementations, based on a total amount of computing resources 112 for the server. The computing resources 112 include, for example, memory and scheduled processing time on one or more processors. In some implementations, the threshold number of requests is based on the total amount of memory available to the server 102 divided by the size of the largest set of objects that may be allocated for any request.
In some implementations, the total number of requests that can be processed at any one time is set to a configurable value, N, and the memory usage of the sever 102 is approximately bounded by N*M, where M is the size of the largest set of objects that may be allocated for any user request. Both of the values of N and M can be set by system administrators, and are based on the resources available to the server and the estimated largest set of objects that may be allocated for any user request. The later parameter can be determined, for example, from empirical data or by an administrator. Thus, by only allocating resources to a request after it is popped from the queue, the resources allocated to the server can be controlled to ensure that they do not exceed the maximum resource allocation requirements.
In some implementations, the queue manager 106 determines, for each request it pops off the queue 110, a difference between a time stamp of the request and the current time. If the difference exceeds a threshold difference, the queue manager 106 discards the request. The request handler 108 does not allocate computing resources for discarded requests or determine responses for discarded requests. In this manner, when the server 102 receives a spike in the rate of incoming requests, and/or if the queue begins to grow too large, the server 102 can quickly process the requests in the queue 110 to catch up to requests that are recent. In some implementations, when the queue manager 106 discards a request, the queue manager 106 sends an error message to the requesting client device 114.
The request handler 108 determines responses for requests popped off the queue 110 by the queue manager 106. For example, if the server 102 is a search engine and the request is a search query, the request handler 108 identifies search results responsive to the search query. The request handler 108 allocates computing resources 112 for each request. For example, the request handler 108 may allocate an amount of memory for each request, schedule processing time on one or more processors, or both. Some requests require a significant allocation of computing resources, for example, where a response to a search query includes images or other audiovisual content and that is stored in memory on the server 102.
The computing resources 112 in FIG. 1 are shown as being connected to the request handler 108 because the request handler 108 allocates computing resources for responses to requests. The computing resources 112 can also be used by the receiving module 104 and the queue manager 106 and other components of the server 102. For example, one or more processors included in the computing resources 112 may be used to execute the receiving module 104 or the queue manager 106 or both in parallel. In another example, the request queue 110 may be stored in memory included in the computing resources 112.
FIG. 2 is a flow diagram of an example process 200 for receiving requests. In some implementations, the process 200 is performed by a server, e.g., the server 102 of FIG. 1 executing the receiving module 104. For purposes of illustration, the process 200 will be described with respect to a server that performs the process 200.
The server receives a request from a client device, e.g., one of the client devices 114 of FIG. 1 (202). The server places the request into a queue, e.g., the request queue 110 of FIG. 1 (204). The server repeats the process 200 for each request that it receives. The server can execute the process 200 independently of, and in parallel with, other processes executing on the server.
FIG. 3 is a flow diagram of an example process 300 for managing a request queue. In some implementations, the process 300 is performed by a server, e.g., the server 102 of FIG. 1 executing the queue manager 106. For purposes of illustration, the process 300 will be described with respect to a server that performs the process 300. The server can execute the process 300 independently of, and in parallel with, other processes executing on the server.
The server initializes a counter value (302). The counter value indicates a number of requests being handled by the server. As described herein, a request is considered as being handled by the server after the server has allocated computing resources for a response to the request. Typically, the server initializes the counter value by setting it to zero.
The server determines whether any requests have been completed (304). The server completes requests, for example, while executing a request handler (e.g., the request handler 108 of FIG. 1) in parallel with the process 300. A request is completed, for example, when results to the request are sent to a client device from which a request was received, or upon any other occurrence of a system condition that allows for the de-allocation of the resources allocated for the request. For each completed request, the server decrements the counter value (306).
The server determines whether the counter value is below a threshold value (308). If the server determines that the counter value is not below the threshold value, the server returns to step 304 to determine whether any requests have been completed so that the counter value can be decremented below the threshold value. By repeating steps 304-308, the server can wait for requests to complete before popping additional requests off a request queue.
If the server determines that the counter value is below the threshold, the server pops a request off a request queue, e.g., the request queue 110 of FIG. 1 (310). The server determines whether the age of the request exceeds a threshold age (312), for example, by determining a difference between a time stamp of the request and a current time.
If the server determines that the age of the request exceeds the threshold age, the server discards the request (318) without allocating computing resources for the request or determining a response for the request. The server then returns to step 304. By discarding a number of requests without allocating resources and determining responses for the requests, the server can quickly begin handling requests that are more recent after receiving a sudden increase in incoming requests.
If the server determines that the age of the request does not exceed the threshold age, the server increments the counter value (314) and notifies a request handler that the request is ready to be handled (316). The server then returns to step 304 so that the server can pop additional requests from the queue as long as the counter value remains below the threshold.
In some implementations, the age threshold check can be omitted. In other implementations, the age threshold check can be done only if the queue size exceed a threshold queue size S, which may occur when the server 102 receives a spike in requests. Spikes in request can occur, for example, where a major news event occurs, or at certain times of the day.
FIG. 4 is a flow diagram of an example process 400 for handling requests. In some implementations, the process 400 is performed by a server, e.g., the server 102 of FIG. 1 executing the request handler 108. For purposes of illustration, the process 400 will be described with respect to a server that performs the process. The server can execute the process 400 independently of, and in parallel with, other processes executing on the server.
The server identifies a popped request (402). For example, the server may pop the request from a queue while executing the process 300 illustrated in FIG. 3 in parallel with the process 400. The server allocates computing resources for a response to the request (404). The server determines a response to the request (406). The server provides the response to the requesting client device (408). For example, the server may make the response available for download by the requesting client device. After providing the response to the requesting client device, the server releases the computing resources allocated to the request. The server notifies a queue manager process that the request is complete (412).
Embodiments of the subject matter and the operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Embodiments of the subject matter described in this specification can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on computer storage medium for execution by, or to control the operation of, data processing apparatus. Alternatively or in addition, the program instructions can be encoded on an artificially-generated propagated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus for execution by a data processing apparatus. A computer storage medium can be, or be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them. Moreover, while a computer storage medium is not a propagated signal, a computer storage medium can be a source or destination of computer program instructions encoded in an artificially-generated propagated signal. The computer storage medium can also be, or be included in, one or more separate physical components or media (e.g., multiple CDs, disks, or other storage devices).
The operations described in this specification can be implemented as operations performed by a data processing apparatus on data stored on one or more computer-readable storage devices or received from other sources.
The term “data processing apparatus” encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing The apparatus can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit). The apparatus can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them. The apparatus and execution environment can realize various different computing model infrastructures, such as web services, distributed computing and grid computing infrastructures.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment. A computer program may, but need not, correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform actions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for performing actions in accordance with instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. However, a computer need not have such devices.
Devices suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
To provide for interaction with a user, embodiments of the subject matter described in this specification can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input. In addition, a computer can interact with a user by sending documents to and receiving documents from a device that is used by the user; for example, by sending web pages to a web browser on a user's client device in response to requests received from the web browser.
Embodiments of the subject matter described in this specification can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described in this specification, or any combination of one or more such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), an inter-network (e.g., the Internet), and peer-to-peer networks (e.g., ad hoc peer-to-peer networks).
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other. In some embodiments, a server transmits data (e.g., an HTML page) to a client device (e.g., for purposes of displaying data to and receiving user input from a user interacting with the client device). Data generated at the client device (e.g., a result of the user interaction) can be received from the client device at the server.
While this specification contains many specific implementation details, these should not be construed as limitations on the scope of any inventions or of what may be claimed, but rather as descriptions of features specific to particular embodiments of particular inventions. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
Thus, particular embodiments of the subject matter have been described. Other embodiments are within the scope of the following claims. In some cases, the actions recited in the claims can be performed in a different order and still achieve desirable results. In addition, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In certain implementations, multitasking and parallel processing may be advantageous.

Claims (11)

What is claimed is:
1. A method performed by data processing apparatus, the method comprising:
placing each request of a plurality of requests into a queue, each request for an image;
popping requests from the queue, and for each popped request, in response to popping the request:
incrementing a counter value indicating a number of requests being handled;
allocating memory for an image satisfying the request and storing the image in the allocated memory;
determining that the image specified by the request has been transmitted to a requester of the request and de-allocating the memory for the image in response to the determination; and
decrementing the counter value after de-allocating the memory;
determining whether the counter value exceeds a first threshold number of requests being handled;
in response to determining that the counter value does not exceed the first threshold number of requests being handled, continuing to pop requests from the queue, wherein the first threshold number of requests being handled is based on a maximum amount of memory per request and an amount of available memory; and
in response to determining that the counter value exceeds the first threshold number of requests being handled, ceasing to pop requests from the queue until the counter value is decremented to or below the first threshold number, including:
determining that the counter value exceeds a second threshold number of requests being handled;
in response to determining that the counter value exceeds the second threshold number of requests being handled, discarding a first plurality of requests from the queue, including, for each of the first plurality of requests in the queue:
determining a difference between a time stamp of the request and a current time; and
if the difference exceeds a threshold difference, discarding the request without allocating computing resources for the request or determining a response for the request, wherein discarding the request includes sending an error message to a device that sent the request.
2. The method of claim 1, wherein placing each request of the plurality of requests into the queue comprises receiving the requests from a plurality of client devices in an order and placing the requests into the queue in the order they are received.
3. The method of claim 1, wherein placing one or more additional requests into the queue is independent of ceasing to pop requests from the queue.
4. The method of claim 1, wherein each request is a search query and each response includes a plurality of search results.
5. The method of claim 1, wherein storing the image in the allocated memory comprises creating a map image.
6. A system comprising:
a data processing apparatus; and
a memory couple to the data processing apparatus having instructions stored thereon which, when executed by the data processing apparatus cause the data processing apparatus to perform operations comprising:
placing each request of a plurality of requests into a queue, each request for an image;
popping requests from the queue, and for each popped request, in response to popping the request:
incrementing a counter value indicating a number of requests being handled;
allocating memory for an image satisfying the request and storing the image in the allocated memory;
determining that the image specified by the request has been transmitted to a requester of the request and de-allocating the memory for the image in response to the determination; and
decrementing the counter value after de-allocating the memory;
determining whether the counter value exceeds a first threshold number of requests being handled;
in response to determining that the counter value does not exceed the first threshold number of requests being handled, continuing to pop requests from the queue, wherein the first threshold number of requests being handled is based on a maximum amount of memory per request and an amount of available memory; and
in response to determining that the counter value exceeds the first threshold number of requests being handled, ceasing to pop requests from the queue until the counter value is decremented to or below the first threshold number, including:
determining that the counter value exceeds a second threshold number of requests being handled;
in response to determining that the counter value exceeds the second threshold number of requests being handled, discarding a first plurality of requests from the queue, including, for each of the first plurality of requests in the queue:
determining a difference between a time stamp of the request and a current time; and
if the difference exceeds a threshold difference, discarding the request without allocating computing resources for the request or determining a response for the request, wherein discarding the request includes sending an error message to a device that sent the request.
7. The system of claim 6, wherein placing each request of the plurality of requests into the queue comprises receiving the requests from a plurality of client devices in an order and placing the requests into the queue in the order they are received.
8. The system of claim 6, wherein placing one or more additional requests into the queue is independent of ceasing to pop requests from the queue.
9. The system of claim 6, wherein each request is a search query and each response includes a plurality of search results.
10. The system of claim 6, wherein storing the image in the allocated memory comprises creating a map image.
11. A computer program product encoded on a computer readable storage device, operable to cause a data processing apparatus to perform operations comprising:
placing each request of a plurality of requests into a queue, each request for an image;
popping requests from the queue, and for each popped request, in response to popping the request:
incrementing a counter value indicating a number of requests being handled;
allocating memory for an image satisfying the request and storing the image in the allocated memory;
determining that the image specified by the request has been transmitted to a requester of the request and de-allocating the memory for the image in response to the determination; and
decrementing the counter value after de-allocating the memory;
determining whether the counter value exceeds a first threshold number of requests being handled;
in response to determining that the counter value does not exceed the first threshold number of requests being handled, continuing to pop requests from the queue, wherein the first threshold number of requests being handled is based on a maximum amount of memory per request and an amount of available memory; and
in response to determining that the counter value exceeds the first threshold number of requests being handled, ceasing to pop requests from the queue until the counter value is decremented to or below the first threshold number, including:
determining that the counter value exceeds a second threshold number of requests being handled;
in response to determining that the counter value exceeds the second threshold number of requests being handled, discarding a first plurality of requests from the queue, including, for each of the first plurality of requests in the queue:
determining a difference between a time stamp of the request and a current time; and
if the difference exceeds a threshold difference, discarding the request without allocating computing resources for the request or determining a response for the request, wherein discarding the request includes sending an error message to a device that sent the request.
US12/882,903 2010-09-15 2010-09-15 Preventing server overload Expired - Fee Related US8417817B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/882,903 US8417817B1 (en) 2010-09-15 2010-09-15 Preventing server overload

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US12/882,903 US8417817B1 (en) 2010-09-15 2010-09-15 Preventing server overload

Publications (1)

Publication Number Publication Date
US8417817B1 true US8417817B1 (en) 2013-04-09

Family

ID=47999360

Family Applications (1)

Application Number Title Priority Date Filing Date
US12/882,903 Expired - Fee Related US8417817B1 (en) 2010-09-15 2010-09-15 Preventing server overload

Country Status (1)

Country Link
US (1) US8417817B1 (en)

Cited By (97)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130054806A1 (en) * 2011-08-31 2013-02-28 Metaswitch Networks Ltd Load Balancing for SIP Services
US20130212603A1 (en) * 2012-02-10 2013-08-15 Twilio, Inc. System and method for managing concurrent events
US9021109B1 (en) * 2012-01-23 2015-04-28 Amazon Technologies, Inc. Controlling requests through message headers
US9137127B2 (en) 2013-09-17 2015-09-15 Twilio, Inc. System and method for providing communication platform metadata
US9160696B2 (en) 2013-06-19 2015-10-13 Twilio, Inc. System for transforming media resource into destination device compatible messaging format
US9226217B2 (en) 2014-04-17 2015-12-29 Twilio, Inc. System and method for enabling multi-modal communication
US9225840B2 (en) 2013-06-19 2015-12-29 Twilio, Inc. System and method for providing a communication endpoint information service
US9231879B1 (en) * 2012-02-20 2016-01-05 F5 Networks, Inc. Methods for policy-based network traffic queue management and devices thereof
US9240941B2 (en) 2012-05-09 2016-01-19 Twilio, Inc. System and method for managing media in a distributed communication network
US9247062B2 (en) 2012-06-19 2016-01-26 Twilio, Inc. System and method for queuing a communication session
US9246694B1 (en) 2014-07-07 2016-01-26 Twilio, Inc. System and method for managing conferencing in a distributed communication network
US9253254B2 (en) 2013-01-14 2016-02-02 Twilio, Inc. System and method for offering a multi-partner delegated platform
US9251371B2 (en) 2014-07-07 2016-02-02 Twilio, Inc. Method and system for applying data retention policies in a computing platform
US9270833B2 (en) 2012-07-24 2016-02-23 Twilio, Inc. Method and system for preventing illicit use of a telephony platform
US9270766B2 (en) 2011-12-30 2016-02-23 F5 Networks, Inc. Methods for identifying network traffic characteristics to correlate and manage one or more subsequent flows and devices thereof
US9274858B2 (en) 2013-09-17 2016-03-01 Twilio, Inc. System and method for tagging and tracking events of an application platform
US9282124B2 (en) 2013-03-14 2016-03-08 Twilio, Inc. System and method for integrating session initiation protocol communication in a telecommunications platform
US9306982B2 (en) 2008-04-02 2016-04-05 Twilio, Inc. System and method for processing media requests during telephony sessions
US9307094B2 (en) 2012-10-15 2016-04-05 Twilio, Inc. System and method for routing communications
US9319857B2 (en) 2012-10-15 2016-04-19 Twilio, Inc. System and method for triggering on platform usage
US9325624B2 (en) 2013-11-12 2016-04-26 Twilio, Inc. System and method for enabling dynamic multi-modal communication
US9336500B2 (en) 2011-09-21 2016-05-10 Twilio, Inc. System and method for authorizing and connecting application developers and users
US9338018B2 (en) 2013-09-17 2016-05-10 Twilio, Inc. System and method for pricing communication of a telecommunication platform
US9338280B2 (en) 2013-06-19 2016-05-10 Twilio, Inc. System and method for managing telephony endpoint inventory
US9338064B2 (en) 2010-06-23 2016-05-10 Twilio, Inc. System and method for managing a computing cluster
US9344573B2 (en) 2014-03-14 2016-05-17 Twilio, Inc. System and method for a work distribution service
US9350642B2 (en) 2012-05-09 2016-05-24 Twilio, Inc. System and method for managing latency in a distributed telephony network
US9357047B2 (en) 2009-03-02 2016-05-31 Twilio, Inc. Method and system for a multitenancy telephone network
US9363301B2 (en) 2014-10-21 2016-06-07 Twilio, Inc. System and method for providing a micro-services communication platform
US9398622B2 (en) 2011-05-23 2016-07-19 Twilio, Inc. System and method for connecting a communication to a client
US9407597B2 (en) 2008-10-01 2016-08-02 Twilio, Inc. Telephony web event system and method
US9455949B2 (en) 2011-02-04 2016-09-27 Twilio, Inc. Method for processing telephony sessions of a network
US9456008B2 (en) 2008-04-02 2016-09-27 Twilio, Inc. System and method for processing telephony sessions
US9459925B2 (en) 2010-06-23 2016-10-04 Twilio, Inc. System and method for managing a computing cluster
US9459926B2 (en) 2010-06-23 2016-10-04 Twilio, Inc. System and method for managing a computing cluster
US9477975B2 (en) 2015-02-03 2016-10-25 Twilio, Inc. System and method for a media intelligence platform
US9483328B2 (en) 2013-07-19 2016-11-01 Twilio, Inc. System and method for delivering application content
US9491309B2 (en) 2009-10-07 2016-11-08 Twilio, Inc. System and method for running a multi-module telephony application
US9516101B2 (en) 2014-07-07 2016-12-06 Twilio, Inc. System and method for collecting feedback in a multi-tenant communication platform
US9553799B2 (en) 2013-11-12 2017-01-24 Twilio, Inc. System and method for client communication in a distributed telephony network
US9554276B2 (en) 2010-10-29 2017-01-24 F5 Networks, Inc. System and method for on the fly protocol conversion in obtaining policy enforcement information
US9590849B2 (en) 2010-06-23 2017-03-07 Twilio, Inc. System and method for managing a computing cluster
US9602586B2 (en) 2012-05-09 2017-03-21 Twilio, Inc. System and method for managing media in a distributed communication network
US9641677B2 (en) 2011-09-21 2017-05-02 Twilio, Inc. System and method for determining and communicating presence information
US9647954B2 (en) 2000-03-21 2017-05-09 F5 Networks, Inc. Method and system for optimizing a network by independently scaling control segments and data flow
US9648006B2 (en) 2011-05-23 2017-05-09 Twilio, Inc. System and method for communicating with a client application
US20170149872A1 (en) * 2014-06-17 2017-05-25 Datenlotsen Informationssysteme Gmbh Client-server system and terminal
US9686170B2 (en) 2014-07-18 2017-06-20 International Business Machines Corporation Measuring delay
US9774687B2 (en) 2014-07-07 2017-09-26 Twilio, Inc. System and method for managing media and signaling in a communication platform
CN107872396A (en) * 2016-09-26 2018-04-03 华为技术有限公司 Communication means, processing equipment, terminal device and server with overtime control
US9948703B2 (en) 2015-05-14 2018-04-17 Twilio, Inc. System and method for signaling through data storage
US9967224B2 (en) 2010-06-25 2018-05-08 Twilio, Inc. System and method for enabling real-time eventing
US10015143B1 (en) 2014-06-05 2018-07-03 F5 Networks, Inc. Methods for securing one or more license entitlement grants and devices thereof
US10015286B1 (en) 2010-06-23 2018-07-03 F5 Networks, Inc. System and method for proxying HTTP single sign on across network domains
US20180232253A1 (en) * 2017-02-10 2018-08-16 Fuji Xerox Co., Ltd. Information processing apparatus and non-transitory computer readable medium
USRE47019E1 (en) 2010-07-14 2018-08-28 F5 Networks, Inc. Methods for DNSSEC proxying and deployment amelioration and systems thereof
US10063713B2 (en) 2016-05-23 2018-08-28 Twilio Inc. System and method for programmatic device connectivity
US10097616B2 (en) 2012-04-27 2018-10-09 F5 Networks, Inc. Methods for optimizing service of content requests and devices thereof
US10122630B1 (en) 2014-08-15 2018-11-06 F5 Networks, Inc. Methods for network traffic presteering and devices thereof
US10135831B2 (en) 2011-01-28 2018-11-20 F5 Networks, Inc. System and method for combining an access control system with a traffic management system
US10165015B2 (en) 2011-05-23 2018-12-25 Twilio Inc. System and method for real-time communication by using a client application communication protocol
US10182013B1 (en) 2014-12-01 2019-01-15 F5 Networks, Inc. Methods for managing progressive image delivery and devices thereof
US10187317B1 (en) 2013-11-15 2019-01-22 F5 Networks, Inc. Methods for traffic rate control and devices thereof
US10230566B1 (en) 2012-02-17 2019-03-12 F5 Networks, Inc. Methods for dynamically constructing a service principal name and devices thereof
US10375155B1 (en) 2013-02-19 2019-08-06 F5 Networks, Inc. System and method for achieving hardware acceleration for asymmetric flow connections
US20190250956A1 (en) * 2017-07-21 2019-08-15 Red Hat, Inc. Low latency distributed counters for quotas
US10404698B1 (en) 2016-01-15 2019-09-03 F5 Networks, Inc. Methods for adaptive organization of web application access points in webtops and devices thereof
US10419891B2 (en) 2015-05-14 2019-09-17 Twilio, Inc. System and method for communicating through multiple endpoints
US10505792B1 (en) 2016-11-02 2019-12-10 F5 Networks, Inc. Methods for facilitating network traffic analytics and devices thereof
US10505818B1 (en) 2015-05-05 2019-12-10 F5 Networks. Inc. Methods for analyzing and load balancing based on server health and devices thereof
US10574758B2 (en) 2017-07-28 2020-02-25 International Business Machines Corporation Server connection capacity management
US10659349B2 (en) 2016-02-04 2020-05-19 Twilio Inc. Systems and methods for providing secure network exchanged for a multitenant virtual private cloud
US10686902B2 (en) 2016-05-23 2020-06-16 Twilio Inc. System and method for a multi-channel notification service
US10721269B1 (en) 2009-11-06 2020-07-21 F5 Networks, Inc. Methods and system for returning requests with javascript for clients before passing a request to a server
US10791088B1 (en) 2016-06-17 2020-09-29 F5 Networks, Inc. Methods for disaggregating subscribers via DHCP address translation and devices thereof
US10797888B1 (en) 2016-01-20 2020-10-06 F5 Networks, Inc. Methods for secured SCEP enrollment for client devices and devices thereof
US10812266B1 (en) 2017-03-17 2020-10-20 F5 Networks, Inc. Methods for managing security tokens based on security violations and devices thereof
US10834065B1 (en) 2015-03-31 2020-11-10 F5 Networks, Inc. Methods for SSL protected NTLM re-authentication and devices thereof
US10972453B1 (en) 2017-05-03 2021-04-06 F5 Networks, Inc. Methods for token refreshment based on single sign-on (SSO) for federated identity environments and devices thereof
US11012512B1 (en) * 2020-05-20 2021-05-18 EMC IP Holding Company LLC Host device with automated write throttling responsive to storage system write pressure condition
US11122042B1 (en) 2017-05-12 2021-09-14 F5 Networks, Inc. Methods for dynamically managing user access control and devices thereof
US11122083B1 (en) 2017-09-08 2021-09-14 F5 Networks, Inc. Methods for managing network connections based on DNS data and network policies and devices thereof
US11159500B2 (en) 2015-10-30 2021-10-26 Rovi Guides, Inc. Methods and systems for managing content subscription data
US11178150B1 (en) 2016-01-20 2021-11-16 F5 Networks, Inc. Methods for enforcing access control list based on managed application and devices thereof
US11212568B2 (en) * 2015-10-30 2021-12-28 Rovi Guides, Inc. Methods and systems for monitoring content subscription usage
CN114500391A (en) * 2021-12-28 2022-05-13 上海弘积信息科技有限公司 Method for dealing with instantaneous overlarge flow
US11343237B1 (en) 2017-05-12 2022-05-24 F5, Inc. Methods for managing a federated identity environment using security and access control data and devices thereof
US11350254B1 (en) 2015-05-05 2022-05-31 F5, Inc. Methods for enforcing compliance policies and devices thereof
US11550511B2 (en) 2021-05-21 2023-01-10 EMC IP Holding Company LLC Write pressure throttling based on service level objectives
US11553047B2 (en) 2018-11-30 2023-01-10 International Business Machines Corporation Dynamic connection capacity management
US20230107052A1 (en) * 2021-10-06 2023-04-06 Imperva, Inc. Waiting room with zero latency
US11637934B2 (en) 2010-06-23 2023-04-25 Twilio Inc. System and method for monitoring account usage on a platform
US11652905B2 (en) * 2017-08-14 2023-05-16 Jio Platforms Limited Systems and methods for controlling real-time traffic surge of application programming interfaces (APIs) at server
US11757946B1 (en) 2015-12-22 2023-09-12 F5, Inc. Methods for analyzing network traffic and enforcing network policies and devices thereof
US11838851B1 (en) 2014-07-15 2023-12-05 F5, Inc. Methods for managing L7 traffic classification and devices thereof
US11895138B1 (en) 2015-02-02 2024-02-06 F5, Inc. Methods for improving web scanner accuracy and devices thereof
US11934659B1 (en) 2022-09-28 2024-03-19 Dell Products L.P. Host background copy process with rate adjustment utilizing input-output processing pressure feedback from storage system

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020198993A1 (en) * 2000-09-01 2002-12-26 Ncr Corporation Downloading and uploading data in information networks
US20040218617A1 (en) * 2001-05-31 2004-11-04 Mats Sagfors Congestion and delay handling in a packet data network
US7752629B2 (en) * 2004-05-21 2010-07-06 Bea Systems Inc. System and method for application server with overload protection
US7774492B2 (en) * 2001-07-26 2010-08-10 Citrix Systems, Inc. System, method and computer program product to maximize server throughput while avoiding server overload by controlling the rate of establishing server-side net work connections
US20100238801A1 (en) * 2006-07-31 2010-09-23 Smith Donald L Method and system for stale data detection based quality of service
US7986625B2 (en) * 2002-12-10 2011-07-26 International Business Machines Corporation Resource-aware system, method and program product for managing request traffic based on a management policy

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020198993A1 (en) * 2000-09-01 2002-12-26 Ncr Corporation Downloading and uploading data in information networks
US20040218617A1 (en) * 2001-05-31 2004-11-04 Mats Sagfors Congestion and delay handling in a packet data network
US7774492B2 (en) * 2001-07-26 2010-08-10 Citrix Systems, Inc. System, method and computer program product to maximize server throughput while avoiding server overload by controlling the rate of establishing server-side net work connections
US7986625B2 (en) * 2002-12-10 2011-07-26 International Business Machines Corporation Resource-aware system, method and program product for managing request traffic based on a management policy
US7752629B2 (en) * 2004-05-21 2010-07-06 Bea Systems Inc. System and method for application server with overload protection
US20100238801A1 (en) * 2006-07-31 2010-09-23 Smith Donald L Method and system for stale data detection based quality of service

Cited By (237)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9647954B2 (en) 2000-03-21 2017-05-09 F5 Networks, Inc. Method and system for optimizing a network by independently scaling control segments and data flow
US10560495B2 (en) 2008-04-02 2020-02-11 Twilio Inc. System and method for processing telephony sessions
US10893079B2 (en) 2008-04-02 2021-01-12 Twilio Inc. System and method for processing telephony sessions
US9596274B2 (en) 2008-04-02 2017-03-14 Twilio, Inc. System and method for processing telephony sessions
US11706349B2 (en) 2008-04-02 2023-07-18 Twilio Inc. System and method for processing telephony sessions
US11831810B2 (en) 2008-04-02 2023-11-28 Twilio Inc. System and method for processing telephony sessions
US10893078B2 (en) 2008-04-02 2021-01-12 Twilio Inc. System and method for processing telephony sessions
US9906651B2 (en) 2008-04-02 2018-02-27 Twilio, Inc. System and method for processing media requests during telephony sessions
US9906571B2 (en) 2008-04-02 2018-02-27 Twilio, Inc. System and method for processing telephony sessions
US11722602B2 (en) 2008-04-02 2023-08-08 Twilio Inc. System and method for processing media requests during telephony sessions
US9456008B2 (en) 2008-04-02 2016-09-27 Twilio, Inc. System and method for processing telephony sessions
US11765275B2 (en) 2008-04-02 2023-09-19 Twilio Inc. System and method for processing telephony sessions
US10694042B2 (en) 2008-04-02 2020-06-23 Twilio Inc. System and method for processing media requests during telephony sessions
US11444985B2 (en) 2008-04-02 2022-09-13 Twilio Inc. System and method for processing telephony sessions
US11856150B2 (en) 2008-04-02 2023-12-26 Twilio Inc. System and method for processing telephony sessions
US11575795B2 (en) 2008-04-02 2023-02-07 Twilio Inc. System and method for processing telephony sessions
US10986142B2 (en) 2008-04-02 2021-04-20 Twilio Inc. System and method for processing telephony sessions
US11843722B2 (en) 2008-04-02 2023-12-12 Twilio Inc. System and method for processing telephony sessions
US9591033B2 (en) 2008-04-02 2017-03-07 Twilio, Inc. System and method for processing media requests during telephony sessions
US9306982B2 (en) 2008-04-02 2016-04-05 Twilio, Inc. System and method for processing media requests during telephony sessions
US11283843B2 (en) 2008-04-02 2022-03-22 Twilio Inc. System and method for processing telephony sessions
US11611663B2 (en) 2008-04-02 2023-03-21 Twilio Inc. System and method for processing telephony sessions
US10455094B2 (en) 2008-10-01 2019-10-22 Twilio Inc. Telephony web event system and method
US10187530B2 (en) 2008-10-01 2019-01-22 Twilio, Inc. Telephony web event system and method
US11641427B2 (en) 2008-10-01 2023-05-02 Twilio Inc. Telephony web event system and method
US11665285B2 (en) 2008-10-01 2023-05-30 Twilio Inc. Telephony web event system and method
US11632471B2 (en) 2008-10-01 2023-04-18 Twilio Inc. Telephony web event system and method
US11005998B2 (en) 2008-10-01 2021-05-11 Twilio Inc. Telephony web event system and method
US9807244B2 (en) 2008-10-01 2017-10-31 Twilio, Inc. Telephony web event system and method
US9407597B2 (en) 2008-10-01 2016-08-02 Twilio, Inc. Telephony web event system and method
US11785145B2 (en) 2009-03-02 2023-10-10 Twilio Inc. Method and system for a multitenancy telephone network
US10348908B2 (en) 2009-03-02 2019-07-09 Twilio, Inc. Method and system for a multitenancy telephone network
US9357047B2 (en) 2009-03-02 2016-05-31 Twilio, Inc. Method and system for a multitenancy telephone network
US9894212B2 (en) 2009-03-02 2018-02-13 Twilio, Inc. Method and system for a multitenancy telephone network
US11240381B2 (en) 2009-03-02 2022-02-01 Twilio Inc. Method and system for a multitenancy telephone network
US9621733B2 (en) 2009-03-02 2017-04-11 Twilio, Inc. Method and system for a multitenancy telephone network
US10708437B2 (en) 2009-03-02 2020-07-07 Twilio Inc. Method and system for a multitenancy telephone network
US11637933B2 (en) 2009-10-07 2023-04-25 Twilio Inc. System and method for running a multi-module telephony application
US10554825B2 (en) 2009-10-07 2020-02-04 Twilio Inc. System and method for running a multi-module telephony application
US9491309B2 (en) 2009-10-07 2016-11-08 Twilio, Inc. System and method for running a multi-module telephony application
US10721269B1 (en) 2009-11-06 2020-07-21 F5 Networks, Inc. Methods and system for returning requests with javascript for clients before passing a request to a server
US11108815B1 (en) 2009-11-06 2021-08-31 F5 Networks, Inc. Methods and system for returning requests with javascript for clients before passing a request to a server
US9590849B2 (en) 2010-06-23 2017-03-07 Twilio, Inc. System and method for managing a computing cluster
US11637934B2 (en) 2010-06-23 2023-04-25 Twilio Inc. System and method for monitoring account usage on a platform
US9459925B2 (en) 2010-06-23 2016-10-04 Twilio, Inc. System and method for managing a computing cluster
US9338064B2 (en) 2010-06-23 2016-05-10 Twilio, Inc. System and method for managing a computing cluster
US9459926B2 (en) 2010-06-23 2016-10-04 Twilio, Inc. System and method for managing a computing cluster
US10015286B1 (en) 2010-06-23 2018-07-03 F5 Networks, Inc. System and method for proxying HTTP single sign on across network domains
US9967224B2 (en) 2010-06-25 2018-05-08 Twilio, Inc. System and method for enabling real-time eventing
US11936609B2 (en) 2010-06-25 2024-03-19 Twilio Inc. System and method for enabling real-time eventing
US11088984B2 (en) 2010-06-25 2021-08-10 Twilio Ine. System and method for enabling real-time eventing
USRE47019E1 (en) 2010-07-14 2018-08-28 F5 Networks, Inc. Methods for DNSSEC proxying and deployment amelioration and systems thereof
US9554276B2 (en) 2010-10-29 2017-01-24 F5 Networks, Inc. System and method for on the fly protocol conversion in obtaining policy enforcement information
US10135831B2 (en) 2011-01-28 2018-11-20 F5 Networks, Inc. System and method for combining an access control system with a traffic management system
US10230772B2 (en) 2011-02-04 2019-03-12 Twilio, Inc. Method for processing telephony sessions of a network
US9455949B2 (en) 2011-02-04 2016-09-27 Twilio, Inc. Method for processing telephony sessions of a network
US11032330B2 (en) 2011-02-04 2021-06-08 Twilio Inc. Method for processing telephony sessions of a network
US9882942B2 (en) 2011-02-04 2018-01-30 Twilio, Inc. Method for processing telephony sessions of a network
US10708317B2 (en) 2011-02-04 2020-07-07 Twilio Inc. Method for processing telephony sessions of a network
US11848967B2 (en) 2011-02-04 2023-12-19 Twilio Inc. Method for processing telephony sessions of a network
US11399044B2 (en) 2011-05-23 2022-07-26 Twilio Inc. System and method for connecting a communication to a client
US10122763B2 (en) 2011-05-23 2018-11-06 Twilio, Inc. System and method for connecting a communication to a client
US10165015B2 (en) 2011-05-23 2018-12-25 Twilio Inc. System and method for real-time communication by using a client application communication protocol
US10560485B2 (en) 2011-05-23 2020-02-11 Twilio Inc. System and method for connecting a communication to a client
US9648006B2 (en) 2011-05-23 2017-05-09 Twilio, Inc. System and method for communicating with a client application
US9398622B2 (en) 2011-05-23 2016-07-19 Twilio, Inc. System and method for connecting a communication to a client
US10819757B2 (en) 2011-05-23 2020-10-27 Twilio Inc. System and method for real-time communication by using a client application communication protocol
US20130054806A1 (en) * 2011-08-31 2013-02-28 Metaswitch Networks Ltd Load Balancing for SIP Services
US8775628B2 (en) * 2011-08-31 2014-07-08 Metaswitch Networks Ltd. Load balancing for SIP services
US10841421B2 (en) 2011-09-21 2020-11-17 Twilio Inc. System and method for determining and communicating presence information
US10686936B2 (en) 2011-09-21 2020-06-16 Twilio Inc. System and method for determining and communicating presence information
US9641677B2 (en) 2011-09-21 2017-05-02 Twilio, Inc. System and method for determining and communicating presence information
US9942394B2 (en) 2011-09-21 2018-04-10 Twilio, Inc. System and method for determining and communicating presence information
US11489961B2 (en) 2011-09-21 2022-11-01 Twilio Inc. System and method for determining and communicating presence information
US10182147B2 (en) 2011-09-21 2019-01-15 Twilio Inc. System and method for determining and communicating presence information
US10212275B2 (en) 2011-09-21 2019-02-19 Twilio, Inc. System and method for determining and communicating presence information
US9336500B2 (en) 2011-09-21 2016-05-10 Twilio, Inc. System and method for authorizing and connecting application developers and users
US9270766B2 (en) 2011-12-30 2016-02-23 F5 Networks, Inc. Methods for identifying network traffic characteristics to correlate and manage one or more subsequent flows and devices thereof
US9985976B1 (en) 2011-12-30 2018-05-29 F5 Networks, Inc. Methods for identifying network traffic characteristics to correlate and manage one or more subsequent flows and devices thereof
US9021109B1 (en) * 2012-01-23 2015-04-28 Amazon Technologies, Inc. Controlling requests through message headers
US9495227B2 (en) * 2012-02-10 2016-11-15 Twilio, Inc. System and method for managing concurrent events
US10467064B2 (en) 2012-02-10 2019-11-05 Twilio Inc. System and method for managing concurrent events
US20130212603A1 (en) * 2012-02-10 2013-08-15 Twilio, Inc. System and method for managing concurrent events
US11093305B2 (en) 2012-02-10 2021-08-17 Twilio Inc. System and method for managing concurrent events
US10230566B1 (en) 2012-02-17 2019-03-12 F5 Networks, Inc. Methods for dynamically constructing a service principal name and devices thereof
US9231879B1 (en) * 2012-02-20 2016-01-05 F5 Networks, Inc. Methods for policy-based network traffic queue management and devices thereof
US10097616B2 (en) 2012-04-27 2018-10-09 F5 Networks, Inc. Methods for optimizing service of content requests and devices thereof
US10637912B2 (en) 2012-05-09 2020-04-28 Twilio Inc. System and method for managing media in a distributed communication network
US9240941B2 (en) 2012-05-09 2016-01-19 Twilio, Inc. System and method for managing media in a distributed communication network
US9350642B2 (en) 2012-05-09 2016-05-24 Twilio, Inc. System and method for managing latency in a distributed telephony network
US9602586B2 (en) 2012-05-09 2017-03-21 Twilio, Inc. System and method for managing media in a distributed communication network
US11165853B2 (en) 2012-05-09 2021-11-02 Twilio Inc. System and method for managing media in a distributed communication network
US10200458B2 (en) 2012-05-09 2019-02-05 Twilio, Inc. System and method for managing media in a distributed communication network
US9247062B2 (en) 2012-06-19 2016-01-26 Twilio, Inc. System and method for queuing a communication session
US11546471B2 (en) 2012-06-19 2023-01-03 Twilio Inc. System and method for queuing a communication session
US10320983B2 (en) 2012-06-19 2019-06-11 Twilio Inc. System and method for queuing a communication session
US9614972B2 (en) 2012-07-24 2017-04-04 Twilio, Inc. Method and system for preventing illicit use of a telephony platform
US9270833B2 (en) 2012-07-24 2016-02-23 Twilio, Inc. Method and system for preventing illicit use of a telephony platform
US11882139B2 (en) 2012-07-24 2024-01-23 Twilio Inc. Method and system for preventing illicit use of a telephony platform
US9948788B2 (en) 2012-07-24 2018-04-17 Twilio, Inc. Method and system for preventing illicit use of a telephony platform
US10469670B2 (en) 2012-07-24 2019-11-05 Twilio Inc. Method and system for preventing illicit use of a telephony platform
US11063972B2 (en) 2012-07-24 2021-07-13 Twilio Inc. Method and system for preventing illicit use of a telephony platform
US9319857B2 (en) 2012-10-15 2016-04-19 Twilio, Inc. System and method for triggering on platform usage
US9307094B2 (en) 2012-10-15 2016-04-05 Twilio, Inc. System and method for routing communications
US9654647B2 (en) 2012-10-15 2017-05-16 Twilio, Inc. System and method for routing communications
US11595792B2 (en) 2012-10-15 2023-02-28 Twilio Inc. System and method for triggering on platform usage
US11246013B2 (en) 2012-10-15 2022-02-08 Twilio Inc. System and method for triggering on platform usage
US10257674B2 (en) 2012-10-15 2019-04-09 Twilio, Inc. System and method for triggering on platform usage
US11689899B2 (en) 2012-10-15 2023-06-27 Twilio Inc. System and method for triggering on platform usage
US10033617B2 (en) 2012-10-15 2018-07-24 Twilio, Inc. System and method for triggering on platform usage
US10757546B2 (en) 2012-10-15 2020-08-25 Twilio Inc. System and method for triggering on platform usage
US9253254B2 (en) 2013-01-14 2016-02-02 Twilio, Inc. System and method for offering a multi-partner delegated platform
US10375155B1 (en) 2013-02-19 2019-08-06 F5 Networks, Inc. System and method for achieving hardware acceleration for asymmetric flow connections
US11637876B2 (en) 2013-03-14 2023-04-25 Twilio Inc. System and method for integrating session initiation protocol communication in a telecommunications platform
US9282124B2 (en) 2013-03-14 2016-03-08 Twilio, Inc. System and method for integrating session initiation protocol communication in a telecommunications platform
US11032325B2 (en) 2013-03-14 2021-06-08 Twilio Inc. System and method for integrating session initiation protocol communication in a telecommunications platform
US10051011B2 (en) 2013-03-14 2018-08-14 Twilio, Inc. System and method for integrating session initiation protocol communication in a telecommunications platform
US10560490B2 (en) 2013-03-14 2020-02-11 Twilio Inc. System and method for integrating session initiation protocol communication in a telecommunications platform
US9240966B2 (en) 2013-06-19 2016-01-19 Twilio, Inc. System and method for transmitting and receiving media messages
US9338280B2 (en) 2013-06-19 2016-05-10 Twilio, Inc. System and method for managing telephony endpoint inventory
US9225840B2 (en) 2013-06-19 2015-12-29 Twilio, Inc. System and method for providing a communication endpoint information service
US9992608B2 (en) 2013-06-19 2018-06-05 Twilio, Inc. System and method for providing a communication endpoint information service
US10057734B2 (en) 2013-06-19 2018-08-21 Twilio Inc. System and method for transmitting and receiving media messages
US9160696B2 (en) 2013-06-19 2015-10-13 Twilio, Inc. System for transforming media resource into destination device compatible messaging format
US9483328B2 (en) 2013-07-19 2016-11-01 Twilio, Inc. System and method for delivering application content
US11539601B2 (en) 2013-09-17 2022-12-27 Twilio Inc. System and method for providing communication platform metadata
US10671452B2 (en) 2013-09-17 2020-06-02 Twilio Inc. System and method for tagging and tracking events of an application
US9811398B2 (en) 2013-09-17 2017-11-07 Twilio, Inc. System and method for tagging and tracking events of an application platform
US9137127B2 (en) 2013-09-17 2015-09-15 Twilio, Inc. System and method for providing communication platform metadata
US9274858B2 (en) 2013-09-17 2016-03-01 Twilio, Inc. System and method for tagging and tracking events of an application platform
US9853872B2 (en) 2013-09-17 2017-12-26 Twilio, Inc. System and method for providing communication platform metadata
US11379275B2 (en) 2013-09-17 2022-07-05 Twilio Inc. System and method for tagging and tracking events of an application
US9959151B2 (en) 2013-09-17 2018-05-01 Twilio, Inc. System and method for tagging and tracking events of an application platform
US10439907B2 (en) 2013-09-17 2019-10-08 Twilio Inc. System and method for providing communication platform metadata
US9338018B2 (en) 2013-09-17 2016-05-10 Twilio, Inc. System and method for pricing communication of a telecommunication platform
US11394673B2 (en) 2013-11-12 2022-07-19 Twilio Inc. System and method for enabling dynamic multi-modal communication
US10069773B2 (en) 2013-11-12 2018-09-04 Twilio, Inc. System and method for enabling dynamic multi-modal communication
US10686694B2 (en) 2013-11-12 2020-06-16 Twilio Inc. System and method for client communication in a distributed telephony network
US10063461B2 (en) 2013-11-12 2018-08-28 Twilio, Inc. System and method for client communication in a distributed telephony network
US9553799B2 (en) 2013-11-12 2017-01-24 Twilio, Inc. System and method for client communication in a distributed telephony network
US11831415B2 (en) 2013-11-12 2023-11-28 Twilio Inc. System and method for enabling dynamic multi-modal communication
US9325624B2 (en) 2013-11-12 2016-04-26 Twilio, Inc. System and method for enabling dynamic multi-modal communication
US11621911B2 (en) 2013-11-12 2023-04-04 Twillo Inc. System and method for client communication in a distributed telephony network
US10187317B1 (en) 2013-11-15 2019-01-22 F5 Networks, Inc. Methods for traffic rate control and devices thereof
US11882242B2 (en) 2014-03-14 2024-01-23 Twilio Inc. System and method for a work distribution service
US11330108B2 (en) 2014-03-14 2022-05-10 Twilio Inc. System and method for a work distribution service
US10003693B2 (en) 2014-03-14 2018-06-19 Twilio, Inc. System and method for a work distribution service
US10291782B2 (en) 2014-03-14 2019-05-14 Twilio, Inc. System and method for a work distribution service
US9628624B2 (en) 2014-03-14 2017-04-18 Twilio, Inc. System and method for a work distribution service
US9344573B2 (en) 2014-03-14 2016-05-17 Twilio, Inc. System and method for a work distribution service
US10904389B2 (en) 2014-03-14 2021-01-26 Twilio Inc. System and method for a work distribution service
US10440627B2 (en) 2014-04-17 2019-10-08 Twilio Inc. System and method for enabling multi-modal communication
US10873892B2 (en) 2014-04-17 2020-12-22 Twilio Inc. System and method for enabling multi-modal communication
US9226217B2 (en) 2014-04-17 2015-12-29 Twilio, Inc. System and method for enabling multi-modal communication
US11653282B2 (en) 2014-04-17 2023-05-16 Twilio Inc. System and method for enabling multi-modal communication
US9907010B2 (en) 2014-04-17 2018-02-27 Twilio, Inc. System and method for enabling multi-modal communication
US10015143B1 (en) 2014-06-05 2018-07-03 F5 Networks, Inc. Methods for securing one or more license entitlement grants and devices thereof
US11457062B2 (en) * 2014-06-17 2022-09-27 Datenlotsen Informationssysteme Gmbh Client-server system and terminal
US20170149872A1 (en) * 2014-06-17 2017-05-25 Datenlotsen Informationssysteme Gmbh Client-server system and terminal
US9774687B2 (en) 2014-07-07 2017-09-26 Twilio, Inc. System and method for managing media and signaling in a communication platform
US10212237B2 (en) 2014-07-07 2019-02-19 Twilio, Inc. System and method for managing media and signaling in a communication platform
US9246694B1 (en) 2014-07-07 2016-01-26 Twilio, Inc. System and method for managing conferencing in a distributed communication network
US9858279B2 (en) 2014-07-07 2018-01-02 Twilio, Inc. Method and system for applying data retention policies in a computing platform
US11755530B2 (en) 2014-07-07 2023-09-12 Twilio Inc. Method and system for applying data retention policies in a computing platform
US11768802B2 (en) 2014-07-07 2023-09-26 Twilio Inc. Method and system for applying data retention policies in a computing platform
US11341092B2 (en) 2014-07-07 2022-05-24 Twilio Inc. Method and system for applying data retention policies in a computing platform
US9251371B2 (en) 2014-07-07 2016-02-02 Twilio, Inc. Method and system for applying data retention policies in a computing platform
US10116733B2 (en) 2014-07-07 2018-10-30 Twilio, Inc. System and method for collecting feedback in a multi-tenant communication platform
US10747717B2 (en) 2014-07-07 2020-08-18 Twilio Inc. Method and system for applying data retention policies in a computing platform
US9588974B2 (en) 2014-07-07 2017-03-07 Twilio, Inc. Method and system for applying data retention policies in a computing platform
US9553900B2 (en) 2014-07-07 2017-01-24 Twilio, Inc. System and method for managing conferencing in a distributed communication network
US9516101B2 (en) 2014-07-07 2016-12-06 Twilio, Inc. System and method for collecting feedback in a multi-tenant communication platform
US10757200B2 (en) 2014-07-07 2020-08-25 Twilio Inc. System and method for managing conferencing in a distributed communication network
US10229126B2 (en) 2014-07-07 2019-03-12 Twilio, Inc. Method and system for applying data retention policies in a computing platform
US11838851B1 (en) 2014-07-15 2023-12-05 F5, Inc. Methods for managing L7 traffic classification and devices thereof
US9686170B2 (en) 2014-07-18 2017-06-20 International Business Machines Corporation Measuring delay
US10122630B1 (en) 2014-08-15 2018-11-06 F5 Networks, Inc. Methods for network traffic presteering and devices thereof
US10637938B2 (en) 2014-10-21 2020-04-28 Twilio Inc. System and method for providing a micro-services communication platform
US9363301B2 (en) 2014-10-21 2016-06-07 Twilio, Inc. System and method for providing a micro-services communication platform
US9509782B2 (en) 2014-10-21 2016-11-29 Twilio, Inc. System and method for providing a micro-services communication platform
US11019159B2 (en) 2014-10-21 2021-05-25 Twilio Inc. System and method for providing a micro-services communication platform
US9906607B2 (en) 2014-10-21 2018-02-27 Twilio, Inc. System and method for providing a micro-services communication platform
US10182013B1 (en) 2014-12-01 2019-01-15 F5 Networks, Inc. Methods for managing progressive image delivery and devices thereof
US11895138B1 (en) 2015-02-02 2024-02-06 F5, Inc. Methods for improving web scanner accuracy and devices thereof
US10853854B2 (en) 2015-02-03 2020-12-01 Twilio Inc. System and method for a media intelligence platform
US10467665B2 (en) 2015-02-03 2019-11-05 Twilio Inc. System and method for a media intelligence platform
US9805399B2 (en) 2015-02-03 2017-10-31 Twilio, Inc. System and method for a media intelligence platform
US9477975B2 (en) 2015-02-03 2016-10-25 Twilio, Inc. System and method for a media intelligence platform
US11544752B2 (en) 2015-02-03 2023-01-03 Twilio Inc. System and method for a media intelligence platform
US10834065B1 (en) 2015-03-31 2020-11-10 F5 Networks, Inc. Methods for SSL protected NTLM re-authentication and devices thereof
US10505818B1 (en) 2015-05-05 2019-12-10 F5 Networks. Inc. Methods for analyzing and load balancing based on server health and devices thereof
US11350254B1 (en) 2015-05-05 2022-05-31 F5, Inc. Methods for enforcing compliance policies and devices thereof
US11272325B2 (en) 2015-05-14 2022-03-08 Twilio Inc. System and method for communicating through multiple endpoints
US10560516B2 (en) 2015-05-14 2020-02-11 Twilio Inc. System and method for signaling through data storage
US11265367B2 (en) 2015-05-14 2022-03-01 Twilio Inc. System and method for signaling through data storage
US9948703B2 (en) 2015-05-14 2018-04-17 Twilio, Inc. System and method for signaling through data storage
US10419891B2 (en) 2015-05-14 2019-09-17 Twilio, Inc. System and method for communicating through multiple endpoints
US11212568B2 (en) * 2015-10-30 2021-12-28 Rovi Guides, Inc. Methods and systems for monitoring content subscription usage
US11159500B2 (en) 2015-10-30 2021-10-26 Rovi Guides, Inc. Methods and systems for managing content subscription data
US11757946B1 (en) 2015-12-22 2023-09-12 F5, Inc. Methods for analyzing network traffic and enforcing network policies and devices thereof
US10404698B1 (en) 2016-01-15 2019-09-03 F5 Networks, Inc. Methods for adaptive organization of web application access points in webtops and devices thereof
US11178150B1 (en) 2016-01-20 2021-11-16 F5 Networks, Inc. Methods for enforcing access control list based on managed application and devices thereof
US10797888B1 (en) 2016-01-20 2020-10-06 F5 Networks, Inc. Methods for secured SCEP enrollment for client devices and devices thereof
US10659349B2 (en) 2016-02-04 2020-05-19 Twilio Inc. Systems and methods for providing secure network exchanged for a multitenant virtual private cloud
US11171865B2 (en) 2016-02-04 2021-11-09 Twilio Inc. Systems and methods for providing secure network exchanged for a multitenant virtual private cloud
US10686902B2 (en) 2016-05-23 2020-06-16 Twilio Inc. System and method for a multi-channel notification service
US10440192B2 (en) 2016-05-23 2019-10-08 Twilio Inc. System and method for programmatic device connectivity
US11265392B2 (en) 2016-05-23 2022-03-01 Twilio Inc. System and method for a multi-channel notification service
US11622022B2 (en) 2016-05-23 2023-04-04 Twilio Inc. System and method for a multi-channel notification service
US11076054B2 (en) 2016-05-23 2021-07-27 Twilio Inc. System and method for programmatic device connectivity
US11627225B2 (en) 2016-05-23 2023-04-11 Twilio Inc. System and method for programmatic device connectivity
US10063713B2 (en) 2016-05-23 2018-08-28 Twilio Inc. System and method for programmatic device connectivity
US10791088B1 (en) 2016-06-17 2020-09-29 F5 Networks, Inc. Methods for disaggregating subscribers via DHCP address translation and devices thereof
CN107872396A (en) * 2016-09-26 2018-04-03 华为技术有限公司 Communication means, processing equipment, terminal device and server with overtime control
US10505792B1 (en) 2016-11-02 2019-12-10 F5 Networks, Inc. Methods for facilitating network traffic analytics and devices thereof
US10503540B2 (en) * 2017-02-10 2019-12-10 Fuji Xerox Co., Ltd. Information processing apparatus and non-transitory computer readable medium
US20180232253A1 (en) * 2017-02-10 2018-08-16 Fuji Xerox Co., Ltd. Information processing apparatus and non-transitory computer readable medium
US10812266B1 (en) 2017-03-17 2020-10-20 F5 Networks, Inc. Methods for managing security tokens based on security violations and devices thereof
US10972453B1 (en) 2017-05-03 2021-04-06 F5 Networks, Inc. Methods for token refreshment based on single sign-on (SSO) for federated identity environments and devices thereof
US11122042B1 (en) 2017-05-12 2021-09-14 F5 Networks, Inc. Methods for dynamically managing user access control and devices thereof
US11343237B1 (en) 2017-05-12 2022-05-24 F5, Inc. Methods for managing a federated identity environment using security and access control data and devices thereof
US11709707B2 (en) 2017-07-21 2023-07-25 Red Hat, Inc. Low latency distributed counters for quotas
US20190250956A1 (en) * 2017-07-21 2019-08-15 Red Hat, Inc. Low latency distributed counters for quotas
US10963305B2 (en) * 2017-07-21 2021-03-30 Red Hat, Inc. Low latency distributed counters for quotas
US10574758B2 (en) 2017-07-28 2020-02-25 International Business Machines Corporation Server connection capacity management
US10616346B2 (en) 2017-07-28 2020-04-07 International Business Machines Corporation Server connection capacity management
US11070625B2 (en) 2017-07-28 2021-07-20 International Business Machines Corporation Server connection capacity management
US11652905B2 (en) * 2017-08-14 2023-05-16 Jio Platforms Limited Systems and methods for controlling real-time traffic surge of application programming interfaces (APIs) at server
US11122083B1 (en) 2017-09-08 2021-09-14 F5 Networks, Inc. Methods for managing network connections based on DNS data and network policies and devices thereof
US11792275B2 (en) 2018-11-30 2023-10-17 International Business Machines Corporation Dynamic connection capacity management
US11553047B2 (en) 2018-11-30 2023-01-10 International Business Machines Corporation Dynamic connection capacity management
US11012512B1 (en) * 2020-05-20 2021-05-18 EMC IP Holding Company LLC Host device with automated write throttling responsive to storage system write pressure condition
US11550511B2 (en) 2021-05-21 2023-01-10 EMC IP Holding Company LLC Write pressure throttling based on service level objectives
US20230107052A1 (en) * 2021-10-06 2023-04-06 Imperva, Inc. Waiting room with zero latency
US11900182B2 (en) * 2021-10-06 2024-02-13 Imperva, Inc. Waiting room with zero latency
CN114500391A (en) * 2021-12-28 2022-05-13 上海弘积信息科技有限公司 Method for dealing with instantaneous overlarge flow
US11934659B1 (en) 2022-09-28 2024-03-19 Dell Products L.P. Host background copy process with rate adjustment utilizing input-output processing pressure feedback from storage system

Similar Documents

Publication Publication Date Title
US8417817B1 (en) Preventing server overload
US20210311781A1 (en) Method and system for scalable job processing
US20200287794A1 (en) Intelligent autoscale of services
US9729488B2 (en) On-demand mailbox synchronization and migration system
US8949258B2 (en) Techniques to manage file conversions
US9699250B2 (en) Method and system for building an elastic cloud web server farm
US8589923B2 (en) Preprovisioning virtual machines based on request frequency and current network configuration
US8275787B2 (en) System for managing data collection processes
US11119813B1 (en) Mapreduce implementation using an on-demand network code execution system
US20180018293A1 (en) Method, controller, and system for service flow control in object-based storage system
US9424075B1 (en) Dynamic virtual partitioning for delayed queues
US8745635B2 (en) Managing business process messaging
US9596127B2 (en) Scalable data feed system
WO2018108001A1 (en) System and method to handle events using historical data in serverless systems
CN104396200A (en) Ensuring predictable and quantifiable networking performance
US11249826B2 (en) Link optimization for callout request messages
US9596298B1 (en) Load balancing in a distributed processing system
US10944683B1 (en) Hybrid queue system for request throttling
US9270617B2 (en) Load controller framework
CN109428926B (en) Method and device for scheduling task nodes
CN112052133A (en) Service system monitoring method and device based on Kubernetes
CN111831503B (en) Monitoring method based on monitoring agent and monitoring agent device
WO2014105155A1 (en) Communication system
US20110246553A1 (en) Validation of internal data in batch applications
US11669365B1 (en) Task pool for managed compute instances

Legal Events

Date Code Title Description
AS Assignment

Owner name: GOOGLE INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:JACOBS, AARON;REEL/FRAME:025167/0863

Effective date: 20100917

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: GOOGLE LLC, CALIFORNIA

Free format text: CHANGE OF NAME;ASSIGNOR:GOOGLE INC.;REEL/FRAME:044101/0299

Effective date: 20170929

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20210409