发明名称 CLIENT-INITIATED LEADER ELECTION IN DISTRIBUTED CLIENT-SERVER SYSTEMS
摘要 A method for a client-initiated leader election in a distributed system including receiving a master listener election request by at least one listener of a plurality of listeners in the distributed system, arranging a list of configured listeners in a descending priority order, the list of configured listeners comprises one or more listeners of the plurality of listeners set for connection, selecting a listener with a highest priority from the list of configured listeners, determining an availability of the selected listener, verifying a connectivity to the selected listener using a ping utility program, assigning the selected listener as a master listener based on the connectivity, and connecting to the master listener.
申请公布号 US2017070598(A1) 申请公布日期 2017.03.09
申请号 US201615299619 申请日期 2016.10.21
申请人 International Business Machines Corporation 发明人 Bute Yogesh A.;Shukla Hemant K.;Srivastava Vinod K.;Thube Sandip P.;Vadgama Dharmesh V.
分类号 H04L29/06;H04L12/26;H04L29/08 主分类号 H04L29/06
代理机构 代理人
主权项 1. A computer program product 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 program product comprising a computer readable storage medium having program instructions embodied therewith, the program instructions executable by a computer to cause the computer to perform a method comprising: establishing a connection between a first server computer of the plurality of server computers and the client computer; receiving, by the first server computer, a master server election request from the client computer; determining 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; obtaining 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; arranging 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; verifying 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; designating the second server computer as the master server in response to verifying connectivity to the second server computer by updating the master server cache; updating 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; sending a response message to the client computer comprising information about the designation of the second server computer as the master server; and establishing 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.
地址 Armonk NY US