×

Client-initiated leader election in distributed client-server systems

  • US 9,667,750 B2
  • Filed: 10/21/2016
  • Issued: 05/30/2017
  • Est. Priority Date: 09/08/2015
  • Status: Expired due to Fees
First Claim
Patent Images

1. A computer system for a client-initiated leader election in a distributed client server computing system comprising a plurality of server computers and a client computer, the computer system comprising:

  • one or more hardware computer processors, one or more computer-readable storage media, and program instructions stored on the one or more computer-readable storage media for execution by at least one of the one or more computer processors, the program instructions comprising;

    program instructions to establish a connection between a first server computer of the plurality of server computers and the client computer;

    program instructions to receive, by the first server computer, a master server election request from the client computer;

    program instructions to determine if one of the plurality of server computers is designated as a master server in a master server cache by reading a system configuration of the distributed client server computing system in response to receiving the master server election request from the client computer, wherein the master server cache stores information designating one of the plurality of server computers as the master server;

    program instructions to obtain a list of the plurality of server computers from a configuration management system in response to no one server computer of the plurality of server computers being designated as the master server in the master server cache;

    program instructions to arrange the list of the plurality of server computers in a descending order based on a predetermined priority of each server computer to become the master server;

    program instructions to verify connectivity to a second server computer of the plurality of server computers by sending a test message to the second server computer using a ping utility program, wherein the second server computer is one of the plurality of server computers on the list having the highest priority;

    program instructions to designate the second server computer as the master server in response to verifying connectivity to the second server computer by updating the master server cache;

    program instructions to update system configuration and notifying all of the plurality of server computers of the distributed client server computing system of the designation of the second server computer as the master server by sending a heartbeat message to each of the plurality of server computers;

    program instructions to send a response message to the client computer comprising information about the designation of the second server computer as the master server; and

    program instructions to establish a connection between the master server and the client computer, wherein the master server receives future requests from the client computer, forwards future requests received form the client computer onto an appropriate server computer of the plurality of server computers, and manages load balancing among all of the plurality of server computers.

View all claims
  • 2 Assignments
Timeline View
Assignment View
    ×
    ×