Distributed system to determine a server's health

US9906422B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9906422-B2
Application numberUS-201414280481-A
CountryUS
Kind codeB2
Filing dateMay 16, 2014
Priority dateMay 16, 2014
Publication dateFeb 27, 2018
Grant dateFeb 27, 2018

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Exemplary embodiments for a distributed system for determining a server's health are disclosed. The systems and methods provide for a network controller to direct one or more servicing nodes to check the health of one or more servers, and report a health score to the network controller. The network controller may then calculate, update and maintain a health score for each server in the network from the various health scores reported to it from the servicing nodes. This allows a distributed system to be used to facilitate network operations, as a single device is not relied on for periodically determining each server's health.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for determining, at a network controller, a health score of a server, the method comprising: receiving, from a client, a request for a service session with a server of a plurality of servers, each of the plurality of servers being in communication with one or more servicing nodes of a plurality of servicing nodes; directing the plurality of servicing nodes in communication with the network controller to determine a health score of at least one of the plurality of servers, each of the plurality of servicing nodes being configured to determine the health score of the one or more of the plurality of servers, the determining of the health score by each of the plurality of servicing nodes including determining a server health score of the one or more of the plurality of servers based at least on reachability of the one or more of the plurality of servers, the reachability being determined by sending a query to the one or more of the plurality of servers and examining whether the one or more of the plurality of servers respond to the query; receiving the health score of the at least one server from each of the plurality of servicing nodes; calculating an aggregated health score for each server of the plurality of servers using the received health scores from the plurality of servicing nodes; and sending the aggregated health score to a servicing node of the plurality of servicing nodes, the servicing node being designated to process the service session by selecting, based at least on the aggregated health score, one of the plurality of servers for providing the service associated with the service session and directing the request for the service session to the selected one of the plurality of servers, wherein the servicing node designated to process the service session is not one of the plurality of servicing nodes that reported the health score of the one of the plurality of servers to the network controller. 2. The method of claim 1 , wherein the sending the aggregated health score to the servicing node designated to process the service session enables the servicing node to use the aggregated health score to select the server or not to select the server for the service session. 3. The method of claim 2 , wherein the servicing node designated to process the service session is one of the plurality of servicing nodes directed to determine a health score of at least one of the plurality of servers, and the aggregated health score conflicts with the health score determined by the servicing node. 4. The method of claim 3 , wherein the servicing node designated to process the service session does not select the server based on the aggregated health score when the servicing node designated to process the service session would have selected the server if using the health score determined by the servicing node. 5. The method of claim 1 , wherein, based on the aggregated health score, the servicing node designated to process the service session does not select the server, when the servicing node would have selected the server without using the aggregated health score. 6. The method of claim 1 , wherein the aggregated health score is based on a majority of health scores received by the network controller. 7. The method of claim 6 , wherein the majority of received health scores indicate that the server is in good health, or the majority of received health scores indicate that the server is in poor health. 8. The method of claim 1 , wherein the calculating is based on an average of the received health scores, or a weighted average of the received health scores. 9. The method of claim 1 , further comprising: receiving one or more updated health scores from at least one of the plurality of servicing nodes; calculating an updated aggregated health score based on the one or more updated health scores; and sending the updated aggregated health score to the servicing node designated to process the service session. 10. The method of claim 1 , wherein at least one of the received health scores comprises one or more scores related to connectivity, system resource utilization, number of connections, and load of a service application. 11. A non-transitory computer-readable storage medium comprising instructions, which when executed by one or more processors of a network controller, perform a method for determining a health score of a server, the method comprising: receiving, from a client, a request for a service session with a server of a plurality of servers, each of the plurality of servers being in communication with one or more servicing nodes of a plurality of servicing nodes; directing the plurality of servicing nodes in communication with the network controller to determine a health score of at least one of the plurality of servers, each of the plurality of servicing nodes being configured to determine the health score of the one or more of the plurality of servers, the determining of the health score by each of the plurality of servicing nodes including determining a server health score of the one or more of the plurality of servers based at least on reachability of the one or more of the plurality of servers, the reachability being determined by sending a query to the one or more of the plurality of servers and examining whether the one or more of the plurality of servers respond to the query; receiving the health score of the at least one server from each of the plurality of servicing nodes; calculating an aggregated health score for each server of the plurality of servers using the received health scores from the plurality of servicing nodes; and sending the aggregated health score to a servicing node of the plurality of servicing nodes, the servicing node being designated to process the service session by selecting, based at least on the aggregated health score, one of the plurality of servers for providing the service associated with the service session and directing the request for the service session to the selected one of the plurality of servers, wherein the servicing node designated to process the service session is not one of the plurality of servicing nodes that reported the health score of the one of the plurality of servers to the network controller. 12. A system for determining a health score of a server, the system comprising: a plurality of servicing nodes in communication with a plurality of servers that provide a service; and a network controller comprising a processor and a memory, the network controller in communication with the plurality of servicing nodes, the network controller configured to: receive, from a client a request for a service session from a client with a server of a plurality of servers, each of the plurality of servers being in communication with one or more servicing nodes of the plurality of servicing nodes: direct at least one the plurality of servicing nodes to determine a health score of at least one of the plurality of servers, each of the plurality of servicing nodes being configured to determine the health score of the one or more of the plurality of servers, the determining of the health score by each of the plurality of servicing nodes including determining a server health score of the one or more of the plurality of servers based at least on reachability of the one or more of the plurality of servers, the reachability being determined by sending a query to the one or more of the plurality of servers and examining whether the one or more of the plurality of servers respond to the query; receive the health score of the at least one server from each of the at least one plurality of servicing nodes; calculate an

Assignees

Inventors

Classifications

  • Processing captured monitoring data, e.g. for logfile generation · CPC title

  • by checking functioning · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9906422B2 cover?
Exemplary embodiments for a distributed system for determining a server's health are disclosed. The systems and methods provide for a network controller to direct one or more servicing nodes to check the health of one or more servers, and report a health score to the network controller. The network controller may then calculate, update and maintain a health score for each server in the network …
Who is the assignee on this patent?
A10 Networks Inc
What technology area does this patent fall under?
Primary CPC classification H04L43/0817. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Feb 27 2018 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).