Package org.jgroups.protocols.rules

Source Code of org.jgroups.protocols.rules.CheckFDMonitor

package org.jgroups.protocols.rules;

import org.jgroups.View;
import org.jgroups.protocols.FD;

/**
* Rule which checks if the FD monitor is running when we have more than 1 member. If not, starts it.
* The rule uninstalls itself if no FD protocol is found.
* @author Bela Ban
* @since  3.3
*/
public class CheckFDMonitor extends Rule {
    protected FD fd;

    public String name() {
        return getClass().getSimpleName();
    }

    public String description() {
        return "Starts FD.Monitor if membership > 1 and monitor isn't running";
    }

    public void init() {
        super.init();
        fd=(FD)sv.getProtocolStack().findProtocol(FD.class);
        if(fd == null) {
            log.info("FD was not found, uninstalling myself (" + getClass().getSimpleName() + ")");
            sv.uninstallRule(getClass().getSimpleName());
        }
    }

    public boolean eval() {
        return sv.getView() != null && sv.getView().size() > 1 && !fd.isMonitorRunning();
    }

    public String condition() {
        View view=sv.getView();
        return "Membership is " + (view != null? view.size() : "n/a") + ", FD.Monitor running=" + fd.isMonitorRunning();
    }

    public void trigger() throws Throwable {
        System.out.println(sv.getLocalAddress() + ": starting failure detection");
        fd.startFailureDetection();
    }

    public String toString() {
        return CheckFDMonitor.class.getSimpleName() + ": " + condition();
    }
}
TOP

Related Classes of org.jgroups.protocols.rules.CheckFDMonitor

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.