org.jgroups.protocols.pbcast.ServerGmsImpl Maven / Gradle / Ivy
Go to download
This artifact provides a single jar that contains all classes required to use remote Jakarta Enterprise Beans and Jakarta Messaging, including
all dependencies. It is intended for use by those not using maven, maven users should just import the Jakarta Enterprise Beans and
Jakarta Messaging BOM's instead (shaded JAR's cause lots of problems with maven, as it is very easy to inadvertently end up
with different versions on classes on the class path).
package org.jgroups.protocols.pbcast;
import org.jgroups.Address;
import org.jgroups.Message;
import org.jgroups.View;
import org.jgroups.util.Digest;
import org.jgroups.util.MergeId;
import org.jgroups.util.Promise;
import java.util.Collection;
import java.util.Map;
import java.util.Objects;
/**
* Common super class for CoordGmsImpl and ParticipantGmsImpl
* @author Bela Ban
*/
public abstract class ServerGmsImpl extends GmsImpl {
protected ServerGmsImpl(GMS gms) {
super(gms);
}
public void init() throws Exception {
super.init();
}
/**
* Invoked upon receiving a MERGE event from the MERGE layer. Starts the merge protocol.
* See description of protocol in DESIGN.
* @param views A List of different views detected by the merge protocol
*/
public void merge(Map views) {
merger.merge(views);
}
/**
* Get the view and digest and send back both (MergeData) in the form of a MERGE_RSP to the sender.
* If a merge is already in progress, send back a MergeData with the merge_rejected field set to true.
* @param sender The address of the merge leader
* @param merge_id The merge ID
* @param mbrs The set of members from which we expect responses
*/
public void handleMergeRequest(Address sender, MergeId merge_id, Collection extends Address> mbrs) {
merger.handleMergeRequest(sender, merge_id, mbrs);
}
public void handleMergeResponse(MergeData data, MergeId merge_id) {
merger.handleMergeResponse(data, merge_id);
}
public void handleMergeCancelled(MergeId merge_id) {
merger.handleMergeCancelled(merge_id);
}
/**
* Called by the GMS when a VIEW is received.
* @param view The view to be installed
* @param digest If view is a MergeView, the digest contains the seqnos of all members and has to be set by GMS
*/
public void handleViewChange(View view, Digest digest) {
if(gms.isLeaving() && !view.containsMember(gms.local_addr))
return;
View prev_view=gms.view();
gms.installView(view, digest);
Address prev_coord=prev_view != null? prev_view.getCoord() : null, curr_coord=view.getCoord();
if(!Objects.equals(curr_coord, prev_coord))
coordChanged(prev_coord, curr_coord);
}
public void handleMergeView(final MergeData data,final MergeId merge_id) {
merger.handleMergeView(data, merge_id);
}
public void handleDigestResponse(Address sender, Digest digest) {
merger.handleDigestResponse(sender, digest);
}
protected void coordChanged(Address from, Address to) {}
/** Sends a leave request to coord and blocks until a leave response has been received,
or the leave timeout has elapsed */
protected boolean sendLeaveReqToCoord(final Address coord) {
if(coord == null) {
log.warn("%s: cannot send LEAVE request to null coord", gms.getLocalAddress());
return false;
}
Promise leave_promise=gms.getLeavePromise();
gms.setLeaving(true);
log.trace("%s: sending LEAVE request to %s", gms.local_addr, coord);
long start=System.currentTimeMillis();
sendLeaveMessage(coord, gms.local_addr);
Address sender=leave_promise.getResult(gms.leave_timeout);
if(!Objects.equals(coord, sender))
return false;
long time=System.currentTimeMillis()-start;
if(sender != null)
log.trace("%s: got LEAVE response from %s in %d ms", gms.local_addr, coord, time);
else
log.trace("%s: timed out waiting for LEAVE response from %s (after %d ms)", gms.local_addr, coord, time);
return true;
}
protected void sendLeaveMessage(Address coord, Address mbr) {
Message msg=new Message(coord).setFlag(Message.Flag.OOB)
.putHeader(gms.getId(), new GMS.GmsHeader(GMS.GmsHeader.LEAVE_REQ, mbr));
gms.getDownProtocol().down(msg);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy